commerce
commerce copied to clipboard
Customer Cookie
Bigcommerce changed the cookie header in the response from doing login mutation. You get 2 cookies, you need to concat them. Until this is fixed, login won't work on the preview site
Also a separate question, have you guys come up with any way to login the customer on the bigcommerce frontend? A logged in customer on the nextjs frontend will not be logged in at checkout.
I am also having these issues! Very frustrating.
I am also having these issues! Very frustrating.
Before when the cookie came from bigcommerce it came as a string, now it is an array, I think one called shop_token and the other one is called shopper-pref, so you just have to set those as cookies on your frontend, and then you can send it as a header with graphql query to get the current customer
I believe this may be a duplicate: https://github.com/vercel/commerce/issues/299
I am also having these issues! Very frustrating.
Before when the cookie came from bigcommerce it came as a string, now it is an array, I think one called shop_token and the other one is called shopper-pref, so you just have to set those as cookies on your frontend, and then you can send it as a header with graphql query to get the current customer
the new token uses the key Shopper-Pref
, but now SHOP_TOKEN
is missing from cookies.... basically, this breaks wishlist and login functionality.
I am also having these issues! Very frustrating.
Before when the cookie came from bigcommerce it came as a string, now it is an array, I think one called shop_token and the other one is called shopper-pref, so you just have to set those as cookies on your frontend, and then you can send it as a header with graphql query to get the current customer
the new token uses the key
Shopper-Pref
, but nowSHOP_TOKEN
is missing from cookies.... basically, this breaks wishlist and login functionality.
https://gist.github.com/jorgemasta/c709b63501344970026f3a3e7646cc77
try using this instead of the graphql cookie, it returns 3 cookies
I just solved the problem for myself. I set the Shopper-Pref
cookie like so:
I changed the async function login(){...}
definition in the file framework/bigcommerce/auth/login.ts (lines 32-71)
to the following:
async function login({
query = loginMutation,
variables,
res: response,
config,
}: {
query?: string
variables: LoginVariables
res: ServerResponse
config?: BigcommerceConfig
}): Promise<LoginResult> {
config = getConfig(config)
const { data, res } = await config.fetch<RecursivePartial<LoginMutation>>(
query,
{ variables }
)
// Set-Cookie returns several cookies, we want SHOP_TOKEN and Shopper-pref
let shopToken = getCookie(res.headers.get('Set-Cookie'), 'SHOP_TOKEN');
let prefToken = getCookie(res.headers.get('Set-Cookie'), 'Shopper-Pref');
if (shopToken && typeof shopToken === 'string') {
// In development, don't set a secure shopToken or the browser will ignore it
if (process.env.NODE_ENV !== 'production') {
shopToken = shopToken.replace(/; Secure/gi, '')
shopToken = shopToken.replace(/; SameSite=none/gi, '; SameSite=lax')
}
response.setHeader(
'Set-Cookie',
concatHeader(response.getHeader('Set-Cookie'), shopToken)!
)
response.setHeader(
'Set-Cookie',
concatHeader(response.getHeader('Set-Cookie'), `${prefToken}`)!
)
}
return {
result: data.login?.result,
}
}
I just solved the problem for myself. I set the
Shopper-Pref
cookie like so:I changed the
async function login(){...}
definition in the fileframework/bigcommerce/auth/login.ts (lines 32-71)
to the following:async function login({ query = loginMutation, variables, res: response, config, }: { query?: string variables: LoginVariables res: ServerResponse config?: BigcommerceConfig }): Promise<LoginResult> { config = getConfig(config) const { data, res } = await config.fetch<RecursivePartial<LoginMutation>>( query, { variables } ) // Set-Cookie returns several cookies, we want SHOP_TOKEN and Shopper-pref let shopToken = getCookie(res.headers.get('Set-Cookie'), 'SHOP_TOKEN'); let prefToken = getCookie(res.headers.get('Set-Cookie'), 'Shopper-Pref'); if (shopToken && typeof shopToken === 'string') { // In development, don't set a secure shopToken or the browser will ignore it if (process.env.NODE_ENV !== 'production') { shopToken = shopToken.replace(/; Secure/gi, '') shopToken = shopToken.replace(/; SameSite=none/gi, '; SameSite=lax') } response.setHeader( 'Set-Cookie', concatHeader(response.getHeader('Set-Cookie'), shopToken)! ) response.setHeader( 'Set-Cookie', concatHeader(response.getHeader('Set-Cookie'), `${prefToken}`)! ) } return { result: data.login?.result, } }
This did it for me. Using the getCookie function from @kogan007 I got this to work. Thank you all!
@clockelliptic I have updated my code to cater for the multiple cookies as per your code above. However, when I'm redirected to the Bigcommerce checkout url, the customer is not logged in.
Any additional steps I need to take to make this work? Is your implementation based on using redirecting to Bigcommerce store checkout url as well?
@clockelliptic I have updated my code to cater for the multiple cookies as per your code above. However, when I'm redirected to the Bigcommerce checkout url, the customer is not logged in.
Any additional steps I need to take to make this work? Is your implementation based on using redirecting to Bigcommerce store checkout url as well?
https://github.com/bigcommerce/storefront-data-hooks
For starters the checkout needs to be on a subdomain of your headless implementation
Any news or merged request as been made on this issue ?
In my side, even using the getCookie
from @kogan007's answer with @clockelliptic's code it does not work.
If I am already logged in when I proceed to checkout I got an error.
data:image/s3,"s3://crabby-images/13a3e/13a3e3c2f222940577406f23207e3c1e75f8604a" alt="Capture d’écran 2021-10-17 à 22 40 59"
And as @kogan007 said
For starters the checkout needs to be on a subdomain of your headless implementation
my stores domain are, I think, well configured, regarding https://github.com/bigcommerce/storefront-data-hooks#checkout
data:image/s3,"s3://crabby-images/e97e6/e97e6a3ee40bc2b4c173d64c93044247446b4f60" alt="Capture d’écran 2021-10-17 à 23 43 18"
Am I missing something else ?
@Florian-crg Don't use the cookie code anymore. See this https://github.com/vercel/commerce/issues/531
You need to implement server session. Use the graphql login mutation and get the customer ID. Use the ID to create a customer impersonation token, and store it along with any other customer information you need in a secure session. Check out https://github.com/vvo/next-iron-session or Next Auth for implementing this.
Also for checkout code make sure the customer ID is an Int and not a string, and console.log the payload to make sure all the variables are there. You might be missing some environment variables.
Yes you're right one of my variables had something. When you mean create a customer impersonation token you're talking about the BC route /storefront/api-token-customer-impersonation ?
Because I do not see any mention in the storefront customer impersonation token about the customer ID.
I feel lost between the doc and what I understand in the issues opened about the login.
Hey there! Thank you for your contribution. We have decided to take Next.js Commerce in a new direction and will be closing out current PRs and issues due to this change. Please see this PR for more details: #966