1457 lines
258 KiB
JavaScript
1457 lines
258 KiB
JavaScript
"use strict";
|
|
exports.id = 895;
|
|
exports.ids = [895];
|
|
exports.modules = {
|
|
|
|
/***/ 33111:
|
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
exports.InvalidArgumentError = exports.isIacShareResultsOptions = exports.assertIaCOptionsFlags = exports.UnsupportedEntitlementCommandError = exports.UnsupportedEntitlementFlagError = exports.FlagValueError = exports.FeatureFlagError = exports.FlagError = void 0;
|
|
const errors_1 = __webpack_require__(55191);
|
|
const args_1 = __webpack_require__(94765);
|
|
const error_utils_1 = __webpack_require__(36401);
|
|
const types_1 = __webpack_require__(94820);
|
|
const keys = [
|
|
'org',
|
|
'debug',
|
|
'insecure',
|
|
'detectionDepth',
|
|
'severityThreshold',
|
|
'rules',
|
|
'json',
|
|
'sarif',
|
|
'json-file-output',
|
|
'sarif-file-output',
|
|
'v',
|
|
'version',
|
|
'h',
|
|
'help',
|
|
'q',
|
|
'quiet',
|
|
'scan',
|
|
'report',
|
|
// Tags and attributes
|
|
'tags',
|
|
'project-tags',
|
|
'project-environment',
|
|
'project-lifecycle',
|
|
'project-business-criticality',
|
|
'target-reference',
|
|
'var-file',
|
|
// PolicyOptions
|
|
'ignore-policy',
|
|
'policy-path',
|
|
// Report options
|
|
'remote-repo-url',
|
|
'target-name',
|
|
];
|
|
const allowed = new Set(keys);
|
|
function camelcaseToDash(key) {
|
|
return key.replace(/[A-Z]/g, (m) => '-' + m.toLowerCase());
|
|
}
|
|
function getFlagName(key) {
|
|
const dashes = key.length === 1 ? '-' : '--';
|
|
const flag = camelcaseToDash(key);
|
|
return `${dashes}${flag}`;
|
|
}
|
|
class FlagError extends errors_1.CustomError {
|
|
constructor(key) {
|
|
const flag = getFlagName(key);
|
|
const msg = `Unsupported flag "${flag}" provided. Run snyk iac test --help for supported flags`;
|
|
super(msg);
|
|
this.code = types_1.IaCErrorCodes.FlagError;
|
|
this.strCode = error_utils_1.getErrorStringCode(this.code);
|
|
this.userMessage = msg;
|
|
}
|
|
}
|
|
exports.FlagError = FlagError;
|
|
class FeatureFlagError extends errors_1.CustomError {
|
|
constructor(key, featureFlag, hasSnykPreview) {
|
|
const flag = getFlagName(key);
|
|
let msg;
|
|
if (hasSnykPreview) {
|
|
msg = `Flag "${flag}" is only supported if feature flag '${featureFlag}' is enabled. The feature flag can be enabled via Snyk Preview if you are on the Enterprise Plan`;
|
|
}
|
|
else {
|
|
msg = `Flag "${flag}" is only supported if feature flag "${featureFlag}" is enabled. To enable it, please contact Snyk support.`;
|
|
}
|
|
super(msg);
|
|
this.code = types_1.IaCErrorCodes.FeatureFlagError;
|
|
this.strCode = error_utils_1.getErrorStringCode(this.code);
|
|
this.userMessage = msg;
|
|
}
|
|
}
|
|
exports.FeatureFlagError = FeatureFlagError;
|
|
class FlagValueError extends errors_1.CustomError {
|
|
constructor(key, value) {
|
|
const flag = getFlagName(key);
|
|
const msg = `Unsupported value "${value}" provided to flag "${flag}".\nSupported values are: ${SUPPORTED_TF_PLAN_SCAN_MODES.join(', ')}`;
|
|
super(msg);
|
|
this.code = types_1.IaCErrorCodes.FlagValueError;
|
|
this.strCode = error_utils_1.getErrorStringCode(this.code);
|
|
this.userMessage = msg;
|
|
}
|
|
}
|
|
exports.FlagValueError = FlagValueError;
|
|
class UnsupportedEntitlementFlagError extends errors_1.CustomError {
|
|
constructor(key, entitlementName) {
|
|
const flag = getFlagName(key);
|
|
super(`Unsupported flag: ${flag} - Missing the ${entitlementName} entitlement`);
|
|
this.code = types_1.IaCErrorCodes.UnsupportedEntitlementFlagError;
|
|
this.strCode = error_utils_1.getErrorStringCode(this.code);
|
|
this.userMessage = `Flag "${flag}" is currently not supported for this org. To enable it, please contact snyk support.`;
|
|
}
|
|
}
|
|
exports.UnsupportedEntitlementFlagError = UnsupportedEntitlementFlagError;
|
|
class UnsupportedEntitlementCommandError extends errors_1.CustomError {
|
|
constructor(key, entitlementName) {
|
|
super(`Unsupported command: ${key} - Missing the ${entitlementName} entitlement`);
|
|
this.code = types_1.IaCErrorCodes.UnsupportedEntitlementFlagError;
|
|
this.strCode = error_utils_1.getErrorStringCode(this.code);
|
|
this.userMessage = `Command "${key}" is currently not supported for this org. To enable it, please contact snyk support.`;
|
|
}
|
|
}
|
|
exports.UnsupportedEntitlementCommandError = UnsupportedEntitlementCommandError;
|
|
/**
|
|
* Validates the command line flags passed to the snyk iac test
|
|
* command. The current argument parsing is very permissive and
|
|
* allows unknown flags to be provided without validation.
|
|
*
|
|
* For snyk iac we need to explicitly validate the flags to avoid
|
|
* misconfigurations and typos. For example, if the --experimental
|
|
* flag were to be misspelled we would end up sending the client
|
|
* data to our backend rather than running it locally as intended.
|
|
* @param argv command line args passed to the process
|
|
*/
|
|
function assertIaCOptionsFlags(argv) {
|
|
// We process the process.argv so we don't get default values.
|
|
const parsed = args_1.args(argv);
|
|
for (const key of Object.keys(parsed.options)) {
|
|
// The _ property is a special case that contains non
|
|
// flag strings passed to the command line (usually files)
|
|
// and `iac` is the command provided.
|
|
if (key !== '_' && key !== 'iac' && !allowed.has(key)) {
|
|
throw new FlagError(key);
|
|
}
|
|
}
|
|
if (parsed.options.scan) {
|
|
assertTerraformPlanModes(parsed.options.scan);
|
|
}
|
|
}
|
|
exports.assertIaCOptionsFlags = assertIaCOptionsFlags;
|
|
const SUPPORTED_TF_PLAN_SCAN_MODES = [
|
|
types_1.TerraformPlanScanMode.DeltaScan,
|
|
types_1.TerraformPlanScanMode.FullScan,
|
|
];
|
|
function assertTerraformPlanModes(scanModeArgValue) {
|
|
if (!SUPPORTED_TF_PLAN_SCAN_MODES.includes(scanModeArgValue)) {
|
|
throw new FlagValueError('scan', scanModeArgValue);
|
|
}
|
|
}
|
|
function isIacShareResultsOptions(options) {
|
|
return options.iac && options.report;
|
|
}
|
|
exports.isIacShareResultsOptions = isIacShareResultsOptions;
|
|
class InvalidArgumentError extends errors_1.CustomError {
|
|
constructor(key) {
|
|
const flag = getFlagName(key);
|
|
const msg = `Invalid argument provided to flag "${flag}". Value must be a string`;
|
|
super(msg);
|
|
this.code = types_1.IaCErrorCodes.InvalidArgumentError;
|
|
this.strCode = error_utils_1.getErrorStringCode(this.code);
|
|
this.userMessage = msg;
|
|
}
|
|
}
|
|
exports.InvalidArgumentError = InvalidArgumentError;
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 36401:
|
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
exports.getErrorStringCode = void 0;
|
|
const types_1 = __webpack_require__(94820);
|
|
function getErrorStringCode(code) {
|
|
const errorName = types_1.IaCErrorCodes[code];
|
|
if (!errorName) {
|
|
return 'INVALID_IAC_ERROR';
|
|
}
|
|
let result = errorName.replace(/([A-Z])/g, '_$1');
|
|
if (result.charAt(0) === '_') {
|
|
result = result.substring(1);
|
|
}
|
|
return result.toUpperCase();
|
|
}
|
|
exports.getErrorStringCode = getErrorStringCode;
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 11693:
|
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
exports.FailedToGetIacOrgSettingsError = exports.getIacOrgSettings = void 0;
|
|
const types_1 = __webpack_require__(94820);
|
|
const config_1 = __webpack_require__(25425);
|
|
const is_ci_1 = __webpack_require__(10090);
|
|
const api_token_1 = __webpack_require__(95181);
|
|
const request_1 = __webpack_require__(52050);
|
|
const errors_1 = __webpack_require__(55191);
|
|
const error_utils_1 = __webpack_require__(36401);
|
|
function getIacOrgSettings(publicOrgId) {
|
|
const payload = {
|
|
method: 'get',
|
|
url: config_1.default.API + '/iac-org-settings',
|
|
json: true,
|
|
qs: { org: publicOrgId },
|
|
headers: {
|
|
'x-is-ci': is_ci_1.isCI(),
|
|
authorization: api_token_1.getAuthHeader(),
|
|
},
|
|
};
|
|
return new Promise((resolve, reject) => {
|
|
request_1.makeRequest(payload, (error, res) => {
|
|
if (error) {
|
|
return reject(error);
|
|
}
|
|
if (res.statusCode < 200 || res.statusCode > 299) {
|
|
return reject(new FailedToGetIacOrgSettingsError());
|
|
}
|
|
resolve(res.body);
|
|
});
|
|
});
|
|
}
|
|
exports.getIacOrgSettings = getIacOrgSettings;
|
|
class FailedToGetIacOrgSettingsError extends errors_1.CustomError {
|
|
constructor(message) {
|
|
super(message || 'Failed to fetch IaC organization settings');
|
|
this.code = types_1.IaCErrorCodes.FailedToGetIacOrgSettingsError;
|
|
this.strCode = error_utils_1.getErrorStringCode(this.code);
|
|
this.userMessage =
|
|
'We failed to fetch your organization settings, including custom severity overrides for infrastructure-as-code policies. Please run the command again with the `-d` flag and contact support@snyk.io with the contents of the output.';
|
|
}
|
|
}
|
|
exports.FailedToGetIacOrgSettingsError = FailedToGetIacOrgSettingsError;
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 47658:
|
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
exports.DescribeExclusiveArgumentError = void 0;
|
|
const custom_error_1 = __webpack_require__(17188);
|
|
const drift_1 = __webpack_require__(26445);
|
|
class DescribeExclusiveArgumentError extends custom_error_1.CustomError {
|
|
constructor() {
|
|
super('Please use only one of these arguments: ' +
|
|
drift_1.DescribeExclusiveArgs.join(', '));
|
|
}
|
|
}
|
|
exports.DescribeExclusiveArgumentError = DescribeExclusiveArgumentError;
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 37541:
|
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
exports.DescribeRequiredArgumentError = void 0;
|
|
const custom_error_1 = __webpack_require__(17188);
|
|
const chalk_1 = __webpack_require__(32589);
|
|
class DescribeRequiredArgumentError extends custom_error_1.CustomError {
|
|
constructor() {
|
|
super(chalk_1.default.red('Describe command require one of these arguments:\n' +
|
|
' --only-unmanaged: Report resources not under Terraform control\n' +
|
|
' --only-managed: Report resources from Terraform states that changed (may take a while)\n' +
|
|
' --all: Scan for managed and unmanaged resources (may take a while)'));
|
|
}
|
|
}
|
|
exports.DescribeRequiredArgumentError = DescribeRequiredArgumentError;
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 24030:
|
|
/***/ ((__unused_webpack_module, exports) => {
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
exports.default = ``;
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 19679:
|
|
/***/ ((__unused_webpack_module, exports) => {
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
exports.default = `<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="1560pt" height="2448pt" viewBox="0 0 1560 2448"><g enable-background="new"><g><g id="Layer-1" data-name="AAPL:Style"><g id="Layer-2" data-name="AAPL:StyleContent"><mask id="ma0"><g transform="matrix(1,0,0,.99999997,0,-4)"><use xlink:href="#im1" x="0" y="0" width="1560" height="2456"/></g></mask><symbol id="im1" viewBox="0 0 1560 2456"><image width="1560" height="2456" xlink:href=""/></symbol><g mask="url(#ma0)"><g transform="matrix(1,0,0,.99999997,0,-4)"><symbol id="im2" viewBox="0 0 1560 2456"><image width="1560" height="2456" xlink:href=""/></symbol><use xlink:href="#im2" x="0" y="0" width="1560" height="2456"/></g></g></g><g><clipPath id="cp3"><path transform="matrix(1,0,0,-1,0,2448)" d="M 32 28 L 1528 28 L 1528 2420 L 32 2420 Z "/></clipPath><g clip-path="url(#cp3)"><clipPath id="cp4"><path transform="matrix(1,0,0,-1,0,2448)" d="M 1112.1 680.7587 L 1098.936 671.1768 L 1097.16 687.6313 C 1092.278 665.5576 1086.207 643.5719 1078.634 622.9377 C 1061.259 575.548 1030.556 539.6363 991.2844 518.3651 C 988.9836 404.758 883.6349 343.4667 784.3751 343.4667 C 684.2923 343.4667 578.0609 404.7087 575.7205 518.2764 C 536.3696 539.587 505.6268 575.4987 488.2323 622.9377 C 479.2435 647.4674 472.3445 673.8682 467.0364 700.0759 L 463.6342 668.4936 L 455.1858 674.4319 L 421.2724 360.4915 L 345.4268 413.6546 L 400.516 923.7587 C 359.6181 977.0598 311.2626 1043.563 298.6977 1075.77 C 278.5363 1127.278 304.2016 1390.828 317.6491 1512.159 L 233.5625 1734.684 L 233.5625 1741.935 C 233.5625 1850.823 376.2694 2129.401 424.358 2220.301 C 450.6306 2273.25 472.2835 2313.63 478.3256 2324.843 L 530.4276 2420 C 530.4276 2420 578.0118 2089.298 577.9771 2089.004 L 603.6328 1910.349 L 627.4751 1713.692 C 656.4059 1722.983 697.7071 1733.983 742.1899 1738.586 C 753.9293 1767.049 766.6556 1785.924 780.625 1785.924 C 807.0499 1785.924 833.3892 1761.183 857.2572 1733.972 C 885.2824 1729.128 910.9329 1722.39 931.5017 1716.104 L 958.1732 1910.341 L 1031.265 2420 L 1068.638 2350.303 L 1069.203 2354.227 L 1127.445 2245.911 C 1148.261 2207.329 1330.437 1865.454 1330.437 1741.935 L 1330.428 1741.935 L 1330.428 1734.694 L 1247.838 1512.139 C 1261.266 1390.828 1287.973 1127.239 1267.811 1075.741 C 1255.365 1043.888 1207.922 978.3603 1167.342 925.2957 L 1222.292 418.6005 L 1146.447 363.5457 L 1112.1 680.7587 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp4)"><clipPath id="cp5"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp5)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 213.5625 2440 L 1350.437 2440 L 1350.437 323.4667 L 213.5625 323.4667 Z " fill="#ffffff"/></g></g><clipPath id="cp6"><path transform="matrix(1,0,0,-1,0,2448)" d="M 1527.312 558.9249 L 779.651 28.69804 L 32 558.9249 L 32 1795.358 C 32 1795.358 308.4514 1898.518 780.6671 1898.518 C 1252.883 1898.518 1527.312 1795.358 1527.312 1795.358 L 1527.312 558.9249 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp6)"><clipPath id="cp7"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp7)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 12 1918.518 L 1547.312 1918.518 L 1547.312 8.698039 L 12 8.698039 Z " fill="#ffffff"/></g></g><clipPath id="cp8"><path transform="matrix(1,0,0,-1,0,2448)" d="M 1102.676 888.0417 L 780.2891 888.0417 L 780.2891 1428.714 L 453.1714 903.8485 L 402.3125 364.8874 L 775.252 98.08248 L 780.2891 94.47059 L 1161.688 366.8074 L 1102.676 888.0417 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp8)"><clipPath id="cp9"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp9)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 382.3125 1448.714 L 1181.688 1448.714 L 1181.688 74.47059 L 382.3125 74.47059 Z " fill="#3b3b63"/></g></g><clipPath id="cp10"><path transform="matrix(1,0,0,-1,0,2448)" d="M 772.6201 103.8667 L 78.875 596.7912 L 78.875 1746.239 C 78.875 1746.239 335.3942 1842.141 773.563 1842.141 C 1211.732 1842.141 1466.375 1746.239 1466.375 1746.239 L 1466.375 596.7912 L 772.6201 103.8667 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp10)"><clipPath id="cp11"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp11)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 58.875 1862.141 L 1486.375 1862.141 L 1486.375 83.86667 L 58.875 83.86667 Z " fill="#dbdbdb"/></g></g><clipPath id="cp12"><path transform="matrix(1,0,0,-1,0,2448)" d="M 782.9527 1842.141 C 782.6286 1842.141 782.3241 1842.131 782 1842.131 L 782 103.8667 L 782.0098 103.8667 L 1475.75 596.7994 L 1475.75 1746.237 C 1475.75 1746.237 1221.112 1842.141 782.9527 1842.141 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp12)"><clipPath id="cp13"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp13)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 762 1862.141 L 1495.75 1862.141 L 1495.75 83.86667 L 762 83.86667 Z " fill="#c6c6c6"/></g></g><clipPath id="cp14"><path transform="matrix(1,0,0,-1,0,2448)" d="M 1157 367.2637 L 1098.352 888.4392 L 777.3125 888.4392 L 777.3125 94.47059 L 1157 367.2637 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp14)"><clipPath id="cp15"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp15)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 757.3125 908.4392 L 1177 908.4392 L 1177 74.47059 L 757.3125 74.47059 Z " fill="#3b3b63"/></g></g><clipPath id="cp16"><path transform="matrix(1,0,0,-1,0,2448)" d="M 402.3125 364.8874 L 782 94.47059 L 782 1428.714 L 453.4016 903.8485 L 402.3125 364.8874 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp16)"><clipPath id="cp17"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp17)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 382.3125 1448.714 L 802 1448.714 L 802 74.47059 L 382.3125 74.47059 Z " fill="#53537a"/></g></g><clipPath id="cp18"><path transform="matrix(1,0,0,-1,0,2448)" d="M 941.375 521.9922 C 941.375 434.0455 857.474 390.4471 780.5048 390.4471 C 703.5355 390.4471 617.9375 434.0455 617.9375 521.9922 " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp18)"><clipPath id="cp19"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp19)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 597.9375 541.9922 L 961.375 541.9922 L 961.375 370.4471 L 597.9375 370.4471 Z " fill="#bc9375"/></g></g><clipPath id="cp20"><path transform="matrix(1,0,0,-1,0,2448)" d="M 894.5 568.9725 C 894.5 465.2393 837.638 437.4275 779.6611 437.4275 C 721.6937 437.4275 664.8125 465.2393 664.8125 568.9725 " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp20)"><clipPath id="cp21"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp21)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 644.8125 588.9725 L 914.5 588.9725 L 914.5 417.4275 L 644.8125 417.4275 Z " fill="#083251"/></g></g><clipPath id="cp22"><path transform="matrix(1,0,0,-1,0,2448)" d="M 779.661 475.0118 C 718.1573 475.0118 688.25 519.5975 688.25 611.2549 L 717.5752 611.2549 C 717.5752 503.9478 759.497 503.9478 779.661 503.9478 C 799.8155 503.9478 841.7468 503.9478 841.7468 611.2549 L 871.0625 611.2549 C 871.0625 519.5975 841.1552 475.0118 779.661 475.0118 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp22)"><clipPath id="cp23"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp23)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 668.25 631.2549 L 891.0625 631.2549 L 891.0625 455.0118 L 668.25 455.0118 Z " fill="#ffffff"/></g></g><clipPath id="cp24"><path transform="matrix(1,0,0,-1,0,2448)" d="M 1269.5 1675.155 C 1269.5 1787.941 1077.684 2142.816 1077.684 2142.816 L 1012.794 1692.761 L 954.5584 1597.743 L 780.0153 1590.693 L 779.3259 1589.296 L 779.3259 1590.693 L 604.7541 1597.743 L 546.538 1692.761 L 481.6481 2142.816 C 481.6481 2142.816 289.8125 1787.941 289.8125 1675.155 L 370.8555 1458.437 C 370.8555 1458.437 329.9606 1094.412 348.6319 1046.751 C 367.2457 999.0803 496.5468 839.6681 496.5468 839.6681 C 496.5468 839.6681 496.1638 705.6543 531.5626 609.3057 C 556.8216 540.503 612.4716 512.5961 665.7566 512.5961 C 747.3741 512.5961 779.3068 587.0049 779.3068 587.0049 C 779.3068 587.0049 812.0055 512.5961 893.6229 512.5961 C 946.8984 512.5961 1002.491 540.4554 1027.807 609.3057 C 1063.168 705.6163 1062.814 839.6681 1062.814 839.6681 C 1062.814 839.6681 1192.086 999.0803 1210.738 1046.751 C 1229.4 1094.422 1188.495 1458.437 1188.495 1458.437 L 1269.5 1675.155 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp24)"><clipPath id="cp25"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp25)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 269.8125 2162.816 L 1289.5 2162.816 L 1289.5 492.5961 L 269.8125 492.5961 Z " fill="#c49a7e"/></g></g><clipPath id="cp26"><path transform="matrix(1,0,0,-1,0,2448)" d="M 777.303 1589.98 L 776.9695 1589.306 L 776.9695 1590.693 L 603.238 1597.743 L 545.3021 1692.761 L 480.7055 2142.816 C 480.7055 2142.816 289.8125 1787.941 289.8125 1675.155 L 370.4463 1458.437 C 370.4463 1458.437 329.7578 1094.412 348.3106 1046.751 C 366.8729 999.0803 495.504 839.6681 495.504 839.6681 C 495.504 839.6681 495.1704 705.6543 530.3608 609.3057 C 555.5362 540.503 610.9183 512.5961 663.8992 512.5961 C 745.1714 512.5961 776.9504 587.0049 776.9504 587.0049 C 776.9504 587.0049 777.0933 586.7389 777.3125 586.2543 L 777.3125 1589.98 L 777.303 1589.98 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp26)"><clipPath id="cp27"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp27)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 269.8125 2162.816 L 797.3125 2162.816 L 797.3125 492.5961 L 269.8125 492.5961 Z " fill="#d8b7a0"/></g></g><clipPath id="cp28"><path transform="matrix(1,0,0,-1,0,2448)" d="M 1189.987 1442.178 C 1175.151 1473.084 1196.244 1546.207 1196.244 1546.207 C 1075.391 1669.535 1045.165 1926.706 1045.165 1926.706 C 1022.601 1845.671 973.5568 1606.746 973.5568 1606.746 C 973.5568 1606.746 883.3585 1640.187 780.7509 1640.349 L 780.3879 1640.349 L 779.9867 1640.349 C 774.3505 1640.32 768.8002 1640.178 763.25 1639.997 L 763.25 631.8203 L 770.9114 620.651 L 770.9114 626.1692 L 775.6496 626.1692 L 775.6496 620.651 L 775.6974 626.1692 L 785.0497 626.1692 L 785.0497 620.651 L 785.0497 626.1692 L 789.8357 626.1692 L 789.8357 620.651 L 873.3757 742.0987 L 891.5357 1083.125 L 995.5476 965.011 L 1129.536 926.0417 C 1129.536 926.0417 1179.67 961.6203 1179.67 961.4873 C 1200.954 991.1583 1208.013 1016.432 1213.162 1029.548 C 1231.771 1077.265 1189.987 1442.178 1189.987 1442.178 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp28)"><clipPath id="cp29"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp29)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 743.25 1946.706 L 1237.938 1946.706 L 1237.938 600.651 L 743.25 600.651 Z " fill="#3b3b63"/></g></g><clipPath id="cp30"><path transform="matrix(1,0,0,-1,0,2448)" d="M 589.5215 1606.736 C 589.5215 1606.736 540.6429 1845.659 518.1831 1926.706 C 518.1831 1926.706 488.0908 1669.528 367.674 1546.196 C 367.674 1546.196 388.6872 1473.061 373.9075 1442.164 C 373.9075 1442.164 332.2808 1077.221 350.8196 1029.579 C 355.9397 1016.453 363.0297 991.1881 384.2047 961.5162 C 384.2047 961.6492 434.1778 926.0601 434.1778 926.0601 L 567.6327 965.04 L 671.2333 1083.138 L 689.3724 742.1023 L 772.5498 620.651 L 772.5498 626.1693 L 777.3177 626.1693 L 777.3177 620.651 L 777.3177 626.1693 L 781.9905 626.1693 L 781.9905 1640.331 C 679.3892 1640.16 589.5215 1606.736 589.5215 1606.736 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp30)"><clipPath id="cp31"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp31)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 326.0625 1946.706 L 801.9905 1946.706 L 801.9905 600.651 L 326.0625 600.651 Z " fill="#53537a"/></g></g><clipPath id="cp32"><path transform="matrix(1,0,0,-1,0,2448)" d="M 1023.522 1212.604 L 1023.522 1212.604 L 905.6571 1212.604 L 866.375 1212.604 L 866.375 1210.984 C 866.375 1157.374 913.828 1113.945 969.4904 1113.945 C 1025.172 1113.945 1072.625 1157.383 1072.625 1210.984 L 1072.625 1212.604 L 1023.522 1212.604 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp32)"><clipPath id="cp33"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp33)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 846.375 1232.604 L 1092.625 1232.604 L 1092.625 1093.945 L 846.375 1093.945 Z " fill="#333152"/></g></g><clipPath id="cp34"><path transform="matrix(1,0,0,-1,0,2448)" d="M 903.875 1212.604 L 903.875 1210.937 C 903.875 1178.12 929.9993 1151.529 962.4735 1151.529 C 994.9477 1151.529 1021.062 1178.12 1021.062 1210.937 L 1021.062 1212.604 L 903.875 1212.604 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp34)"><clipPath id="cp35"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp35)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 883.875 1232.604 L 1041.062 1232.604 L 1041.062 1131.529 L 883.875 1131.529 Z " fill="#ffffff"/></g></g><clipPath id="cp36"><path transform="matrix(1,0,0,-1,0,2448)" d="M 980.6553 1212.604 L 953.0633 1212.604 C 952.795 1212.604 952.5651 1212.472 952.3256 1212.425 C 955.7458 1211.718 957.6428 1204.089 956.9051 1199.012 C 955.8033 1191.25 949.0778 1185.862 941.375 1185.73 C 943.6168 1175.585 952.0286 1167.428 963.1995 1165.883 C 977.4745 1163.896 990.667 1173.523 992.6885 1187.548 C 994.1447 1197.872 989.0957 1212.604 980.6553 1212.604 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp36)"><clipPath id="cp37"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp37)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 921.375 1232.604 L 1012.938 1232.604 L 1012.938 1145.624 L 921.375 1145.624 Z " fill="#333152"/></g></g><clipPath id="cp38"><path transform="matrix(1,0,0,-1,0,2448)" d="M 648.5055 1212.604 L 648.5055 1212.604 L 530.6648 1212.604 L 491.375 1212.604 L 491.375 1210.984 C 491.375 1157.374 538.8354 1113.945 594.4856 1113.945 C 650.1646 1113.945 697.625 1157.383 697.625 1210.984 L 697.625 1212.604 L 648.5055 1212.604 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp38)"><clipPath id="cp39"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp39)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 471.375 1232.604 L 717.625 1232.604 L 717.625 1093.945 L 471.375 1093.945 Z " fill="#333152"/></g></g><clipPath id="cp40"><path transform="matrix(1,0,0,-1,0,2448)" d="M 528.875 1212.604 L 528.875 1210.937 C 528.875 1178.12 555.0226 1151.529 587.4544 1151.529 C 619.9435 1151.529 646.0625 1178.12 646.0625 1210.937 L 646.0625 1212.604 L 528.875 1212.604 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp40)"><clipPath id="cp41"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp41)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 508.875 1232.604 L 666.0625 1232.604 L 666.0625 1131.529 L 508.875 1131.529 Z " fill="#ffffff"/></g></g><clipPath id="cp42"><path transform="matrix(1,0,0,-1,0,2448)" d="M 605.6792 1212.604 L 578.0619 1212.604 C 577.8224 1212.604 577.5637 1212.472 577.3434 1212.425 C 580.7537 1211.718 582.6408 1204.089 581.9224 1199.012 C 580.8111 1191.25 574.1247 1185.862 566.375 1185.73 C 568.6453 1175.585 577.056 1167.428 588.2064 1165.883 C 602.4701 1163.896 615.6897 1173.523 617.6822 1187.548 C 619.1574 1197.872 614.1187 1212.604 605.6792 1212.604 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp42)"><clipPath id="cp43"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp43)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 546.375 1232.604 L 637.9375 1232.604 L 637.9375 1145.624 L 546.375 1145.624 Z " fill="#333152"/></g></g><clipPath id="cp44"><path transform="matrix(1,0,0,-1,0,2448)" d="M 1013.379 1259.584 C 1020.01 1266.782 1076.302 1330.055 1001.014 1330.055 C 932.9832 1330.055 884.0345 1275.679 871.0625 1259.584 L 1013.379 1259.584 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp44)"><clipPath id="cp45"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp45)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 851.0625 1350.055 L 1059.812 1350.055 L 1059.812 1239.584 L 851.0625 1239.584 Z " fill="#c49a7e"/></g></g><clipPath id="cp46"><path transform="matrix(1,0,0,-1,0,2448)" d="M 692.9375 1259.584 C 679.9737 1275.679 631.0199 1330.055 562.9625 1330.055 C 487.7052 1330.055 544.0036 1266.782 550.5963 1259.584 L 692.9375 1259.584 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp46)"><clipPath id="cp47"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp47)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 504.1875 1350.055 L 712.9375 1350.055 L 712.9375 1239.584 L 504.1875 1239.584 Z " fill="#d8b7a0"/></g></g><clipPath id="cp48"><path transform="matrix(1,0,0,-1,0,2448)" d="M 453.875 1240.792 L 739.8125 1240.792 L 739.8125 1212.604 L 453.875 1212.604 L 453.875 1240.792 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp48)"><clipPath id="cp49"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp49)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 433.875 1260.792 L 759.8125 1260.792 L 759.8125 1192.604 L 433.875 1192.604 Z " fill="#53537a"/></g></g><clipPath id="cp50"><path transform="matrix(1,0,0,-1,0,2448)" d="M 1307 1678.829 C 1307 1798.019 1131.831 2127.913 1111.815 2165.142 L 1055.813 2269.663 L 975.5894 1709.851 L 938.5626 1649.044 C 902.8136 1661.013 841.9763 1677.717 780.7195 1677.717 C 719.5294 1677.717 659.1021 1661.07 623.5057 1649.082 L 586.4598 1709.86 L 558.3011 1906.095 C 558.3392 1906.418 558.3869 1906.855 558.3869 1907.055 L 558.1676 1907.084 L 506.1126 2269.663 L 448.9275 2165.142 C 428.8836 2127.913 252.3125 1798.019 252.3125 1678.829 L 252.3125 1671.832 L 333.165 1457.106 C 320.2347 1340.027 295.5565 1085.714 314.9425 1036.011 C 327.0241 1004.933 373.5198 940.7603 412.8447 889.3272 L 359.8743 397.1006 L 432.8028 345.8007 L 471.3457 703.8641 C 476.8859 669.0398 485.058 632.2666 497.1873 599.049 C 513.9128 553.2727 543.4732 518.6195 581.3105 498.0558 C 583.5609 388.4683 685.7065 329.3725 781.94 329.3725 C 877.3821 329.3725 978.679 388.5158 980.8913 498.1414 C 1018.652 518.6671 1048.175 553.3202 1064.881 599.049 C 1077.516 633.5976 1085.802 672.0725 1091.314 708.1042 L 1130.086 348.7479 L 1203.014 401.8732 L 1150.177 890.8103 C 1189.197 942.0152 1234.815 1005.246 1246.783 1035.983 C 1266.168 1085.676 1240.489 1340.027 1227.578 1457.087 L 1306.99 1671.842 L 1306.99 1678.829 L 1307 1678.829 Z M 332 1687.566 C 336.3777 1749.078 400.2031 1896.46 461.0849 2020.667 L 477.3125 1907.101 C 471.1234 1864.639 442.8383 1698.112 366.9648 1593.145 L 332 1687.566 Z M 782.794 409.2392 C 740.2878 409.2392 679.8508 428.096 664.8125 478.0828 C 666.3532 478.0357 667.8655 477.9041 669.4346 477.9041 C 677.6485 477.9041 685.352 478.6565 692.7908 479.7098 C 714.3511 449.84 747.9345 440.6797 781.9622 440.6797 C 816.0466 440.6797 849.6962 449.7553 871.2943 479.6722 C 878.6858 478.6659 886.3042 477.9041 894.452 477.9041 C 896.0494 477.9041 897.5901 478.0357 899.1875 478.0828 C 884.3004 428.096 824.6669 409.2392 782.794 409.2392 Z M 730.4375 490.9479 C 741.011 495.7894 750.5599 501.5554 758.9781 507.898 C 766.6714 505.5717 774.0554 505.5717 779.7191 505.5717 C 785.3537 505.5717 792.6604 505.522 800.2957 507.8483 C 808.7332 501.5554 818.3015 495.7894 828.875 490.9479 C 815.6147 480.748 799.2809 475.0118 779.7577 475.0118 C 760.1282 475.0118 743.7171 480.7082 730.4375 490.9479 Z M 1173.243 1064.807 C 1161.902 1035.801 1083.613 932.1618 1031.609 867.813 L 1022.933 857.0248 L 1022.972 843.2588 C 1022.972 842.0126 1022.933 714.9798 990.4009 626.0769 C 966.8781 561.8232 914.6348 554.8784 893.2904 554.8784 C 839.2509 554.8784 815.9287 604.2055 815.107 605.9845 L 812.021 652.1912 L 746.3252 652.1912 L 743.3633 606.2509 C 742.427 604.158 719.6781 555.0021 665.9061 555.0021 C 644.5139 555.0021 592.2898 561.8708 568.7478 626.1245 C 536.3203 714.7135 536.1674 842.0126 536.1674 843.3064 L 536.2152 857.0723 L 527.5399 867.813 C 475.5641 932.1142 397.2661 1035.753 386.2117 1064.056 C 377.374 1094.67 391.9635 1292.644 410.5371 1458.54 L 411.5595 1467.749 L 396.9031 1507.029 C 447.2546 1559.591 482.5866 1631.931 506.9598 1700.789 L 509.3292 1684.027 L 589.2992 1553.179 L 620.542 1566.536 C 621.3255 1566.869 701.4483 1600.813 779.2495 1600.813 C 856.5538 1600.813 937.9952 1566.84 938.7596 1566.507 L 969.9546 1553.265 L 1049.829 1684.055 L 1052.963 1705.898 C 1077.078 1636.364 1112.372 1562.731 1162.962 1508.999 L 1147.618 1467.777 L 1148.64 1458.578 C 1167.204 1292.644 1181.794 1094.67 1173.243 1064.807 Z M 1192.873 1593.145 C 1110.187 1709.306 1084.246 1898.144 1082 1915.403 L 1097.083 2020.667 C 1158.482 1895.814 1222.897 1747.646 1227.313 1685.81 L 1192.873 1593.145 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp50)"><clipPath id="cp51"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp51)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 232.3125 2289.663 L 1327 2289.663 L 1327 309.3725 L 232.3125 309.3725 Z " fill="#333152"/></g></g><clipPath id="cp52"><path transform="matrix(1,0,0,-1,0,2448)" d="M 870.2128 785.0824 L 685.0288 785.0824 C 685.0288 785.0824 660.125 742.0627 660.125 728.1047 C 660.125 686.6508 774.1044 620.651 774.1044 620.651 C 774.1044 620.651 894.5 688.6175 894.5 728.1047 C 894.5 746.9413 870.2128 785.0824 870.2128 785.0824 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp52)"><clipPath id="cp53"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp53)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 640.125 805.0824 L 914.5 805.0824 L 914.5 600.651 L 640.125 600.651 Z " fill="#333152"/></g></g><clipPath id="cp54"><path transform="matrix(1,0,0,-1,0,2448)" d="M 832.5416 656.8079 C 822.5264 674.278 809.5964 677.4669 803.6638 663.9945 C 797.75 650.5128 801.132 625.4243 811.1472 607.9909 C 821.1624 590.5117 834.1018 587.3228 840.0063 600.8044 C 845.9388 614.2769 842.5755 639.3746 832.5416 656.8079 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp54)"><clipPath id="cp55"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp55)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 780.75 692.3294 L 862.9375 692.3294 L 862.9375 572.4627 L 780.75 572.4627 Z " fill="#c49a7e"/></g></g><clipPath id="cp56"><path transform="matrix(1,0,0,-1,0,2448)" d="M 722.0735 656.8079 C 712.0371 639.3746 708.701 614.2769 714.607 600.8044 C 720.5223 587.3228 733.4369 590.5117 743.5014 607.9909 C 753.5191 625.4151 756.8739 650.5128 750.9399 663.9945 C 745.0339 677.4669 732.11 674.278 722.0735 656.8079 Z " fill-rule="evenodd"/></clipPath><g clip-path="url(#cp56)"><clipPath id="cp57"><path transform="matrix(1,0,0,-1,0,2448)" d="M -16 -24 L 1580 -24 L 1580 2468 L -16 2468 Z "/></clipPath><g clip-path="url(#cp57)"><path transform="matrix(1,0,0,-1,0,2448)" d="M 691.6875 692.3294 L 773.875 692.3294 L 773.875 572.4627 L 691.6875 572.4627 Z " fill="#d8b7a0"/></g></g></g></g></g></g></g></svg>`;
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 26445:
|
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
exports.processHTMLOutput = exports.processAnalysis = exports.updateExcludeInPolicy = exports.driftignoreFromPolicy = exports.parseDriftAnalysisResults = exports.validateArgs = exports.DescribeRequiredArgs = exports.DescribeExclusiveArgs = void 0;
|
|
const fs = __webpack_require__(35747);
|
|
const describe_exclusive_argument_error_1 = __webpack_require__(47658);
|
|
const describe_required_argument_error_1 = __webpack_require__(37541);
|
|
const snyk_logo_1 = __webpack_require__(19679);
|
|
const snyk_favicon_1 = __webpack_require__(24030);
|
|
const output_1 = __webpack_require__(55659);
|
|
const driftctl_1 = __webpack_require__(3659);
|
|
exports.DescribeExclusiveArgs = [
|
|
'all',
|
|
'only-managed',
|
|
'drift',
|
|
'only-unmanaged',
|
|
];
|
|
exports.DescribeRequiredArgs = [
|
|
'all',
|
|
'only-managed',
|
|
'drift',
|
|
'only-unmanaged',
|
|
];
|
|
exports.validateArgs = (options) => {
|
|
if (options.kind === 'describe') {
|
|
return validateDescribeArgs(options);
|
|
}
|
|
};
|
|
const validateDescribeArgs = (options) => {
|
|
// Check that there is no more than one of the exclusive arguments
|
|
let count = 0;
|
|
for (const describeExclusiveArg of exports.DescribeExclusiveArgs) {
|
|
if (options[describeExclusiveArg]) {
|
|
count++;
|
|
}
|
|
}
|
|
if (count > 1) {
|
|
throw new describe_exclusive_argument_error_1.DescribeExclusiveArgumentError();
|
|
}
|
|
// Check we have one of the required arguments
|
|
count = 0;
|
|
for (const describeRequiredArgs of exports.DescribeRequiredArgs) {
|
|
if (options[describeRequiredArgs]) {
|
|
count++;
|
|
}
|
|
}
|
|
if (count === 0) {
|
|
throw new describe_required_argument_error_1.DescribeRequiredArgumentError();
|
|
}
|
|
};
|
|
exports.parseDriftAnalysisResults = (input) => {
|
|
return JSON.parse(input);
|
|
};
|
|
function driftignoreFromPolicy(policy) {
|
|
const excludeSection = 'iac-drift';
|
|
if (!policy || !policy.exclude || !(excludeSection in policy.exclude)) {
|
|
return [];
|
|
}
|
|
return policy.exclude[excludeSection];
|
|
}
|
|
exports.driftignoreFromPolicy = driftignoreFromPolicy;
|
|
exports.updateExcludeInPolicy = (policy, analysis, options) => {
|
|
var _a, _b, _c;
|
|
const excludedResources = driftignoreFromPolicy(policy);
|
|
const addResource = (res) => excludedResources.push(`${res.type}.${res.id}`);
|
|
if (!options['exclude-changed'] && analysis.summary.total_changed > 0) {
|
|
(_a = analysis.differences) === null || _a === void 0 ? void 0 : _a.forEach((change) => addResource(change.res));
|
|
}
|
|
if (!options['exclude-missing'] && analysis.summary.total_missing > 0) {
|
|
(_b = analysis.missing) === null || _b === void 0 ? void 0 : _b.forEach((res) => addResource(res));
|
|
}
|
|
if (!options['exclude-unmanaged'] && analysis.summary.total_unmanaged > 0) {
|
|
(_c = analysis.unmanaged) === null || _c === void 0 ? void 0 : _c.forEach((res) => addResource(res));
|
|
}
|
|
if (!policy.exclude) {
|
|
policy.exclude = {};
|
|
}
|
|
policy.exclude['iac-drift'] = excludedResources;
|
|
};
|
|
async function processAnalysis(options, describe) {
|
|
if (options.html || options['html-file-output']) {
|
|
// we use fmt for html output
|
|
const fmtResult = await driftctl_1.runDriftCTL({
|
|
options: { ...options, kind: 'fmt' },
|
|
input: describe.stdout,
|
|
});
|
|
const output = processHTMLOutput(options, fmtResult.stdout);
|
|
if (options.html) {
|
|
// html on stdout
|
|
return output;
|
|
}
|
|
// should return an empty string if we use the html-file-output flag
|
|
return '';
|
|
}
|
|
if (options.json) {
|
|
// json on stdout
|
|
return describe.stdout;
|
|
}
|
|
const analysis = exports.parseDriftAnalysisResults(describe.stdout);
|
|
return output_1.getHumanReadableAnalysis(options, analysis);
|
|
}
|
|
exports.processAnalysis = processAnalysis;
|
|
function processHTMLOutput(options, stdout) {
|
|
if (options.html) {
|
|
stdout = rebrandHTMLOutput(stdout);
|
|
}
|
|
if (options['html-file-output']) {
|
|
const data = fs.readFileSync(options['html-file-output'], {
|
|
encoding: 'utf8',
|
|
});
|
|
fs.writeFileSync(options['html-file-output'], rebrandHTMLOutput(data));
|
|
}
|
|
return stdout;
|
|
}
|
|
exports.processHTMLOutput = processHTMLOutput;
|
|
function rebrandHTMLOutput(data) {
|
|
// Replace favicon
|
|
const faviconReplaceRegex = new RegExp('(<link rel="shortcut icon")(.*)(\\/>)', 'g');
|
|
data = data.replace(faviconReplaceRegex, `<link rel="shortcut icon" type="image/x-icon" href="${snyk_favicon_1.default}" />`);
|
|
// Replace HTML title
|
|
const titleReplaceRegex = new RegExp('(<title>)(.*)(<\\/title>)', 'g');
|
|
data = data.replace(titleReplaceRegex, `<title>Snyk IaC drift report</title>`);
|
|
// Replace header brand logo
|
|
const logoReplaceRegex = new RegExp('(<div id="brand_logo">)((.|\\r|\\n)*?)(<\\/div>)', 'g');
|
|
data = data.replace(logoReplaceRegex, `<div id="brand_logo">${snyk_logo_1.default}</div>`);
|
|
return data;
|
|
}
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 3659:
|
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
|
|
|
|
var _a;
|
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
exports.runDriftCTL = exports.translateExitCode = exports.generateArgs = exports.driftctlVersion = exports.DCTL_EXIT_CODES = void 0;
|
|
const config_1 = __webpack_require__(25425);
|
|
const exit_codes_1 = __webpack_require__(80079);
|
|
const env_paths_1 = __webpack_require__(21766);
|
|
const metrics_1 = __webpack_require__(32971);
|
|
const analytics = __webpack_require__(82744);
|
|
const spinner_1 = __webpack_require__(86766);
|
|
const service_mappings_1 = __webpack_require__(16228);
|
|
const drift_1 = __webpack_require__(26445);
|
|
const debugLib = __webpack_require__(15158);
|
|
const request_1 = __webpack_require__(52050);
|
|
const path = __webpack_require__(85622);
|
|
const child_process = __webpack_require__(63129);
|
|
const fs = __webpack_require__(35747);
|
|
const os = __webpack_require__(12087);
|
|
const crypto = __webpack_require__(76417);
|
|
const file_utils_1 = __webpack_require__(52761);
|
|
const debug = debugLib('driftctl');
|
|
const cachePath = (_a = config_1.default.CACHE_PATH) !== null && _a !== void 0 ? _a : env_paths_1.default('snyk').cache;
|
|
exports.DCTL_EXIT_CODES = {
|
|
EXIT_IN_SYNC: 0,
|
|
EXIT_NOT_IN_SYNC: 1,
|
|
EXIT_ERROR: 2,
|
|
};
|
|
exports.driftctlVersion = 'v0.35.2';
|
|
const driftctlChecksums = {
|
|
driftctl_darwin_amd64: '1e21863bb99d104da8a1e33999563cc172ca51bb5b6ac7d3a4bd9678e0285067',
|
|
'driftctl_windows_386.exe': '20dc49a4faebfdbdf9f9198499ba2426ea6cda0666e82d81cd4e08a41516d5e0',
|
|
driftctl_darwin_arm64: '37b7a4c72f4db62b056f1b534eb93fbb8dd32c303719ed4af87d9bd4d903fcf6',
|
|
driftctl_linux_arm64: '3e6dabf013e097be1aac0e6e0f4ebcc3ada85a1906c6841d57fbe96c9ee9857e',
|
|
'driftctl_windows_arm.exe': '480c330fefdc6e1d58de943817556a1cd183d32d58b6cb20c8127cd3b8753dc4',
|
|
driftctl_linux_amd64: '80b7b99c343e1502f54321987c9f00fa3c381fbea819b1e440a0377b18706fb1',
|
|
'driftctl_windows_amd64.exe': 'bbc71047bd75e1bcd80752b7c03c27c0d8d7d93bec72a70eb8bc8220687805de',
|
|
'driftctl_windows_arm64.exe': 'be1a5564ec3351503caa16121d192ad8d8e8f287a5324939214b20177c7363e4',
|
|
driftctl_linux_arm: 'd04c911bdb86092743077bfbb025bfb8391978236bb381122594aeaa77f9a68f',
|
|
driftctl_linux_386: 'e720c2f3c25594c7b83ffb2123c461283589b6ee73b9a59c1c4f48bb2bac2775',
|
|
};
|
|
const dctlBaseUrl = 'https://static.snyk.io/cli/driftctl/';
|
|
const driftctlPath = path.join(cachePath, 'driftctl_' + exports.driftctlVersion);
|
|
const driftctlDefaultOptions = ['--no-version-check'];
|
|
let isBinaryDownloaded = false;
|
|
exports.generateArgs = async (options, driftIgnore) => {
|
|
if (options.kind === 'describe') {
|
|
return await generateScanFlags(options, driftIgnore);
|
|
}
|
|
if (options.kind === 'fmt') {
|
|
return generateFmtFlags(options);
|
|
}
|
|
throw 'Unsupported command';
|
|
};
|
|
const generateFmtFlags = (options) => {
|
|
const args = ['fmt', ...driftctlDefaultOptions];
|
|
if (options.json) {
|
|
args.push('--output');
|
|
args.push('json://stdout');
|
|
}
|
|
if (options.html) {
|
|
args.push('--output');
|
|
args.push('html://stdout');
|
|
}
|
|
if (options['html-file-output']) {
|
|
args.push('--output');
|
|
args.push('html://' + options['html-file-output']);
|
|
}
|
|
return args;
|
|
};
|
|
const generateScanFlags = async (options, driftIgnore) => {
|
|
const args = ['scan', ...driftctlDefaultOptions];
|
|
if (options.quiet) {
|
|
args.push('--quiet');
|
|
}
|
|
if (options.filter) {
|
|
args.push('--filter');
|
|
args.push(options.filter);
|
|
}
|
|
args.push('--output');
|
|
args.push('json://stdout');
|
|
if (options['fetch-tfstate-headers']) {
|
|
args.push('--headers');
|
|
args.push(options['fetch-tfstate-headers']);
|
|
}
|
|
if (options['tfc-token']) {
|
|
args.push('--tfc-token');
|
|
args.push(options['tfc-token']);
|
|
}
|
|
if (options['tfc-endpoint']) {
|
|
args.push('--tfc-endpoint');
|
|
args.push(options['tfc-endpoint']);
|
|
}
|
|
if (options['tf-provider-version']) {
|
|
args.push('--tf-provider-version');
|
|
args.push(options['tf-provider-version']);
|
|
}
|
|
if (options.strict) {
|
|
args.push('--strict');
|
|
}
|
|
if (options.deep || options.all) {
|
|
args.push('--deep');
|
|
}
|
|
if (options['only-managed'] || options.drift) {
|
|
args.push('--only-managed');
|
|
}
|
|
if (options['only-unmanaged']) {
|
|
args.push('--only-unmanaged');
|
|
}
|
|
if (options.driftignore) {
|
|
args.push('--driftignore');
|
|
args.push(options.driftignore);
|
|
}
|
|
if (options['tf-lockfile']) {
|
|
args.push('--tf-lockfile');
|
|
args.push(options['tf-lockfile']);
|
|
}
|
|
if (driftIgnore && driftIgnore.length > 0) {
|
|
args.push('--ignore');
|
|
args.push(driftIgnore.join(','));
|
|
}
|
|
let configDir = cachePath;
|
|
await file_utils_1.createDirIfNotExists(cachePath);
|
|
if (options['config-dir']) {
|
|
configDir = options['config-dir'];
|
|
}
|
|
args.push('--config-dir');
|
|
args.push(configDir);
|
|
if (options.from) {
|
|
const froms = options.from.split(',');
|
|
for (const f of froms) {
|
|
args.push('--from');
|
|
args.push(f);
|
|
}
|
|
}
|
|
let to = 'aws+tf';
|
|
if (options.to) {
|
|
to = options.to;
|
|
}
|
|
args.push('--to');
|
|
args.push(to);
|
|
if (options.service) {
|
|
const services = options.service.split(',');
|
|
service_mappings_1.verifyServiceMappingExists(services);
|
|
args.push('--ignore');
|
|
args.push(service_mappings_1.createIgnorePattern(services));
|
|
}
|
|
debug(args);
|
|
return args;
|
|
};
|
|
function translateExitCode(exitCode) {
|
|
switch (exitCode) {
|
|
case exports.DCTL_EXIT_CODES.EXIT_IN_SYNC:
|
|
return 0;
|
|
case exports.DCTL_EXIT_CODES.EXIT_NOT_IN_SYNC:
|
|
return exit_codes_1.EXIT_CODES.VULNS_FOUND;
|
|
case exports.DCTL_EXIT_CODES.EXIT_ERROR:
|
|
return exit_codes_1.EXIT_CODES.ERROR;
|
|
default:
|
|
debug('driftctl returned %d', exitCode);
|
|
return exit_codes_1.EXIT_CODES.ERROR;
|
|
}
|
|
}
|
|
exports.translateExitCode = translateExitCode;
|
|
exports.runDriftCTL = async ({ options, driftIgnore, input, stdio, }) => {
|
|
const path = await findOrDownload();
|
|
await drift_1.validateArgs(options);
|
|
const args = await exports.generateArgs(options, driftIgnore);
|
|
if (!stdio) {
|
|
stdio = ['pipe', 'pipe', 'inherit'];
|
|
}
|
|
debug('running driftctl %s ', args.join(' '));
|
|
const p = child_process.spawn(path, args, {
|
|
stdio,
|
|
env: { ...process.env, DCTL_IS_SNYK: 'true' },
|
|
});
|
|
let stdout = '';
|
|
return new Promise((resolve, reject) => {
|
|
var _a, _b, _c;
|
|
if (input) {
|
|
(_a = p.stdin) === null || _a === void 0 ? void 0 : _a.write(input);
|
|
(_b = p.stdin) === null || _b === void 0 ? void 0 : _b.end();
|
|
}
|
|
p.on('error', (error) => {
|
|
reject(error);
|
|
});
|
|
(_c = p.stdout) === null || _c === void 0 ? void 0 : _c.on('data', (data) => {
|
|
stdout += data;
|
|
});
|
|
p.on('exit', (code) => {
|
|
resolve({ code: translateExitCode(code), stdout });
|
|
});
|
|
});
|
|
};
|
|
async function findOrDownload() {
|
|
let dctl = await findDriftCtl();
|
|
if (isBinaryDownloaded) {
|
|
return dctl;
|
|
}
|
|
let downloadDuration = 0;
|
|
let binaryExist = true;
|
|
if (dctl === '') {
|
|
binaryExist = false;
|
|
try {
|
|
await file_utils_1.createDirIfNotExists(cachePath);
|
|
dctl = driftctlPath;
|
|
const duration = new metrics_1.TimerMetricInstance('driftctl_download');
|
|
duration.start();
|
|
await download(driftctlUrl(), dctl);
|
|
duration.stop();
|
|
downloadDuration = Math.round(duration.getValue() / 1000);
|
|
}
|
|
catch (err) {
|
|
return Promise.reject(err);
|
|
}
|
|
}
|
|
analytics.add('iac-drift-binary-already-exist', binaryExist);
|
|
analytics.add('iac-drift-binary-download-duration-seconds', downloadDuration);
|
|
isBinaryDownloaded = true;
|
|
return dctl;
|
|
}
|
|
async function findDriftCtl() {
|
|
// lookup in custom path contained in env var DRIFTCTL_PATH
|
|
let dctlPath = config_1.default.DRIFTCTL_PATH;
|
|
if (dctlPath != null) {
|
|
const exists = await file_utils_1.isExe(dctlPath);
|
|
if (exists) {
|
|
debug('Found driftctl in $DRIFTCTL_PATH: %s', dctlPath);
|
|
return dctlPath;
|
|
}
|
|
}
|
|
// lookup in app cache
|
|
dctlPath = driftctlPath;
|
|
const exists = await file_utils_1.isExe(dctlPath);
|
|
if (exists) {
|
|
debug('Found driftctl in cache: %s', dctlPath);
|
|
return dctlPath;
|
|
}
|
|
debug('driftctl not found');
|
|
return '';
|
|
}
|
|
async function download(url, destination) {
|
|
debug('downloading driftctl into %s', destination);
|
|
const payload = {
|
|
method: 'GET',
|
|
url: url,
|
|
output: destination,
|
|
follow: 3,
|
|
};
|
|
await spinner_1.spinner('Downloading...');
|
|
return new Promise((resolve, reject) => {
|
|
request_1.makeRequest(payload, function (err, res, body) {
|
|
try {
|
|
if (err) {
|
|
reject(new Error('Could not download driftctl from ' + url + ': ' + err));
|
|
return;
|
|
}
|
|
if (res.statusCode !== 200) {
|
|
reject(new Error('Could not download driftctl from ' + url + ': ' + res.statusCode));
|
|
return;
|
|
}
|
|
validateChecksum(body);
|
|
fs.writeFileSync(destination, body);
|
|
debug('File saved: ' + destination);
|
|
fs.chmodSync(destination, 0o744);
|
|
resolve(true);
|
|
}
|
|
finally {
|
|
spinner_1.spinner.clearAll();
|
|
}
|
|
});
|
|
});
|
|
}
|
|
function validateChecksum(body) {
|
|
// only validate if we downloaded the official driftctl binary
|
|
if (config_1.default.DRIFTCTL_URL || config_1.default.DRIFTCTL_PATH) {
|
|
return;
|
|
}
|
|
const computedHash = crypto
|
|
.createHash('sha256')
|
|
.update(body)
|
|
.digest('hex');
|
|
const givenHash = driftctlChecksums[driftctlFileName()];
|
|
if (computedHash != givenHash) {
|
|
throw new Error('Downloaded file has inconsistent checksum...');
|
|
}
|
|
}
|
|
function driftctlFileName() {
|
|
let platform = 'linux';
|
|
switch (os.platform()) {
|
|
case 'darwin':
|
|
platform = 'darwin';
|
|
break;
|
|
case 'win32':
|
|
platform = 'windows';
|
|
break;
|
|
}
|
|
let arch = 'amd64';
|
|
switch (os.arch()) {
|
|
case 'ia32':
|
|
case 'x32':
|
|
arch = '386';
|
|
break;
|
|
case 'arm':
|
|
arch = 'arm';
|
|
break;
|
|
case 'arm64':
|
|
arch = 'arm64';
|
|
break;
|
|
}
|
|
let ext = '';
|
|
switch (os.platform()) {
|
|
case 'win32':
|
|
ext = '.exe';
|
|
break;
|
|
}
|
|
return `driftctl_${platform}_${arch}${ext}`;
|
|
}
|
|
function driftctlUrl() {
|
|
if (config_1.default.DRIFTCTL_URL) {
|
|
return config_1.default.DRIFTCTL_URL;
|
|
}
|
|
return `${dctlBaseUrl}/${exports.driftctlVersion}/${driftctlFileName()}`;
|
|
}
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 55659:
|
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
exports.getHumanReadableAnalysis = void 0;
|
|
const service_mappings_1 = __webpack_require__(16228);
|
|
const chalk_1 = __webpack_require__(32589);
|
|
const common_1 = __webpack_require__(47724);
|
|
const jsondiffpatch_1 = __webpack_require__(79732);
|
|
function getHumanReadableAnalysis(option, analysis) {
|
|
let output = getHumanReadableHeader();
|
|
if (!option['only-unmanaged']) {
|
|
output += getHumanReadableManaged(analysis);
|
|
}
|
|
if (!option['only-managed'] && !option.drift) {
|
|
output += getHumanReadableUnmanaged(analysis);
|
|
}
|
|
output += getHumanReadableSummary(analysis);
|
|
return output;
|
|
}
|
|
exports.getHumanReadableAnalysis = getHumanReadableAnalysis;
|
|
function changeAsString(obj) {
|
|
if (typeof obj === 'string') {
|
|
return obj;
|
|
}
|
|
return JSON.stringify(obj);
|
|
}
|
|
function isJsonDiff(driftChange) {
|
|
if (!(typeof driftChange.from === 'string')) {
|
|
return false;
|
|
}
|
|
try {
|
|
JSON.parse(driftChange.from);
|
|
}
|
|
catch (e) {
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
function getNonJsonDiff(driftChange) {
|
|
let output = '';
|
|
switch (driftChange.type) {
|
|
case 'create':
|
|
output += chalk_1.default.green('+') + ' ' + driftChange.path.join('.') + ': ';
|
|
output +=
|
|
chalk_1.default.bold(changeAsString(driftChange.from)) +
|
|
' => ' +
|
|
chalk_1.default.green(changeAsString(driftChange.to));
|
|
break;
|
|
case 'update':
|
|
output += chalk_1.default.yellow('~') + ' ' + driftChange.path.join('.') + ': ';
|
|
output +=
|
|
chalk_1.default.bold(changeAsString(driftChange.from)) +
|
|
' => ' +
|
|
chalk_1.default.yellow(changeAsString(driftChange.to));
|
|
break;
|
|
case 'delete':
|
|
output += chalk_1.default.red('-') + ' ' + driftChange.path.join('.') + ': ';
|
|
output += chalk_1.default.red(changeAsString(driftChange.from));
|
|
break;
|
|
default:
|
|
output += driftChange.path.join('.') + ': ';
|
|
output +=
|
|
chalk_1.default.bold(changeAsString(driftChange.from)) +
|
|
' => ' +
|
|
chalk_1.default.bold(changeAsString(driftChange.to));
|
|
break;
|
|
}
|
|
output += '\n';
|
|
return output;
|
|
}
|
|
function getJsonDiff(driftChange) {
|
|
let output = '';
|
|
let from = null;
|
|
if (driftChange.from) {
|
|
from = JSON.parse(driftChange.from);
|
|
}
|
|
let to = null;
|
|
if (driftChange.to) {
|
|
to = JSON.parse(driftChange.to);
|
|
}
|
|
let diffStr = '';
|
|
const diffPatch = jsondiffpatch_1.create().diff(from, to);
|
|
if (diffPatch) {
|
|
diffStr = jsondiffpatch_1.console.format(diffPatch, from);
|
|
}
|
|
switch (driftChange.type) {
|
|
case 'create':
|
|
output += chalk_1.default.green('+') + ' ' + driftChange.path.join('.') + ':\n';
|
|
break;
|
|
case 'update':
|
|
output += chalk_1.default.yellow('~') + ' ' + driftChange.path.join('.') + ':\n';
|
|
break;
|
|
case 'delete':
|
|
output += chalk_1.default.red('-') + ' ' + driftChange.path.join('.') + ':\n';
|
|
break;
|
|
default:
|
|
output += driftChange.path.join('.') + ':\n';
|
|
break;
|
|
}
|
|
for (const elem of diffStr.split('\n')) {
|
|
output += addLine(common_1.leftPad(elem, 4));
|
|
}
|
|
return output;
|
|
}
|
|
function getHumanReadableDrift(analysis) {
|
|
var _a;
|
|
let output = '';
|
|
if (!analysis.differences || analysis.differences.length <= 0) {
|
|
return '';
|
|
}
|
|
const diffByStates = new Map();
|
|
for (const difference of analysis.differences) {
|
|
let statefile = 'Generated';
|
|
if (difference.res.source) {
|
|
statefile = difference.res.source.source;
|
|
}
|
|
if (!diffByStates.has(statefile)) {
|
|
diffByStates.set(statefile, {
|
|
diffByType: new Map(),
|
|
count: 0,
|
|
});
|
|
}
|
|
const hrDiffs = mustGet(diffByStates, statefile);
|
|
const type = difference.res.type;
|
|
if (!hrDiffs.diffByType.has(type)) {
|
|
hrDiffs.diffByType.set(type, []);
|
|
}
|
|
(_a = hrDiffs.diffByType.get(type)) === null || _a === void 0 ? void 0 : _a.push(difference);
|
|
hrDiffs.count++;
|
|
}
|
|
output += addLine(chalk_1.default.bold('Changed resources: ' + analysis.differences.length));
|
|
output += '\n';
|
|
for (const state of [...diffByStates.keys()].sort()) {
|
|
const hrDiffs = mustGet(diffByStates, state);
|
|
output += addLine(chalk_1.default.blue('State: ' +
|
|
chalk_1.default.bold(state) +
|
|
' [ Changed Resources: ' +
|
|
chalk_1.default.bold(hrDiffs.count.toString()) +
|
|
' ]'));
|
|
output += '\n';
|
|
for (const type of [...hrDiffs.diffByType.keys()].sort()) {
|
|
output += addLine(common_1.leftPad('Resource Type: ' + type, 2));
|
|
const diffs = mustGet(hrDiffs.diffByType, type);
|
|
for (const diff of diffs) {
|
|
output += common_1.leftPad('ID: ' + chalk_1.default.bold(diff.res.id), 4);
|
|
if (diff.res.human_readable_attributes &&
|
|
diff.res.human_readable_attributes.size > 0) {
|
|
for (const humanReadableAttribute of [
|
|
...diff.res.human_readable_attributes.keys(),
|
|
].sort()) {
|
|
output +=
|
|
' ' +
|
|
humanReadableAttribute +
|
|
': ' +
|
|
diff.res.human_readable_attributes.get(humanReadableAttribute);
|
|
}
|
|
}
|
|
output += '\n';
|
|
for (const driftChange of diff.changelog) {
|
|
output += common_1.leftPad('');
|
|
if (isJsonDiff(driftChange)) {
|
|
output += getJsonDiff(driftChange);
|
|
}
|
|
else {
|
|
output += getNonJsonDiff(driftChange);
|
|
}
|
|
}
|
|
output += '\n';
|
|
}
|
|
}
|
|
}
|
|
return output;
|
|
}
|
|
function getHumanReadableMissing(analysis) {
|
|
var _a;
|
|
let output = '';
|
|
if (!analysis.missing || analysis.missing.length <= 0) {
|
|
return '';
|
|
}
|
|
const missingByStates = new Map();
|
|
for (const missing of analysis.missing) {
|
|
let statefile = 'Generated';
|
|
if (missing.source) {
|
|
statefile = missing.source.source;
|
|
}
|
|
if (!missingByStates.has(statefile)) {
|
|
missingByStates.set(statefile, {
|
|
missingByType: new Map(),
|
|
count: 0,
|
|
});
|
|
}
|
|
const hrMissing = mustGet(missingByStates, statefile);
|
|
const type = missing.type;
|
|
if (!hrMissing.missingByType.has(type)) {
|
|
hrMissing.missingByType.set(type, []);
|
|
}
|
|
(_a = hrMissing.missingByType.get(type)) === null || _a === void 0 ? void 0 : _a.push(missing);
|
|
hrMissing.count++;
|
|
}
|
|
output += addLine(chalk_1.default.bold('Missing resources: ' + analysis.missing.length));
|
|
output += '\n';
|
|
for (const state of [...missingByStates.keys()].sort()) {
|
|
const hrMissing = mustGet(missingByStates, state);
|
|
output += addLine(chalk_1.default.blue('State: ' +
|
|
chalk_1.default.bold(state) +
|
|
' [ Missing Resources: ' +
|
|
chalk_1.default.bold(hrMissing.count.toString()) +
|
|
' ]'));
|
|
output += '\n';
|
|
for (const type of [...hrMissing.missingByType.keys()].sort()) {
|
|
output += addLine(common_1.leftPad('Resource Type: ' + type, 2));
|
|
const driftResources = mustGet(hrMissing.missingByType, type);
|
|
output += getHumanReadableResourceList(driftResources) + '\n';
|
|
}
|
|
}
|
|
return output;
|
|
}
|
|
function getHumanReadableManaged(analysis) {
|
|
let output = '';
|
|
if (analysis.differences && analysis.differences.length > 0) {
|
|
output += getHumanReadableDrift(analysis);
|
|
}
|
|
if (analysis.missing && analysis.missing.length > 0) {
|
|
output += getHumanReadableMissing(analysis);
|
|
}
|
|
return output;
|
|
}
|
|
function getHumanReadableResourceList(driftResources) {
|
|
let output = '';
|
|
for (const res of driftResources) {
|
|
output += common_1.leftPad('ID: ' + chalk_1.default.bold(res.id), 4);
|
|
if (res.human_readable_attributes &&
|
|
res.human_readable_attributes.size > 0) {
|
|
for (const humanReadableAttribute of [
|
|
...res.human_readable_attributes.keys(),
|
|
].sort()) {
|
|
output +=
|
|
' ' +
|
|
humanReadableAttribute +
|
|
': ' +
|
|
res.human_readable_attributes.get(humanReadableAttribute);
|
|
}
|
|
}
|
|
output += '\n';
|
|
}
|
|
return output;
|
|
}
|
|
function getHumanReadableUnmanaged(analysis) {
|
|
var _a;
|
|
let output = '';
|
|
if (!analysis.unmanaged || analysis.unmanaged.length <= 0) {
|
|
return '';
|
|
}
|
|
const unmanagedByServices = new Map();
|
|
for (const unmanaged of analysis.unmanaged) {
|
|
const service = service_mappings_1.findServiceMappingForType(unmanaged.type);
|
|
if (!unmanagedByServices.has(service)) {
|
|
unmanagedByServices.set(service, {
|
|
unmanagedByType: new Map(),
|
|
count: 0,
|
|
});
|
|
}
|
|
const hrUnmanaged = mustGet(unmanagedByServices, service);
|
|
const type = unmanaged.type;
|
|
if (!hrUnmanaged.unmanagedByType.has(type)) {
|
|
hrUnmanaged.unmanagedByType.set(type, []);
|
|
}
|
|
(_a = hrUnmanaged.unmanagedByType.get(type)) === null || _a === void 0 ? void 0 : _a.push(unmanaged);
|
|
hrUnmanaged.count++;
|
|
}
|
|
output += addLine(chalk_1.default.bold('Unmanaged resources: ' + analysis.unmanaged.length));
|
|
output += '\n';
|
|
for (let service of [...unmanagedByServices.keys()].sort()) {
|
|
const hrUnmanaged = mustGet(unmanagedByServices, service);
|
|
if (service === '') {
|
|
service = 'Unidentified';
|
|
}
|
|
output += addLine(chalk_1.default.blue('Service: ' +
|
|
chalk_1.default.bold(service) +
|
|
' [ Unmanaged Resources: ' +
|
|
chalk_1.default.bold(hrUnmanaged.count.toString()) +
|
|
' ]'));
|
|
output += '\n';
|
|
for (const type of [...hrUnmanaged.unmanagedByType.keys()].sort()) {
|
|
output += addLine(common_1.leftPad('Resource Type: ' + type, 2));
|
|
const driftResources = mustGet(hrUnmanaged.unmanagedByType, type);
|
|
output += getHumanReadableResourceList(driftResources) + '\n';
|
|
}
|
|
}
|
|
return output;
|
|
}
|
|
function getHumanReadableHeader() {
|
|
// TODO: driftctl to return number of states and supported resources?
|
|
let output = addLine(chalk_1.default.bold('Snyk Scanning Infrastructure As Code Discrepancies...'));
|
|
output += '\n';
|
|
output += addLine(common_1.leftPad('Info: Resources under IaC, but different to terraform states.', 2));
|
|
output += addLine(common_1.leftPad('Resolve: Reapply IaC resources or update into terraform.', 2));
|
|
output += '\n';
|
|
return output;
|
|
}
|
|
function getHumanReadableSummary(analysis) {
|
|
let output = addLine(chalk_1.default.bold('Test Summary'));
|
|
output += '\n';
|
|
// TODO: driftctl to return number of states
|
|
if (analysis.managed) {
|
|
output += addLine(common_1.leftPad('Managed Resources: ' + chalk_1.default.bold(analysis.managed.length.toString()), 2));
|
|
}
|
|
if (analysis.differences) {
|
|
output += addLine(common_1.leftPad('Changed Resources: ' +
|
|
chalk_1.default.bold(analysis.differences.length.toString()), 2));
|
|
}
|
|
if (analysis.missing) {
|
|
output += addLine(common_1.leftPad('Missing Resources: ' + chalk_1.default.bold(analysis.missing.length.toString()), 2));
|
|
}
|
|
if (analysis.unmanaged) {
|
|
output += addLine(common_1.leftPad('Unmanaged Resources: ' +
|
|
chalk_1.default.bold(analysis.unmanaged.length.toString()), 2));
|
|
}
|
|
output += '\n';
|
|
output += addLine(common_1.leftPad('IaC Coverage: ' + chalk_1.default.bold(analysis.coverage.toString() + '%'), 2));
|
|
output += addLine(common_1.leftPad('Info: To reach full coverage, remove resources or move it to Terraform.', 2));
|
|
output += '\n';
|
|
output += addLine(common_1.leftPad('Tip: Run --help to find out about commands and flags.', 2));
|
|
output += addLine(common_1.leftPad('Scanned with ' +
|
|
analysis.provider_name +
|
|
' provider version ' +
|
|
analysis.provider_version +
|
|
'. Use --tf-provider-version to update.', 6));
|
|
return output;
|
|
}
|
|
function addLine(line) {
|
|
return line + '\n';
|
|
}
|
|
// Used when we are sure the key exists because we just set it but typescript linter does not see that...
|
|
function mustGet(map, key) {
|
|
const value = map.get(key);
|
|
if (!value) {
|
|
throw new Error('Key does not exists');
|
|
}
|
|
return value;
|
|
}
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 52761:
|
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
exports.saveFile = exports.isArchive = exports.isFile = exports.createDirIfNotExists = exports.isExists = exports.isExe = void 0;
|
|
const tar = __webpack_require__(97998);
|
|
const fs_1 = __webpack_require__(35747);
|
|
const util_1 = __webpack_require__(31669);
|
|
async function isExe(path) {
|
|
try {
|
|
await fs_1.promises.access(path, fs_1.constants.X_OK);
|
|
return true;
|
|
}
|
|
catch (err) {
|
|
return false;
|
|
}
|
|
}
|
|
exports.isExe = isExe;
|
|
async function isExists(path) {
|
|
try {
|
|
await fs_1.promises.stat(path);
|
|
return true;
|
|
}
|
|
catch (err) {
|
|
return false;
|
|
}
|
|
}
|
|
exports.isExists = isExists;
|
|
async function createDirIfNotExists(path) {
|
|
const isDirExists = await isExists(path);
|
|
if (!isDirExists) {
|
|
fs_1.promises.mkdir(path, { recursive: true });
|
|
}
|
|
}
|
|
exports.createDirIfNotExists = createDirIfNotExists;
|
|
async function isFile(path) {
|
|
try {
|
|
return (await fs_1.promises.stat(path)).isFile();
|
|
}
|
|
catch (err) {
|
|
return false;
|
|
}
|
|
}
|
|
exports.isFile = isFile;
|
|
async function isArchive(path) {
|
|
try {
|
|
const tarList = util_1.promisify(tar.list);
|
|
await tarList({ file: path, strict: true });
|
|
return true;
|
|
}
|
|
catch (e) {
|
|
return false;
|
|
}
|
|
}
|
|
exports.isArchive = isArchive;
|
|
async function saveFile(dataBuffer, savePath) {
|
|
await fs_1.promises.writeFile(savePath, dataBuffer);
|
|
await fs_1.promises.chmod(savePath, 0o744);
|
|
}
|
|
exports.saveFile = saveFile;
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ 16228:
|
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
exports.InvalidServiceError = exports.createIgnorePatternWithMap = exports.createIgnorePattern = exports.findServiceMappingForType = exports.verifyServiceMappingExists = exports.services2resources = void 0;
|
|
const errors_1 = __webpack_require__(55191);
|
|
const types_1 = __webpack_require__(94820);
|
|
const error_utils_1 = __webpack_require__(36401);
|
|
exports.services2resources = new Map([
|
|
// Amazon
|
|
[
|
|
'aws_s3',
|
|
[
|
|
'aws_s3_bucket',
|
|
'aws_s3_bucket_analytics_configuration',
|
|
'aws_s3_bucket_inventory',
|
|
'aws_s3_bucket_metric',
|
|
'aws_s3_bucket_notification',
|
|
'aws_s3_bucket_policy',
|
|
],
|
|
],
|
|
[
|
|
'aws_ec2',
|
|
[
|
|
'aws_instance',
|
|
'aws_key_pair',
|
|
'aws_ami',
|
|
'aws_ebs_snapshot',
|
|
'aws_ebs_volume',
|
|
'aws_eip',
|
|
'aws_eip_association',
|
|
'aws_volume_attachment',
|
|
'aws_launch_configuration',
|
|
'aws_launch_template',
|
|
],
|
|
],
|
|
['aws_lambda', ['aws_lambda_function', 'aws_lambda_event_source_mapping']],
|
|
[
|
|
'aws_rds',
|
|
[
|
|
'aws_db_instance',
|
|
'aws_db_subnet_group',
|
|
'aws_rds_cluster',
|
|
'aws_rds_cluster_endpoint',
|
|
'aws_rds_cluster_instance',
|
|
],
|
|
],
|
|
['aws_route53', ['aws_route53_record', 'aws_route53_zone']],
|
|
[
|
|
'aws_iam',
|
|
[
|
|
'aws_iam_access_key',
|
|
'aws_iam_policy',
|
|
'aws_iam_policy_attachment',
|
|
'aws_iam_role',
|
|
'aws_iam_role_policy',
|
|
'aws_iam_role_policy_attachment',
|
|
'aws_iam_user',
|
|
'aws_iam_user_policy',
|
|
'aws_iam_user_policy_attachment',
|
|
],
|
|
],
|
|
[
|
|
'aws_vpc',
|
|
[
|
|
'aws_security_group',
|
|
'aws_security_group_rule',
|
|
'aws_subnet',
|
|
'aws_default_vpc',
|
|
'aws_vpc',
|
|
'aws_default_security_group',
|
|
'aws_route_table',
|
|
'aws_default_route_table',
|
|
'aws_route',
|
|
'aws_route_table_association',
|
|
'aws_nat_gateway',
|
|
'aws_internet_gateway',
|
|
],
|
|
],
|
|
[
|
|
'aws_api_gateway',
|
|
[
|
|
'aws_api_gateway_resource',
|
|
'aws_api_gateway_rest_api',
|
|
'aws_api_gateway_account',
|
|
'aws_api_gateway_api_key',
|
|
'aws_api_gateway_authorizer',
|
|
'aws_api_gateway_base_path_mapping',
|
|
'aws_api_gateway_domain_name',
|
|
'aws_api_gateway_gateway_response',
|
|
'aws_api_gateway_integration',
|
|
'aws_api_gateway_integration_response',
|
|
'aws_api_gateway_method',
|
|
'aws_api_gateway_method_response',
|
|
'aws_api_gateway_method_settings',
|
|
'aws_api_gateway_model',
|
|
'aws_api_gateway_request_validator',
|
|
'aws_api_gateway_rest_api_policy',
|
|
'aws_api_gateway_stage',
|
|
'aws_api_gateway_vpc_link',
|
|
],
|
|
],
|
|
[
|
|
'aws_apigatewayv2',
|
|
[
|
|
'aws_apigatewayv2_api',
|
|
'aws_apigatewayv2_api_mapping',
|
|
'aws_apigatewayv2_authorizer',
|
|
'aws_apigatewayv2_deployment',
|
|
'aws_apigatewayv2_domain_name',
|
|
'aws_apigatewayv2_integration',
|
|
'aws_apigatewayv2_integration_response',
|
|
'aws_apigatewayv2_model',
|
|
'aws_apigatewayv2_route',
|
|
'aws_apigatewayv2_route_response',
|
|
'aws_apigatewayv2_stage',
|
|
'aws_apigatewayv2_vpc_link',
|
|
],
|
|
],
|
|
['aws_sqs', ['aws_sqs_queue', 'aws_sqs_queue_policy']],
|
|
[
|
|
'aws_sns',
|
|
['aws_sns_topic', 'aws_sns_topic_policy', 'aws_sns_topic_subscription'],
|
|
],
|
|
['aws_ecr', ['aws_ecr_repository']],
|
|
['aws_cloudfront', ['aws_cloudfront_distribution']],
|
|
['aws_kms', ['aws_kms_key', 'aws_kms_alias']],
|
|
['aws_dynamodb', ['aws_dynamodb_table']],
|
|
// Azure
|
|
['azure_base', ['azurerm_resource_group']],
|
|
['azure_compute', ['azurerm_image', 'azurerm_ssh_public_key']],
|
|
['azure_storage', ['azurerm_storage_account', 'azurerm_storage_container']],
|
|
[
|
|
'azure_network',
|
|
[
|
|
'azurerm_resource_group',
|
|
'azurerm_subnet',
|
|
'azurerm_public_ip',
|
|
'azurerm_firewall',
|
|
'azurerm_route',
|
|
'azurerm_route_table',
|
|
'azurerm_network_security_group',
|
|
],
|
|
],
|
|
['azure_container', ['azurerm_container_registry']],
|
|
[
|
|
'azure_database',
|
|
['azurerm_postgresql_server', 'azurerm_postgresql_database'],
|
|
],
|
|
['azure_loadbalancer', ['azurerm_lb', 'azurerm_lb_rule']],
|
|
[
|
|
'azure_private_dns',
|
|
[
|
|
'azurerm_private_dns_a_record',
|
|
'azurerm_private_dns_aaaa_record',
|
|
'azurerm_private_dns_cname_record',
|
|
'azurerm_private_dns_mx_record',
|
|
'azurerm_private_dns_ptr_record',
|
|
'azurerm_private_dns_srv_record',
|
|
'azurerm_private_dns_txt_record',
|
|
'azurerm_private_dns_zone',
|
|
],
|
|
],
|
|
// Google
|
|
[
|
|
'google_cloud_platform',
|
|
[
|
|
'google_project_iam_binding',
|
|
'google_project_iam_member',
|
|
'google_project_iam_policy',
|
|
],
|
|
],
|
|
[
|
|
'google_cloud_storage',
|
|
[
|
|
'google_storage_bucket',
|
|
'google_storage_bucket_iam_binding',
|
|
'google_storage_bucket_iam_member',
|
|
'google_storage_bucket_iam_policy',
|
|
],
|
|
],
|
|
[
|
|
'google_compute_engine',
|
|
[
|
|
'google_compute_address',
|
|
'google_compute_disk',
|
|
'google_compute_global_address',
|
|
'google_compute_firewall',
|
|
'google_compute_health_check',
|
|
'google_compute_image',
|
|
'google_compute_instance',
|
|
'google_compute_instance_group',
|
|
'google_compute_network',
|
|
'google_compute_node_group',
|
|
'google_compute_router',
|
|
'google_compute_subnetwork',
|
|
],
|
|
],
|
|
['google_cloud_dns', ['google_dns_managed_zone']],
|
|
[
|
|
'google_cloud_bigtable',
|
|
['google_bigtable_instance', 'google_bigtable_table'],
|
|
],
|
|
[
|
|
'google_cloud_bigquery',
|
|
['google_bigquery_table', 'google_bigquery_dataset'],
|
|
],
|
|
['google_cloud_functions', ['google_cloudfunctions_function']],
|
|
['google_cloud_sql', ['google_sql_database_instance']],
|
|
['google_cloud_run', ['google_cloud_run_service']],
|
|
]);
|
|
function verifyServiceMappingExists(services) {
|
|
if (services.length == 0) {
|
|
throw new InvalidServiceError('');
|
|
}
|
|
for (const s of services) {
|
|
if (!exports.services2resources.has(s)) {
|
|
throw new InvalidServiceError(`We were unable to match service "${s}". Please provide a valid service name: ${existingServiceNames()}`);
|
|
}
|
|
}
|
|
}
|
|
exports.verifyServiceMappingExists = verifyServiceMappingExists;
|
|
function findServiceMappingForType(type) {
|
|
var _a;
|
|
for (const service of exports.services2resources.keys()) {
|
|
if ((_a = exports.services2resources.get(service)) === null || _a === void 0 ? void 0 : _a.includes(type)) {
|
|
return service;
|
|
}
|
|
}
|
|
return '';
|
|
}
|
|
exports.findServiceMappingForType = findServiceMappingForType;
|
|
function existingServiceNames() {
|
|
let res = '';
|
|
for (const s of exports.services2resources.keys()) {
|
|
res += `${s},`;
|
|
}
|
|
return res.substring(0, res.length - 1);
|
|
}
|
|
function createIgnorePattern(services) {
|
|
return createIgnorePatternWithMap(services, exports.services2resources);
|
|
}
|
|
exports.createIgnorePattern = createIgnorePattern;
|
|
function createIgnorePatternWithMap(services, serviceMap) {
|
|
let res = '*';
|
|
const seenResources = new Set();
|
|
for (const s of services) {
|
|
const resourcePatterns = serviceMap.get(s);
|
|
for (const rp of resourcePatterns || []) {
|
|
// A resource might belong to multiple services, skip it if already processed
|
|
if (seenResources.has(rp)) {
|
|
continue;
|
|
}
|
|
res += `,!${rp}`;
|
|
seenResources.add(rp);
|
|
}
|
|
}
|
|
return res;
|
|
}
|
|
exports.createIgnorePatternWithMap = createIgnorePatternWithMap;
|
|
class InvalidServiceError extends errors_1.CustomError {
|
|
constructor(msg) {
|
|
super(msg);
|
|
this.code = types_1.IaCErrorCodes.InvalidServiceError;
|
|
this.strCode = error_utils_1.getErrorStringCode(this.code);
|
|
this.userMessage = msg;
|
|
}
|
|
}
|
|
exports.InvalidServiceError = InvalidServiceError;
|
|
|
|
|
|
/***/ })
|
|
|
|
};
|
|
;
|
|
//# sourceMappingURL=895.index.js.map
|