mirror of
https://github.com/azure/login.git
synced 2026-06-06 12:17:07 +00:00
* Bump lodash from 4.17.15 to 4.17.19 (#52) Bumps [lodash](https://github.com/lodash/lodash) from 4.17.15 to 4.17.19. - [Release notes](https://github.com/lodash/lodash/releases) - [Commits](https://github.com/lodash/lodash/compare/4.17.15...4.17.19) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Amruta Kawade <65217380+AmrutaKawade@users.noreply.github.com> * Bump @actions/core from 1.1.3 to 1.2.6 (#60) Bumps [@actions/core](https://github.com/actions/toolkit/tree/HEAD/packages/core) from 1.1.3 to 1.2.6. - [Release notes](https://github.com/actions/toolkit/releases) - [Changelog](https://github.com/actions/toolkit/blob/main/packages/core/RELEASES.md) - [Commits](https://github.com/actions/toolkit/commits/HEAD/packages/core) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Amruta Kawade <65217380+AmrutaKawade@users.noreply.github.com> * updating node_nodules * updated package-lock Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
74 lines
1.7 KiB
JavaScript
74 lines
1.7 KiB
JavaScript
"use strict";
|
|
const MIMEType = require("whatwg-mimetype");
|
|
const { parseURL, serializeURL } = require("whatwg-url");
|
|
const {
|
|
stripLeadingAndTrailingASCIIWhitespace,
|
|
stringPercentDecode,
|
|
isomorphicDecode,
|
|
forgivingBase64Decode
|
|
} = require("./utils.js");
|
|
|
|
module.exports = stringInput => {
|
|
const urlRecord = parseURL(stringInput);
|
|
|
|
if (urlRecord === null) {
|
|
return null;
|
|
}
|
|
|
|
return module.exports.fromURLRecord(urlRecord);
|
|
};
|
|
|
|
module.exports.fromURLRecord = urlRecord => {
|
|
if (urlRecord.scheme !== "data") {
|
|
return null;
|
|
}
|
|
|
|
const input = serializeURL(urlRecord, true).substring("data:".length);
|
|
|
|
let position = 0;
|
|
|
|
let mimeType = "";
|
|
while (position < input.length && input[position] !== ",") {
|
|
mimeType += input[position];
|
|
++position;
|
|
}
|
|
mimeType = stripLeadingAndTrailingASCIIWhitespace(mimeType);
|
|
|
|
if (position === input.length) {
|
|
return null;
|
|
}
|
|
|
|
++position;
|
|
|
|
const encodedBody = input.substring(position);
|
|
|
|
let body = stringPercentDecode(encodedBody);
|
|
|
|
// Can't use /i regexp flag because it isn't restricted to ASCII.
|
|
const mimeTypeBase64MatchResult = /(.*); *[Bb][Aa][Ss][Ee]64$/.exec(mimeType);
|
|
if (mimeTypeBase64MatchResult) {
|
|
const stringBody = isomorphicDecode(body);
|
|
body = forgivingBase64Decode(stringBody);
|
|
|
|
if (body === null) {
|
|
return null;
|
|
}
|
|
mimeType = mimeTypeBase64MatchResult[1];
|
|
}
|
|
|
|
if (mimeType.startsWith(";")) {
|
|
mimeType = "text/plain" + mimeType;
|
|
}
|
|
|
|
let mimeTypeRecord;
|
|
try {
|
|
mimeTypeRecord = new MIMEType(mimeType);
|
|
} catch (e) {
|
|
mimeTypeRecord = new MIMEType("text/plain;charset=US-ASCII");
|
|
}
|
|
|
|
return {
|
|
mimeType: mimeTypeRecord,
|
|
body
|
|
};
|
|
};
|