@shopify/admin-api-client
Version:
Shopify Admin API Client - A lightweight JS client to interact with Shopify's Admin API
139 lines (121 loc) • 3.24 kB
text/typescript
import {
createGraphQLClient,
getCurrentSupportedApiVersions,
validateApiVersion,
validateDomainAndGetStoreUrl,
generateGetGQLClientParams,
generateGetHeaders,
} from '@shopify/graphql-client';
import {
DEFAULT_CONTENT_TYPE,
ACCESS_TOKEN_HEADER,
CLIENT,
DEFAULT_CLIENT_VERSION,
} from '../constants';
import {
validateRequiredAccessToken,
validateServerSideUsage,
} from '../validations';
import {AdminApiClientConfig, AdminApiClientOptions} from '../types';
import {AdminApiClient, AdminOperations} from './types';
export function createAdminApiClient({
storeDomain,
apiVersion,
accessToken,
userAgentPrefix,
retries = 0,
customFetchApi,
logger,
isTesting,
}: AdminApiClientOptions): AdminApiClient {
const currentSupportedApiVersions = getCurrentSupportedApiVersions();
const storeUrl = validateDomainAndGetStoreUrl({
client: CLIENT,
storeDomain,
});
const baseApiVersionValidationParams = {
client: CLIENT,
currentSupportedApiVersions,
logger,
};
validateServerSideUsage(isTesting);
validateApiVersion({
client: CLIENT,
currentSupportedApiVersions,
apiVersion,
logger,
});
validateRequiredAccessToken(accessToken);
const apiUrlFormatter = generateApiUrlFormatter(
storeUrl,
apiVersion,
baseApiVersionValidationParams,
);
const config: AdminApiClientConfig = {
storeDomain: storeUrl,
apiVersion,
accessToken,
headers: {
'Content-Type': DEFAULT_CONTENT_TYPE,
Accept: DEFAULT_CONTENT_TYPE,
[ACCESS_TOKEN_HEADER]: accessToken,
'User-Agent': `${
userAgentPrefix ? `${userAgentPrefix} | ` : ''
}${CLIENT} v${DEFAULT_CLIENT_VERSION}`,
},
apiUrl: apiUrlFormatter(),
userAgentPrefix,
};
const graphqlClient = createGraphQLClient({
headers: config.headers,
url: config.apiUrl,
retries,
customFetchApi,
logger,
});
const getHeaders = generateGetHeaders(config);
const getApiUrl = generateGetApiUrl(config, apiUrlFormatter);
const getGQLClientParams = generateGetGQLClientParams<AdminOperations>({
getHeaders,
getApiUrl,
});
const client: AdminApiClient = {
config,
getHeaders,
getApiUrl,
fetch: (...props) => {
return graphqlClient.fetch(...getGQLClientParams(...props));
},
request: (...props) => {
return graphqlClient.request(...getGQLClientParams(...props));
},
};
return Object.freeze(client);
}
function generateApiUrlFormatter(
storeUrl: string,
defaultApiVersion: string,
baseApiVersionValidationParams: Omit<
Parameters<typeof validateApiVersion>[0],
'apiVersion'
>,
) {
return (apiVersion?: string) => {
if (apiVersion) {
validateApiVersion({
...baseApiVersionValidationParams,
apiVersion,
});
}
const urlApiVersion = (apiVersion ?? defaultApiVersion).trim();
return `${storeUrl}/admin/api/${urlApiVersion}/graphql.json`;
};
}
function generateGetApiUrl(
config: AdminApiClientConfig,
apiUrlFormatter: (version?: string) => string,
): AdminApiClient['getApiUrl'] {
return (propApiVersion?: string) => {
return propApiVersion ? apiUrlFormatter(propApiVersion) : config.apiUrl;
};
}