Step 6. Create a customer and generate a customer token
Order processing with Inventory Management
In this step, we will create a customer account that is tied to the us
web view that we created in Step 1. Configure your environment. Before we can do this, we need to know the website and store view IDs.
Get the website and store view IDs
The GET /V1/store/storeViews
endpoint returns an array of store view IDs, along with the corresponding website and store group IDs. When you create a customer, change the id
parameter to the store_id
parameter
Endpoint:
GET <host>/rest/all/V1/store/storeViews
Scope:
all
store view
Headers:
Content-Type
: application/json
Authorization
: Bearer <admin_token>
Payload:
Not applicable
Response:
The value of the id
and website_id
parameters for the US Store View is 2
.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
[
{
"id": 1,
"code": "default",
"name": "Default Store View",
"website_id": 1,
"store_group_id": 1,
"is_active": 1
},
{
"id": 0,
"code": "admin",
"name": "Admin",
"website_id": 0,
"store_group_id": 0,
"is_active": 1
},
{
"id": 2,
"code": "us",
"name": "US Store View",
"website_id": 2,
"store_group_id": 2,
"is_active": 1
},
{
"id": 3,
"code": "de",
"name": "Germany Store View",
"website_id": 3,
"store_group_id": 3,
"is_active": 1
}
]
Create a customer
We can use the same customer definition presented in Step 3. Create a customer, with the only differences being the scope of the call (us
instead of default
) and inserting the store_id
and website_id
parameters into the payload.
Endpoint:
POST <host>/rest/us/V1/customers
Scope:
us
store view
Headers:
Content-Type
: application/json
Authorization
: Bearer <admin_token>
Payload:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
{
"customer" : {
"lastname" : "Doe",
"firstname" : "Jane",
"email" : "jdoe@example.com",
"store_id": 2,
"website_id": 2,
"addresses" : [
{
"defaultBilling" : true,
"defaultShipping" : true,
"firstname" : "Jane",
"lastname" : "Doe",
"region" : {
"regionCode" : "NY",
"regionId" : 43,
"region" : "New York"
},
"countryId" : "US",
"postcode" : "10755",
"city" : "Purchase",
"street" : [
"123 Oak Ave"
],
"telephone" : "512-555-1111"
}
]
},
"password" : "Password1"
}
Response:
The customer id
is 3
.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
{
"id": 3,
"group_id": 1,
"default_billing": "3",
"default_shipping": "3",
"created_at": "2019-01-28 20:53:45",
"updated_at": "2019-01-28 20:53:46",
"created_in": "US Store View",
"email": "jdoe@example.com",
"firstname": "Jane",
"lastname": "Doe",
"store_id": 2,
"website_id": 2,
"addresses": [
{
"id": 3,
"customer_id": 3,
"region": {
"region_code": "NY",
"region": "New York",
"region_id": 43
},
"region_id": 43,
"country_id": "US",
"street": [
"123 Oak Ave"
],
"telephone": "512-555-1111",
"postcode": "10755",
"city": "Purchase",
"firstname": "Jane",
"lastname": "Doe",
"default_shipping": true,
"default_billing": true
}
],
"disable_auto_group_change": 0,
"extension_attributes": {
"is_subscribed": false
}
}
Generate the customer’s access token
To generate a customer’s access token, you must specify the customer’s username and password in the payload. You do not specify an admin authorization token.
By default, a customer token is valid for 1 hour. To change this value, click Stores > Settings > Configuration > Services > OAuth > Access Token Expiration. Then enter a new value for Customer Token Lifetime (hours).
Endpoint:
POST <host>/rest/us/V1/integration/customer/token
Scope:
us
store view
Headers:
Content-Type
: application/json
Payload:
1
2
3
4
{
"username": "jdoe@example.com",
"password": "Password1"
}
Response:
Magento returns the customer’s access token. Your integration must specify a customer token in the authorization header of every call customers make on their own behalf.
fl0o0yr1xota4w88negpwfsle38807yb
Verify this step
- Log in to the Test website using the email
jdoe@example.com
and passwordPassword1
. - Click the account name (Jane) in the upper right corner and select My Account.
- Click Address Book to view the default billing and shipping addresses.