forked from crowetic/commerce
* Adding multiple initial files * Updated the default cart endpoint * Fixes * Updated CommerceAPI class for better usage * Adding more migration changes * Taking multiple steps into better API types * Adding more experimental types * Removed many testing types * Adding types, fixes and other updates * Updated commerce types * Updated types for hooks now using the API * Updated mutation types * Simplified cart types for the provider * Updated cart hooks * Remove normalizers from the hooks * Updated cart endpoint * Removed cart handlers * bug fixes * Improve quantity input behavior in cart item * Removed endpoints folder * Making progress on api operations * Moved method * Moved types * Changed the way ops are created * Added customer endpoint * Login endpoint * Added logout endpoint * Add missing logout files * Added signup endpoint * Removed customers old endpoints * Moved endpoints to nested folder * Removed old customer endpoint builders * Updated login operation * Updated login operation * Added getAllPages operation * Renamed endpoint operations to handlers * Changed import * Renamed operations to handlers in usage * Moved getAllPages everywhere * Moved getPage * Updated getPage usage * Moved getSiteInfo * Added def types for product * Updated type * moved products catalog endpoint * removed old catalog endpoint * Moved wishlist * Removed commerce.endpoint * Replaced references to commerce.endpoint * Updated catalog products * Moved checkout api * Added the get customer wishlist operation * Removed old wishlist stuff * Added getAllProductPaths operation * updated reference to operation * Moved getAllProducts * Updated getProduct operation * Removed old getConfig and references * Removed is-allowed-method from BC * Updated types for auth hooks * Updated useCustomer and core types * Updated useData and util hooks * Updated useSearch hook * Updated types for useWishlist * Added index for types * Fixes * Updated urls to the API * Renamed fetchInput to fetcherInput * Updated fetch type * Fixes in search hook * Updated Shopify Provider Structure (#340) * Add codegen, update fragments & schemas * Update checkout-create.ts * Update checkout-create.ts * Update README.md * Update product mutations & queries * Uptate customer fetch types * Update schemas * Start updates * Moved Page, AllPages & Site Info * Moved product, all products (paths) * Add translations, update operations & fixes * Update api endpoints, types & fixes * Add api checkout endpoint * Updates * Fixes * Update commerce.config.json Co-authored-by: B <curciobelen@gmail.com> * Added category type and normalizer * updated init script to exclude other providers * Excluded swell and venture temporarily * Fix category & color normalization * Fixed category normalizer in shopify * Don't use getSlug for category on /search * Update colors.ts Co-authored-by: cond0r <pinte_catalin@yahoo.com> Co-authored-by: B <curciobelen@gmail.com>
80 lines
2.2 KiB
TypeScript
80 lines
2.2 KiB
TypeScript
import type { ServerResponse } from 'http'
|
|
import type {
|
|
OperationContext,
|
|
OperationOptions,
|
|
} from '@commerce/api/operations'
|
|
import type { LoginOperation } from '../../types/login'
|
|
import type { LoginMutation } from '../../schema'
|
|
import type { RecursivePartial } from '../utils/types'
|
|
import concatHeader from '../utils/concat-cookie'
|
|
import type { BigcommerceConfig, Provider } from '..'
|
|
|
|
export const loginMutation = /* GraphQL */ `
|
|
mutation login($email: String!, $password: String!) {
|
|
login(email: $email, password: $password) {
|
|
result
|
|
}
|
|
}
|
|
`
|
|
|
|
export default function loginOperation({
|
|
commerce,
|
|
}: OperationContext<Provider>) {
|
|
async function login<T extends LoginOperation>(opts: {
|
|
variables: T['variables']
|
|
config?: BigcommerceConfig
|
|
res: ServerResponse
|
|
}): Promise<T['data']>
|
|
|
|
async function login<T extends LoginOperation>(
|
|
opts: {
|
|
variables: T['variables']
|
|
config?: BigcommerceConfig
|
|
res: ServerResponse
|
|
} & OperationOptions
|
|
): Promise<T['data']>
|
|
|
|
async function login<T extends LoginOperation>({
|
|
query = loginMutation,
|
|
variables,
|
|
res: response,
|
|
config,
|
|
}: {
|
|
query?: string
|
|
variables: T['variables']
|
|
res: ServerResponse
|
|
config?: BigcommerceConfig
|
|
}): Promise<T['data']> {
|
|
config = commerce.getConfig(config)
|
|
|
|
const { data, res } = await config.fetch<RecursivePartial<LoginMutation>>(
|
|
query,
|
|
{ variables }
|
|
)
|
|
// Bigcommerce returns a Set-Cookie header with the auth cookie
|
|
let cookie = res.headers.get('Set-Cookie')
|
|
|
|
if (cookie && typeof cookie === 'string') {
|
|
// In development, don't set a secure cookie or the browser will ignore it
|
|
if (process.env.NODE_ENV !== 'production') {
|
|
cookie = cookie.replace('; Secure', '')
|
|
// SameSite=none can't be set unless the cookie is Secure
|
|
// bc seems to sometimes send back SameSite=None rather than none so make
|
|
// this case insensitive
|
|
cookie = cookie.replace(/; SameSite=none/gi, '; SameSite=lax')
|
|
}
|
|
|
|
response.setHeader(
|
|
'Set-Cookie',
|
|
concatHeader(response.getHeader('Set-Cookie'), cookie)!
|
|
)
|
|
}
|
|
|
|
return {
|
|
result: data.login?.result,
|
|
}
|
|
}
|
|
|
|
return login
|
|
}
|