UNPKG

aws-delivlib

Version:

A fabulous library for defining continuous pipelines for building, testing and releasing code libraries.

103 lines (96 loc) 3.22 kB
"use strict"; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // pkg/dist-src/index.js var dist_src_exports = {}; __export(dist_src_exports, { createUnauthenticatedAuth: () => createUnauthenticatedAuth }); module.exports = __toCommonJS(dist_src_exports); // pkg/dist-src/auth.js async function auth(reason) { return { type: "unauthenticated", reason }; } // pkg/dist-src/is-rate-limit-error.js function isRateLimitError(error) { if (error.status !== 403) { return false; } if (!error.response) { return false; } return error.response.headers["x-ratelimit-remaining"] === "0"; } // pkg/dist-src/is-abuse-limit-error.js var REGEX_ABUSE_LIMIT_MESSAGE = /\babuse\b/i; function isAbuseLimitError(error) { if (error.status !== 403) { return false; } return REGEX_ABUSE_LIMIT_MESSAGE.test(error.message); } // pkg/dist-src/hook.js async function hook(reason, request, route, parameters) { const endpoint = request.endpoint.merge( route, parameters ); return request(endpoint).catch((error) => { if (error.status === 404) { error.message = `Not found. May be due to lack of authentication. Reason: ${reason}`; throw error; } if (isRateLimitError(error)) { error.message = `API rate limit exceeded. This maybe caused by the lack of authentication. Reason: ${reason}`; throw error; } if (isAbuseLimitError(error)) { error.message = `You have triggered an abuse detection mechanism. This maybe caused by the lack of authentication. Reason: ${reason}`; throw error; } if (error.status === 401) { error.message = `Unauthorized. "${endpoint.method} ${endpoint.url}" failed most likely due to lack of authentication. Reason: ${reason}`; throw error; } if (error.status >= 400 && error.status < 500) { error.message = error.message.replace( /\.?$/, `. May be caused by lack of authentication (${reason}).` ); } throw error; }); } // pkg/dist-src/index.js var createUnauthenticatedAuth = function createUnauthenticatedAuth2(options) { if (!options || !options.reason) { throw new Error( "[@octokit/auth-unauthenticated] No reason passed to createUnauthenticatedAuth" ); } return Object.assign(auth.bind(null, options.reason), { hook: hook.bind(null, options.reason) }); }; // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { createUnauthenticatedAuth });