Configuration for constructing the {@see CommercetoolsApi} class.

interface CommercetoolsApiConfig {
    clientId: string;
    clientScopes: string[];
    clientSecret: string;
    customerScopes?: string[];
    httpsAgent?: Agent;
    onAfterResponse?: (response: CommercetoolsRequestResponse) => void;
    onBeforeRequest?: (
        requestConfig: CommercetoolsRequest,
    ) => CommercetoolsRequest | Promise<CommercetoolsRequest>;
    projectKey: string;
    refreshIfWithinSecs?: number;
    region: Region;
    retry?: Partial<CommercetoolsRetryConfig>;
    storeKey?: string;
    systemIdentifier?: string;
    timeoutMs?: number;
}

Hierarchy (View Summary)

Properties

clientId: string
clientScopes: string[]
clientSecret: string
customerScopes?: string[]
httpsAgent?: Agent
onAfterResponse?: (response: CommercetoolsRequestResponse) => void

If passed in, will be called once a request has been made and the response received (or error thrown).

onBeforeRequest?: (
    requestConfig: CommercetoolsRequest,
) => CommercetoolsRequest | Promise<CommercetoolsRequest>

If passed in, will be called before sending a request to commercetools. The {@see requestConfig} parameter can be manipulated if you wish to modify/add headers or any other request data.

projectKey: string
refreshIfWithinSecs?: number
region: Region
retry?: Partial<CommercetoolsRetryConfig>
storeKey?: string
systemIdentifier?: string

If provided, will be passed across to commercetools in the 'User-Agent' HTTP header, in order to help commercetools identify the source of incoming requests.

timeoutMs?: number