@sp-api-sdk/common
Version:
Selling Parner API common library
140 lines (139 loc) • 6.1 kB
JavaScript
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.createAxiosInstance = createAxiosInstance;
const axios_1 = __importStar(require("axios"));
const axios_logger_1 = require("axios-logger");
const axios_retry_1 = __importDefault(require("axios-retry"));
const auth_1 = require("@sp-api-sdk/auth");
const errors_1 = require("./errors");
const regions_1 = require("./regions");
const package_1 = require("./utils/package");
function createAxiosInstance({ auth, restrictedDataToken, region, userAgent = `${package_1.packageJson.name}/${package_1.packageJson.version}`, sandbox = false, rateLimiting, logging, }, rateLimits) {
const regionConfiguration = regions_1.sellingPartnerRegions[region];
if (!regionConfiguration) {
throw new TypeError(`Unknown or unsupported region: ${region}`);
}
const instance = axios_1.default.create({
headers: {
'user-agent': userAgent,
},
});
const endpoint = regionConfiguration.endpoints[sandbox ? 'sandbox' : 'production'];
if (rateLimiting?.retry) {
(0, axios_retry_1.default)(instance, {
retryCondition: (error) => error.response?.status === 429,
retryDelay(retryCount, error) {
const url = new URL(error.config.url);
const method = error.config.method?.toLowerCase();
const amznRateLimit = Number.parseFloat(error.response?.headers['x-amzn-ratelimit-limit'] ?? '');
const rateLimit = Number.isNaN(amznRateLimit)
? rateLimits.find((rateLimit) => rateLimit.method.toLowerCase() === method && rateLimit.urlRegex.exec(url.pathname))?.rate
: amznRateLimit;
const delay = rateLimit ? (1 / rateLimit) * 1000 + 1500 : 60 * 1000;
if (rateLimiting.onRetry) {
rateLimiting.onRetry({ delay, rateLimit, retryCount, error });
}
return delay;
},
});
}
// Set x-amz-access-token to each request
instance.interceptors.request.use(async (config) => {
config.headers['x-amz-access-token'] = restrictedDataToken ?? (await auth.getAccessToken());
return config;
});
instance.interceptors.response.use(async (response) => response, async (error) => {
if ((0, axios_1.isAxiosError)(error) && !(error instanceof auth_1.SellingPartnerApiAuthError)) {
throw new errors_1.SellingPartnerApiError(error);
}
throw error;
});
if (logging?.request) {
const requestLoggerOptions = logging.request === true ? undefined : logging.request;
if (requestLoggerOptions?.headers) {
console.warn('WARNING: You have enabled logging of request headers, this can leak authentication information, you should disable in production.');
}
instance.interceptors.request.use((config) => {
const logger = (0, axios_logger_1.requestLogger)(config, {
prefixText: `sp-api-sdk/${region}`,
dateFormat: 'isoDateTime',
method: true,
url: true,
params: false,
data: true,
headers: false,
logger: console.info,
...requestLoggerOptions,
});
return {
...logger,
headers: config.headers,
};
});
}
if (logging?.response) {
const responseLoggerOptions = logging.response === true ? undefined : logging.response;
instance.interceptors.response.use((response) => (0, axios_logger_1.responseLogger)(response, {
prefixText: `sp-api-sdk/${region}`,
dateFormat: 'isoDateTime',
status: true,
statusText: false,
params: false,
data: false,
headers: true,
logger: console.info,
...responseLoggerOptions,
}));
}
if (logging?.error) {
const errorLoggerOptions = logging.error === true ? undefined : logging.error;
instance.interceptors.response.use((response) => response, async (error) => (0, axios_logger_1.errorLogger)(error, {
prefixText: `sp-api-sdk/${region}`,
dateFormat: 'isoDateTime',
status: true,
statusText: false,
params: false,
data: false,
headers: true,
logger: console.error,
...errorLoggerOptions,
}));
}
return { axios: instance, endpoint };
}
;