aws-ec2-instance-running-scheduler 3.1.2 → 3.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.jsii CHANGED
@@ -8968,6 +8968,6 @@
8968
8968
  "symbolId": "src/constructs/ec2-instance-running-scheduler:TargetResource"
8969
8969
  }
8970
8970
  },
8971
- "version": "3.1.2",
8972
- "fingerprint": "UgxefOblfihXBUKJhjAUapKz9wv2D2H/j5GANVKbAp0="
8971
+ "version": "3.1.3",
8972
+ "fingerprint": "5Nv5bNjOpTE3WkBI2k9ImeKEc+Xa04nNQGGWAcwyAck="
8973
8973
  }
@@ -12607,9 +12607,14 @@ var require_axios = __commonJS({
12607
12607
  var G = getGlobal();
12608
12608
  var FormDataCtor = typeof G.FormData !== "undefined" ? G.FormData : void 0;
12609
12609
  var isFormData = (thing) => {
12610
- let kind;
12611
- return thing && (FormDataCtor && thing instanceof FormDataCtor || isFunction$1(thing.append) && ((kind = kindOf(thing)) === "formdata" || // detect form-data instance
12612
- kind === "object" && isFunction$1(thing.toString) && thing.toString() === "[object FormData]"));
12610
+ if (!thing) return false;
12611
+ if (FormDataCtor && thing instanceof FormDataCtor) return true;
12612
+ const proto = getPrototypeOf(thing);
12613
+ if (!proto || proto === Object.prototype) return false;
12614
+ if (!isFunction$1(thing.append)) return false;
12615
+ const kind = kindOf(thing);
12616
+ return kind === "formdata" || // detect form-data instance
12617
+ kind === "object" && isFunction$1(thing.toString) && thing.toString() === "[object FormData]";
12613
12618
  };
12614
12619
  var isURLSearchParams = kindOfTest("URLSearchParams");
12615
12620
  var [isReadableStream, isRequest, isResponse, isHeaders] = ["ReadableStream", "Request", "Response", "Headers"].map(kindOfTest);
@@ -13037,6 +13042,7 @@ var require_axios = __commonJS({
13037
13042
  AxiosError.ERR_CANCELED = "ERR_CANCELED";
13038
13043
  AxiosError.ERR_NOT_SUPPORT = "ERR_NOT_SUPPORT";
13039
13044
  AxiosError.ERR_INVALID_URL = "ERR_INVALID_URL";
13045
+ AxiosError.ERR_FORM_DATA_DEPTH_EXCEEDED = "ERR_FORM_DATA_DEPTH_EXCEEDED";
13040
13046
  function isVisitable(thing) {
13041
13047
  return utils$1.isPlainObject(thing) || utils$1.isArray(thing);
13042
13048
  }
@@ -13073,6 +13079,7 @@ var require_axios = __commonJS({
13073
13079
  const dots = options.dots;
13074
13080
  const indexes = options.indexes;
13075
13081
  const _Blob = options.Blob || typeof Blob !== "undefined" && Blob;
13082
+ const maxDepth = options.maxDepth === void 0 ? 100 : options.maxDepth;
13076
13083
  const useBlob = _Blob && utils$1.isSpecCompliantForm(formData);
13077
13084
  if (!utils$1.isFunction(visitor)) {
13078
13085
  throw new TypeError("visitor must be a function");
@@ -13127,8 +13134,11 @@ var require_axios = __commonJS({
13127
13134
  convertValue,
13128
13135
  isVisitable
13129
13136
  });
13130
- function build(value, path) {
13137
+ function build(value, path, depth = 0) {
13131
13138
  if (utils$1.isUndefined(value)) return;
13139
+ if (depth > maxDepth) {
13140
+ throw new AxiosError("Object is too deeply nested (" + depth + " levels). Max depth: " + maxDepth, AxiosError.ERR_FORM_DATA_DEPTH_EXCEEDED);
13141
+ }
13132
13142
  if (stack.indexOf(value) !== -1) {
13133
13143
  throw Error("Circular reference detected in " + path.join("."));
13134
13144
  }
@@ -13136,7 +13146,7 @@ var require_axios = __commonJS({
13136
13146
  utils$1.forEach(value, function each(el, key) {
13137
13147
  const result = !(utils$1.isUndefined(el) || el === null) && visitor.call(formData, el, utils$1.isString(key) ? key.trim() : key, path, exposedHelpers);
13138
13148
  if (result === true) {
13139
- build(el, path ? path.concat(key) : [key]);
13149
+ build(el, path ? path.concat(key) : [key], depth + 1);
13140
13150
  }
13141
13151
  });
13142
13152
  stack.pop();
@@ -13154,10 +13164,9 @@ var require_axios = __commonJS({
13154
13164
  "(": "%28",
13155
13165
  ")": "%29",
13156
13166
  "~": "%7E",
13157
- "%20": "+",
13158
- "%00": "\0"
13167
+ "%20": "+"
13159
13168
  };
13160
- return encodeURIComponent(str).replace(/[!'()~]|%20|%00/g, function replacer(match) {
13169
+ return encodeURIComponent(str).replace(/[!'()~]|%20/g, function replacer(match) {
13161
13170
  return charMap[match];
13162
13171
  });
13163
13172
  }
@@ -13361,7 +13370,7 @@ var require_axios = __commonJS({
13361
13370
  name = !name && utils$1.isArray(target) ? target.length : name;
13362
13371
  if (isLast) {
13363
13372
  if (utils$1.hasOwnProp(target, name)) {
13364
- target[name] = [target[name], value];
13373
+ target[name] = utils$1.isArray(target[name]) ? target[name].concat(value) : [target[name], value];
13365
13374
  } else {
13366
13375
  target[name] = value;
13367
13376
  }
@@ -13385,6 +13394,7 @@ var require_axios = __commonJS({
13385
13394
  }
13386
13395
  return null;
13387
13396
  }
13397
+ var own = (obj, key) => obj != null && utils$1.hasOwnProp(obj, key) ? obj[key] : void 0;
13388
13398
  function stringifySafely(rawValue, parser, encoder) {
13389
13399
  if (utils$1.isString(rawValue)) {
13390
13400
  try {
@@ -13424,14 +13434,16 @@ var require_axios = __commonJS({
13424
13434
  }
13425
13435
  let isFileList2;
13426
13436
  if (isObjectPayload) {
13437
+ const formSerializer = own(this, "formSerializer");
13427
13438
  if (contentType.indexOf("application/x-www-form-urlencoded") > -1) {
13428
- return toURLEncodedForm(data, this.formSerializer).toString();
13439
+ return toURLEncodedForm(data, formSerializer).toString();
13429
13440
  }
13430
13441
  if ((isFileList2 = utils$1.isFileList(data)) || contentType.indexOf("multipart/form-data") > -1) {
13431
- const _FormData = this.env && this.env.FormData;
13442
+ const env = own(this, "env");
13443
+ const _FormData = env && env.FormData;
13432
13444
  return toFormData(isFileList2 ? {
13433
13445
  "files[]": data
13434
- } : data, _FormData && new _FormData(), this.formSerializer);
13446
+ } : data, _FormData && new _FormData(), formSerializer);
13435
13447
  }
13436
13448
  }
13437
13449
  if (isObjectPayload || hasJSONContentType) {
@@ -13441,21 +13453,22 @@ var require_axios = __commonJS({
13441
13453
  return data;
13442
13454
  }],
13443
13455
  transformResponse: [function transformResponse(data) {
13444
- const transitional = this.transitional || defaults.transitional;
13456
+ const transitional = own(this, "transitional") || defaults.transitional;
13445
13457
  const forcedJSONParsing = transitional && transitional.forcedJSONParsing;
13446
- const JSONRequested = this.responseType === "json";
13458
+ const responseType = own(this, "responseType");
13459
+ const JSONRequested = responseType === "json";
13447
13460
  if (utils$1.isResponse(data) || utils$1.isReadableStream(data)) {
13448
13461
  return data;
13449
13462
  }
13450
- if (data && utils$1.isString(data) && (forcedJSONParsing && !this.responseType || JSONRequested)) {
13463
+ if (data && utils$1.isString(data) && (forcedJSONParsing && !responseType || JSONRequested)) {
13451
13464
  const silentJSONParsing = transitional && transitional.silentJSONParsing;
13452
13465
  const strictJSONParsing = !silentJSONParsing && JSONRequested;
13453
13466
  try {
13454
- return JSON.parse(data, this.parseReviver);
13467
+ return JSON.parse(data, own(this, "parseReviver"));
13455
13468
  } catch (e) {
13456
13469
  if (strictJSONParsing) {
13457
13470
  if (e.name === "SyntaxError") {
13458
- throw AxiosError.from(e, AxiosError.ERR_BAD_RESPONSE, this, null, this.response);
13471
+ throw AxiosError.from(e, AxiosError.ERR_BAD_RESPONSE, this, null, own(this, "response"));
13459
13472
  }
13460
13473
  throw e;
13461
13474
  }
@@ -13515,38 +13528,37 @@ var require_axios = __commonJS({
13515
13528
  return parsed;
13516
13529
  };
13517
13530
  var $internals = /* @__PURE__ */ Symbol("internals");
13518
- var isValidHeaderValue = (value) => !/[\r\n]/.test(value);
13519
- function assertValidHeaderValue(value, header) {
13520
- if (value === false || value == null) {
13521
- return;
13522
- }
13523
- if (utils$1.isArray(value)) {
13524
- value.forEach((v) => assertValidHeaderValue(v, header));
13525
- return;
13531
+ var INVALID_HEADER_VALUE_CHARS_RE = /[^\x09\x20-\x7E\x80-\xFF]/g;
13532
+ function trimSPorHTAB(str) {
13533
+ let start = 0;
13534
+ let end = str.length;
13535
+ while (start < end) {
13536
+ const code = str.charCodeAt(start);
13537
+ if (code !== 9 && code !== 32) {
13538
+ break;
13539
+ }
13540
+ start += 1;
13526
13541
  }
13527
- if (!isValidHeaderValue(String(value))) {
13528
- throw new Error(`Invalid character in header content ["${header}"]`);
13542
+ while (end > start) {
13543
+ const code = str.charCodeAt(end - 1);
13544
+ if (code !== 9 && code !== 32) {
13545
+ break;
13546
+ }
13547
+ end -= 1;
13529
13548
  }
13549
+ return start === 0 && end === str.length ? str : str.slice(start, end);
13530
13550
  }
13531
13551
  function normalizeHeader(header) {
13532
13552
  return header && String(header).trim().toLowerCase();
13533
13553
  }
13534
- function stripTrailingCRLF(str) {
13535
- let end = str.length;
13536
- while (end > 0) {
13537
- const charCode = str.charCodeAt(end - 1);
13538
- if (charCode !== 10 && charCode !== 13) {
13539
- break;
13540
- }
13541
- end -= 1;
13542
- }
13543
- return end === str.length ? str : str.slice(0, end);
13554
+ function sanitizeHeaderValue(str) {
13555
+ return trimSPorHTAB(str.replace(INVALID_HEADER_VALUE_CHARS_RE, ""));
13544
13556
  }
13545
13557
  function normalizeValue(value) {
13546
13558
  if (value === false || value == null) {
13547
13559
  return value;
13548
13560
  }
13549
- return utils$1.isArray(value) ? value.map(normalizeValue) : stripTrailingCRLF(String(value));
13561
+ return utils$1.isArray(value) ? value.map(normalizeValue) : sanitizeHeaderValue(String(value));
13550
13562
  }
13551
13563
  function parseTokens(str) {
13552
13564
  const tokens = /* @__PURE__ */ Object.create(null);
@@ -13602,7 +13614,6 @@ var require_axios = __commonJS({
13602
13614
  }
13603
13615
  const key = utils$1.findKey(self2, lHeader);
13604
13616
  if (!key || self2[key] === void 0 || _rewrite === true || _rewrite === void 0 && self2[key] !== false) {
13605
- assertValidHeaderValue(_value, _header);
13606
13617
  self2[key || _header] = normalizeValue(_value);
13607
13618
  }
13608
13619
  }
@@ -13816,7 +13827,7 @@ var require_axios = __commonJS({
13816
13827
  }
13817
13828
  function buildFullPath(baseURL, requestedURL, allowAbsoluteUrls) {
13818
13829
  let isRelativeUrl = !isAbsoluteURL(requestedURL);
13819
- if (baseURL && (isRelativeUrl || allowAbsoluteUrls == false)) {
13830
+ if (baseURL && (isRelativeUrl || allowAbsoluteUrls === false)) {
13820
13831
  return combineURLs(baseURL, requestedURL);
13821
13832
  }
13822
13833
  return requestedURL;
@@ -13886,7 +13897,7 @@ var require_axios = __commonJS({
13886
13897
  function getEnv(key) {
13887
13898
  return process.env[key.toLowerCase()] || process.env[key.toUpperCase()] || "";
13888
13899
  }
13889
- var VERSION = "1.15.0";
13900
+ var VERSION = "1.15.1";
13890
13901
  function parseProtocol(url2) {
13891
13902
  const match = /^([-+\w]{1,25})(:?\/\/|:)/.exec(url2);
13892
13903
  return match && match[1] || "";
@@ -14060,7 +14071,8 @@ var require_axios = __commonJS({
14060
14071
  if (isStringValue) {
14061
14072
  value = textEncoder.encode(String(value).replace(/\r?\n|\r\n?/g, CRLF));
14062
14073
  } else {
14063
- headers += `Content-Type: ${value.type || "application/octet-stream"}${CRLF}`;
14074
+ const safeType = String(value.type || "application/octet-stream").replace(/[\r\n]/g, "");
14075
+ headers += `Content-Type: ${safeType}${CRLF}`;
14064
14076
  }
14065
14077
  this.headers = textEncoder.encode(headers + CRLF);
14066
14078
  this.contentLength = isStringValue ? value.byteLength : value.size;
@@ -14155,6 +14167,37 @@ var require_axios = __commonJS({
14155
14167
  }, cb);
14156
14168
  } : fn;
14157
14169
  };
14170
+ var LOOPBACK_HOSTNAMES = /* @__PURE__ */ new Set(["localhost"]);
14171
+ var isIPv4Loopback = (host) => {
14172
+ const parts = host.split(".");
14173
+ if (parts.length !== 4) return false;
14174
+ if (parts[0] !== "127") return false;
14175
+ return parts.every((p) => /^\d+$/.test(p) && Number(p) >= 0 && Number(p) <= 255);
14176
+ };
14177
+ var isIPv6Loopback = (host) => {
14178
+ if (host === "::1") return true;
14179
+ const v4MappedDotted = host.match(/^::ffff:(\d+\.\d+\.\d+\.\d+)$/i);
14180
+ if (v4MappedDotted) return isIPv4Loopback(v4MappedDotted[1]);
14181
+ const v4MappedHex = host.match(/^::ffff:([0-9a-f]{1,4}):([0-9a-f]{1,4})$/i);
14182
+ if (v4MappedHex) {
14183
+ const high = parseInt(v4MappedHex[1], 16);
14184
+ return high >= 32512 && high <= 32767;
14185
+ }
14186
+ const groups = host.split(":");
14187
+ if (groups.length === 8) {
14188
+ for (let i = 0; i < 7; i++) {
14189
+ if (!/^0+$/.test(groups[i])) return false;
14190
+ }
14191
+ return /^0*1$/.test(groups[7]);
14192
+ }
14193
+ return false;
14194
+ };
14195
+ var isLoopback = (host) => {
14196
+ if (!host) return false;
14197
+ if (LOOPBACK_HOSTNAMES.has(host)) return true;
14198
+ if (isIPv4Loopback(host)) return true;
14199
+ return isIPv6Loopback(host);
14200
+ };
14158
14201
  var DEFAULT_PORTS = {
14159
14202
  http: 80,
14160
14203
  https: 443,
@@ -14227,7 +14270,7 @@ var require_axios = __commonJS({
14227
14270
  if (entryHost.charAt(0) === ".") {
14228
14271
  return hostname.endsWith(entryHost);
14229
14272
  }
14230
- return hostname === entryHost;
14273
+ return hostname === entryHost || isLoopback(hostname) && isLoopback(entryHost);
14231
14274
  });
14232
14275
  }
14233
14276
  function speedometer(samplesCount, min) {
@@ -14299,19 +14342,19 @@ var require_axios = __commonJS({
14299
14342
  let bytesNotified = 0;
14300
14343
  const _speedometer = speedometer(50, 250);
14301
14344
  return throttle((e) => {
14302
- const loaded = e.loaded;
14345
+ const rawLoaded = e.loaded;
14303
14346
  const total = e.lengthComputable ? e.total : void 0;
14304
- const progressBytes = loaded - bytesNotified;
14347
+ const loaded = total != null ? Math.min(rawLoaded, total) : rawLoaded;
14348
+ const progressBytes = Math.max(0, loaded - bytesNotified);
14305
14349
  const rate = _speedometer(progressBytes);
14306
- const inRange = loaded <= total;
14307
- bytesNotified = loaded;
14350
+ bytesNotified = Math.max(bytesNotified, loaded);
14308
14351
  const data = {
14309
14352
  loaded,
14310
14353
  total,
14311
14354
  progress: total ? loaded / total : void 0,
14312
14355
  bytes: progressBytes,
14313
14356
  rate: rate ? rate : void 0,
14314
- estimated: rate && total && inRange ? (total - loaded) / rate : void 0,
14357
+ estimated: rate && total ? (total - loaded) / rate : void 0,
14315
14358
  event: e,
14316
14359
  lengthComputable: total != null,
14317
14360
  [isDownloadStream ? "download" : "upload"]: true
@@ -14592,17 +14635,15 @@ var require_axios = __commonJS({
14592
14635
  };
14593
14636
  var httpAdapter = isHttpAdapterSupported && function httpAdapter2(config) {
14594
14637
  return wrapAsync(async function dispatchHttpRequest(resolve, reject, onDone) {
14595
- let {
14596
- data,
14597
- lookup,
14598
- family,
14599
- httpVersion = 1,
14600
- http2Options
14601
- } = config;
14602
- const {
14603
- responseType,
14604
- responseEncoding
14605
- } = config;
14638
+ const own2 = (key) => utils$1.hasOwnProp(config, key) ? config[key] : void 0;
14639
+ let data = own2("data");
14640
+ let lookup = own2("lookup");
14641
+ let family = own2("family");
14642
+ let httpVersion = own2("httpVersion");
14643
+ if (httpVersion === void 0) httpVersion = 1;
14644
+ let http2Options = own2("http2Options");
14645
+ const responseType = own2("responseType");
14646
+ const responseEncoding = own2("responseEncoding");
14606
14647
  const method = config.method.toUpperCase();
14607
14648
  let isDone;
14608
14649
  let rejected = false;
@@ -14733,7 +14774,7 @@ var require_axios = __commonJS({
14733
14774
  tag: `axios-${VERSION}-boundary`,
14734
14775
  boundary: userBoundary && userBoundary[1] || void 0
14735
14776
  });
14736
- } else if (utils$1.isFormData(data) && utils$1.isFunction(data.getHeaders)) {
14777
+ } else if (utils$1.isFormData(data) && utils$1.isFunction(data.getHeaders) && data.getHeaders !== Object.prototype.getHeaders) {
14737
14778
  headers.set(data.getHeaders());
14738
14779
  if (!headers.hasContentLength()) {
14739
14780
  try {
@@ -14830,8 +14871,9 @@ var require_axios = __commonJS({
14830
14871
  if (isHttp2) {
14831
14872
  transport = http2Transport;
14832
14873
  } else {
14833
- if (config.transport) {
14834
- transport = config.transport;
14874
+ const configTransport = own2("transport");
14875
+ if (configTransport) {
14876
+ transport = configTransport;
14835
14877
  } else if (config.maxRedirects === 0) {
14836
14878
  transport = isHttpsRequest ? https : http;
14837
14879
  } else {
@@ -14899,6 +14941,23 @@ var require_axios = __commonJS({
14899
14941
  request: lastRequest
14900
14942
  };
14901
14943
  if (responseType === "stream") {
14944
+ if (config.maxContentLength > -1) {
14945
+ const limit = config.maxContentLength;
14946
+ const source = responseStream;
14947
+ async function* enforceMaxContentLength() {
14948
+ let totalResponseBytes = 0;
14949
+ for await (const chunk of source) {
14950
+ totalResponseBytes += chunk.length;
14951
+ if (totalResponseBytes > limit) {
14952
+ throw new AxiosError("maxContentLength size of " + limit + " exceeded", AxiosError.ERR_BAD_RESPONSE, config, lastRequest);
14953
+ }
14954
+ yield chunk;
14955
+ }
14956
+ }
14957
+ responseStream = stream.Readable.from(enforceMaxContentLength(), {
14958
+ objectMode: false
14959
+ });
14960
+ }
14902
14961
  response.data = responseStream;
14903
14962
  settle(resolve, reject, response);
14904
14963
  } else {
@@ -14960,6 +15019,17 @@ var require_axios = __commonJS({
14960
15019
  });
14961
15020
  req.on("socket", function handleRequestSocket(socket) {
14962
15021
  socket.setKeepAlive(true, 1e3 * 60);
15022
+ const removeSocketErrorListener = () => {
15023
+ socket.removeListener("error", handleRequestSocketError);
15024
+ };
15025
+ function handleRequestSocketError(err) {
15026
+ removeSocketErrorListener();
15027
+ if (!req.destroyed) {
15028
+ req.destroy(err);
15029
+ }
15030
+ }
15031
+ socket.on("error", handleRequestSocketError);
15032
+ req.once("close", removeSocketErrorListener);
14963
15033
  });
14964
15034
  if (config.timeout) {
14965
15035
  const timeout = parseInt(config.timeout, 10);
@@ -14994,7 +15064,24 @@ var require_axios = __commonJS({
14994
15064
  abort(new CanceledError("Request stream has been aborted", config, req));
14995
15065
  }
14996
15066
  });
14997
- data.pipe(req);
15067
+ let uploadStream = data;
15068
+ if (config.maxBodyLength > -1 && config.maxRedirects === 0) {
15069
+ const limit = config.maxBodyLength;
15070
+ let bytesSent = 0;
15071
+ uploadStream = stream.pipeline([data, new stream.Transform({
15072
+ transform(chunk, _enc, cb) {
15073
+ bytesSent += chunk.length;
15074
+ if (bytesSent > limit) {
15075
+ return cb(new AxiosError("Request body larger than maxBodyLength limit", AxiosError.ERR_BAD_REQUEST, config, req));
15076
+ }
15077
+ cb(null, chunk);
15078
+ }
15079
+ })], utils$1.noop);
15080
+ uploadStream.on("error", (err) => {
15081
+ if (!req.destroyed) req.destroy(err);
15082
+ });
15083
+ }
15084
+ uploadStream.pipe(req);
14998
15085
  } else {
14999
15086
  data && req.write(data);
15000
15087
  req.end();
@@ -15087,9 +15174,9 @@ var require_axios = __commonJS({
15087
15174
  }
15088
15175
  }
15089
15176
  function mergeDirectKeys(a, b, prop) {
15090
- if (prop in config2) {
15177
+ if (utils$1.hasOwnProp(config2, prop)) {
15091
15178
  return getMergedValue(a, b);
15092
- } else if (prop in config1) {
15179
+ } else if (utils$1.hasOwnProp(config1, prop)) {
15093
15180
  return getMergedValue(void 0, a);
15094
15181
  }
15095
15182
  }
@@ -15130,7 +15217,9 @@ var require_axios = __commonJS({
15130
15217
  }), function computeConfigValue(prop) {
15131
15218
  if (prop === "__proto__" || prop === "constructor" || prop === "prototype") return;
15132
15219
  const merge2 = utils$1.hasOwnProp(mergeMap, prop) ? mergeMap[prop] : mergeDeepProperties;
15133
- const configValue = merge2(config1[prop], config2[prop], prop);
15220
+ const a = utils$1.hasOwnProp(config1, prop) ? config1[prop] : void 0;
15221
+ const b = utils$1.hasOwnProp(config2, prop) ? config2[prop] : void 0;
15222
+ const configValue = merge2(a, b, prop);
15134
15223
  utils$1.isUndefined(configValue) && merge2 !== mergeDirectKeys || (config[prop] = configValue);
15135
15224
  });
15136
15225
  return config;
@@ -15164,8 +15253,11 @@ var require_axios = __commonJS({
15164
15253
  }
15165
15254
  }
15166
15255
  if (platform.hasStandardBrowserEnv) {
15167
- withXSRFToken && utils$1.isFunction(withXSRFToken) && (withXSRFToken = withXSRFToken(newConfig));
15168
- if (withXSRFToken || withXSRFToken !== false && isURLSameOrigin(newConfig.url)) {
15256
+ if (utils$1.isFunction(withXSRFToken)) {
15257
+ withXSRFToken = withXSRFToken(newConfig);
15258
+ }
15259
+ const shouldSendXSRF = withXSRFToken === true || withXSRFToken == null && isURLSameOrigin(newConfig.url);
15260
+ if (shouldSendXSRF) {
15169
15261
  const xsrfValue = xsrfHeaderName && xsrfCookieName && cookies.read(xsrfCookieName);
15170
15262
  if (xsrfValue) {
15171
15263
  headers.set(xsrfHeaderName, xsrfValue);
@@ -15458,16 +15550,18 @@ var require_axios = __commonJS({
15458
15550
  const encodeText = isFetchSupported && (typeof TextEncoder$1 === "function" ? /* @__PURE__ */ ((encoder) => (str) => encoder.encode(str))(new TextEncoder$1()) : async (str) => new Uint8Array(await new Request(str).arrayBuffer()));
15459
15551
  const supportsRequestStream = isRequestSupported && isReadableStreamSupported && test(() => {
15460
15552
  let duplexAccessed = false;
15461
- const body = new ReadableStream$1();
15462
- const hasContentType = new Request(platform.origin, {
15463
- body,
15553
+ const request = new Request(platform.origin, {
15554
+ body: new ReadableStream$1(),
15464
15555
  method: "POST",
15465
15556
  get duplex() {
15466
15557
  duplexAccessed = true;
15467
15558
  return "half";
15468
15559
  }
15469
- }).headers.has("Content-Type");
15470
- body.cancel();
15560
+ });
15561
+ const hasContentType = request.headers.has("Content-Type");
15562
+ if (request.body != null) {
15563
+ request.body.cancel();
15564
+ }
15471
15565
  return duplexAccessed && !hasContentType;
15472
15566
  });
15473
15567
  const supportsResponseStream = isResponseSupported && isReadableStreamSupported && test(() => utils$1.isReadableStream(new Response("").body));
@@ -15556,6 +15650,12 @@ var require_axios = __commonJS({
15556
15650
  withCredentials = withCredentials ? "include" : "omit";
15557
15651
  }
15558
15652
  const isCredentialsSupported = isRequestSupported && "credentials" in Request.prototype;
15653
+ if (utils$1.isFormData(data)) {
15654
+ const contentType = headers.getContentType();
15655
+ if (contentType && /^multipart\/form-data/i.test(contentType) && !/boundary=/i.test(contentType)) {
15656
+ headers.delete("content-type");
15657
+ }
15658
+ }
15559
15659
  const resolvedOptions = {
15560
15660
  ...fetchOptions,
15561
15661
  signal: composedSignal,
@@ -21885,6 +21985,9 @@ var CheckpointManager = class _CheckpointManager {
21885
21985
  });
21886
21986
  } else {
21887
21987
  this.notifyQueueCompletion();
21988
+ if (!this.terminationTimer) {
21989
+ this.checkAndTerminate();
21990
+ }
21888
21991
  }
21889
21992
  }
21890
21993
  }
@@ -22417,7 +22520,7 @@ var createDefaultLogger = (executionContext) => {
22417
22520
  return new DefaultLogger(executionContext);
22418
22521
  };
22419
22522
  var SDK_NAME = "@aws/durable-execution-sdk-js";
22420
- var SDK_VERSION = "1.1.0";
22523
+ var SDK_VERSION = "1.1.1";
22421
22524
  var defaultLambdaClient;
22422
22525
  var DurableExecutionApiClient = class {
22423
22526
  client;
@@ -22971,7 +23074,7 @@ mime-types/index.js:
22971
23074
  *)
22972
23075
 
22973
23076
  axios/dist/node/axios.cjs:
22974
- (*! Axios v1.15.0 Copyright (c) 2026 Matt Zabriskie and contributors *)
23077
+ (*! Axios v1.15.1 Copyright (c) 2026 Matt Zabriskie and contributors *)
22975
23078
 
22976
23079
  safe-buffer/index.js:
22977
23080
  (*! safe-buffer. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> *)
@@ -139,5 +139,5 @@ class EC2InstanceRunningScheduler extends constructs_1.Construct {
139
139
  }
140
140
  exports.EC2InstanceRunningScheduler = EC2InstanceRunningScheduler;
141
141
  _a = JSII_RTTI_SYMBOL_1;
142
- EC2InstanceRunningScheduler[_a] = { fqn: "aws-ec2-instance-running-scheduler.EC2InstanceRunningScheduler", version: "3.1.2" };
142
+ EC2InstanceRunningScheduler[_a] = { fqn: "aws-ec2-instance-running-scheduler.EC2InstanceRunningScheduler", version: "3.1.3" };
143
143
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ec2-instance-running-scheduler.js","sourceRoot":"","sources":["../../src/constructs/ec2-instance-running-scheduler.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, RemovalPolicy, TimeZone } from 'aws-cdk-lib';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as scheduler from 'aws-cdk-lib/aws-scheduler';\nimport * as targets from 'aws-cdk-lib/aws-scheduler-targets';\nimport { Secret } from 'aws-cdk-lib/aws-secretsmanager';\nimport { Construct } from 'constructs';\nimport { RunningSchedulerFunction } from '../funcs/running-scheduler-function';\n\n/**\n * Cron-style schedule configuration for start/stop actions.\n */\nexport interface Schedule {\n  /** Time zone for the schedule (e.g. ETC_UTC). */\n  readonly timezone: TimeZone;\n  /** Cron minute (0–59). */\n  readonly minute?: string;\n  /** Cron hour (0–23). */\n  readonly hour?: string;\n  /** Cron day of week (e.g. MON-FRI). */\n  readonly week?: string;\n}\n\n/**\n * Defines which EC2 instances are targeted by tag key and values.\n */\nexport interface TargetResource {\n  /** Tag key used to select instances (e.g. Schedule). */\n  readonly tagKey: string;\n  /** Tag values that match instances to include. */\n  readonly tagValues: string[];\n}\n\n/**\n * Secret identifiers required by the scheduler (e.g. Slack).\n */\nexport interface Secrets {\n  /** Name of the Secrets Manager secret containing Slack token and channel. */\n  readonly slackSecretName: string;\n}\n\n/**\n * Properties for creating an EC2 instance running scheduler.\n */\nexport interface EC2InstanceRunningSchedulerProps {\n  /** Tag-based targeting for EC2 instances to start/stop. */\n  readonly targetResource: TargetResource;\n  /** Whether EventBridge Scheduler rules are enabled. Defaults to true if omitted. */\n  readonly enableScheduling?: boolean;\n  /** Secrets (e.g. Slack) used for notifications. */\n  readonly secrets: Secrets;\n  /** Cron schedule for stopping instances. */\n  readonly stopSchedule?: Schedule;\n  /** Cron schedule for starting instances. */\n  readonly startSchedule?: Schedule;\n}\n\n/**\n * Provisions EventBridge Scheduler rules and a Durable Execution Lambda that start/stop tagged EC2 instances.\n *\n * Each schedule invokes the function with `Params` (`TagKey`, `TagValues`, `Mode`). The function uses\n * the Resource Groups Tagging API and EC2 APIs; Slack notifications use the secret named in {@link Secrets.slackSecretName}.\n */\nexport class EC2InstanceRunningScheduler extends Construct {\n  /**\n   * Defines IAM, logging, two cron schedules (start/stop), and the bundled running-scheduler Lambda (Node.js, Durable Execution).\n   *\n   * @param scope - Parent construct.\n   * @param id - Construct id.\n   * @param props - Target tags, optional cron overrides, Slack secret name, and schedule enable flag.\n   */\n  constructor(scope: Construct, id: string, props: EC2InstanceRunningSchedulerProps) {\n    super(scope, id);\n\n    const slackSecret = Secret.fromSecretNameV2(this, 'SlackSecret', props.secrets.slackSecretName);\n\n    // Durable Functions-based Running Scheduler (previous Step Functions logic implemented in Lambda).\n    // Durable Execution requires Node.js 22+.\n    const runningScheduleFunction = new RunningSchedulerFunction(this, 'RunningSchedulerFunction', {\n      description: 'Starts and stops tagged EC2 instances on EventBridge Scheduler schedules.',\n      architecture: lambda.Architecture.ARM_64,\n      timeout: Duration.minutes(15),\n      memorySize: 512,\n      retryAttempts: 2,\n      durableConfig: {\n        executionTimeout: Duration.hours(2),\n        retentionPeriod: Duration.days(1),\n      },\n      environment: {\n        SLACK_SECRET_NAME: props.secrets.slackSecretName,\n      },\n      paramsAndSecrets: lambda.ParamsAndSecretsLayerVersion.fromVersion(lambda.ParamsAndSecretsVersions.V1_0_103, {\n        cacheSize: 500,\n        logLevel: lambda.ParamsAndSecretsLogLevel.INFO,\n      }),\n      role: new iam.Role(this, 'RunningSchedulerFunctionRole', {\n        description: 'Allows the running scheduler to describe, start, and stop EC2 instances and read Slack secrets.',\n        assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'),\n        managedPolicies: [\n          iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicDurableExecutionRolePolicy'),\n        ],\n      }),\n      logGroup: new logs.LogGroup(this, 'RunningSchedulerFunctionLogGroup', {\n        retention: logs.RetentionDays.THREE_MONTHS,\n        removalPolicy: RemovalPolicy.DESTROY,\n      }),\n      loggingFormat: lambda.LoggingFormat.JSON,\n      systemLogLevelV2: lambda.SystemLogLevel.INFO,\n      applicationLogLevelV2: lambda.ApplicationLogLevel.INFO,\n    });\n    runningScheduleFunction.addToRolePolicy(new iam.PolicyStatement({\n      sid: 'GetResources',\n      effect: iam.Effect.ALLOW,\n      actions: [\n        'tag:GetResources',\n      ],\n      resources: ['*'],\n    }));\n    // EC2: describe instances and start/stop by instance id\n    runningScheduleFunction.addToRolePolicy(new iam.PolicyStatement({\n      sid: 'Ec2RunningControl',\n      effect: iam.Effect.ALLOW,\n      actions: [\n        'ec2:DescribeInstances',\n        'ec2:StartInstances',\n        'ec2:StopInstances',\n      ],\n      resources: ['*'],\n    }));\n    // Grant read access to the Slack secret\n    slackSecret.grantRead(runningScheduleFunction);\n\n    // See: https://docs.aws.amazon.com/lambda/latest/dg/durable-getting-started-iac.html\n    const runningScheduleFunctionAlias = runningScheduleFunction.addAlias('live');\n\n    // Whether schedules are enabled (default true unless explicitly disabled).\n    const scheduleEnabled: boolean = (() => {\n      if (props.enableScheduling === undefined || props.enableScheduling) {\n        return true;\n      } else {\n        return false;\n      }\n    })();\n\n    // Durable Functions: Lambda performs tag lookup and instance start/stop in a single run.\n    new scheduler.Schedule(this, 'RunningStartSchedule', {\n      description: 'running start schedule',\n      enabled: scheduleEnabled,\n      schedule: scheduler.ScheduleExpression.cron({\n        minute: props.startSchedule?.minute ?? '50',\n        hour: props.startSchedule?.hour ?? '7',\n        weekDay: props.startSchedule?.week ?? 'MON-FRI',\n        timeZone: props.startSchedule?.timezone ?? TimeZone.ETC_UTC,\n      }),\n      target: new targets.LambdaInvoke(runningScheduleFunctionAlias, {\n        input: scheduler.ScheduleTargetInput.fromObject({\n          Params: {\n            TagKey: props.targetResource.tagKey,\n            TagValues: props.targetResource.tagValues,\n            Mode: 'Start',\n          },\n        }),\n      }),\n    });\n\n    new scheduler.Schedule(this, 'RunningStopSchedule', {\n      description: 'running stop schedule',\n      enabled: scheduleEnabled,\n      schedule: scheduler.ScheduleExpression.cron({\n        minute: props.stopSchedule?.minute ?? '5',\n        hour: props.stopSchedule?.hour ?? '19',\n        weekDay: props.stopSchedule?.week ?? 'MON-FRI',\n        timeZone: props.stopSchedule?.timezone ?? TimeZone.ETC_UTC,\n      }),\n      target: new targets.LambdaInvoke(runningScheduleFunctionAlias, {\n        input: scheduler.ScheduleTargetInput.fromObject({\n          Params: {\n            TagKey: props.targetResource.tagKey,\n            TagValues: props.targetResource.tagValues,\n            Mode: 'Stop',\n          },\n        }),\n      }),\n    });\n  }\n}\n"]}
@@ -29,5 +29,5 @@ class EC2InstanceRunningScheduleStack extends aws_cdk_lib_1.Stack {
29
29
  }
30
30
  exports.EC2InstanceRunningScheduleStack = EC2InstanceRunningScheduleStack;
31
31
  _a = JSII_RTTI_SYMBOL_1;
32
- EC2InstanceRunningScheduleStack[_a] = { fqn: "aws-ec2-instance-running-scheduler.EC2InstanceRunningScheduleStack", version: "3.1.2" };
32
+ EC2InstanceRunningScheduleStack[_a] = { fqn: "aws-ec2-instance-running-scheduler.EC2InstanceRunningScheduleStack", version: "3.1.3" };
33
33
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWMyLWluc3RhbmNlLXJ1bm5pbmctc2NoZWR1bGUtc3RhY2suanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RhY2tzL2VjMi1pbnN0YW5jZS1ydW5uaW5nLXNjaGVkdWxlLXN0YWNrLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsNkNBQWdEO0FBRWhELGlHQUE4SDtBQWtCOUg7O0dBRUc7QUFDSCxNQUFhLCtCQUFnQyxTQUFRLG1CQUFLO0lBQ3hEOzs7Ozs7T0FNRztJQUNILFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBMkM7UUFDbkYsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFFeEIsSUFBSSw0REFBMkIsQ0FBQyxJQUFJLEVBQUUsNkJBQTZCLEVBQUU7WUFDbkUsY0FBYyxFQUFFLEtBQUssQ0FBQyxjQUFjO1lBQ3BDLGdCQUFnQixFQUFFLEtBQUssQ0FBQyxnQkFBZ0I7WUFDeEMsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPO1lBQ3RCLFlBQVksRUFBRSxLQUFLLENBQUMsWUFBWTtZQUNoQyxhQUFhLEVBQUUsS0FBSyxDQUFDLGFBQWE7U0FDbkMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUFsQkgsMEVBbUJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3RhY2ssIFN0YWNrUHJvcHMgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IEVDMkluc3RhbmNlUnVubmluZ1NjaGVkdWxlciwgVGFyZ2V0UmVzb3VyY2UsIFNlY3JldHMsIFNjaGVkdWxlIH0gZnJvbSAnLi4vY29uc3RydWN0cy9lYzItaW5zdGFuY2UtcnVubmluZy1zY2hlZHVsZXInO1xuXG4vKipcbiAqIFByb3BzIGZvciB0aGUgRUMyIGluc3RhbmNlIHJ1bm5pbmcgc2NoZWR1bGUgQ0RLIHN0YWNrLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEVDMkluc3RhbmNlUnVubmluZ1NjaGVkdWxlU3RhY2tQcm9wcyBleHRlbmRzIFN0YWNrUHJvcHMge1xuICAvKiogVGFnLWJhc2VkIHRhcmdldCByZXNvdXJjZSBmb3IgRUMyIGluc3RhbmNlcyB0byBzdGFydC9zdG9wLiAqL1xuICByZWFkb25seSB0YXJnZXRSZXNvdXJjZTogVGFyZ2V0UmVzb3VyY2U7XG4gIC8qKiBXaGV0aGVyIHNjaGVkdWxpbmcgaXMgZW5hYmxlZC4gRGVmYXVsdHMgdG8gdHJ1ZSBpZiBvbWl0dGVkLiAqL1xuICByZWFkb25seSBlbmFibGVTY2hlZHVsaW5nPzogYm9vbGVhbjtcbiAgLyoqIFNlY3JldHMgKGUuZy4gU2xhY2spIGZvciB0aGUgc2NoZWR1bGVyLiAqL1xuICByZWFkb25seSBzZWNyZXRzOiBTZWNyZXRzO1xuICAvKiogQ3JvbiBzY2hlZHVsZSBmb3Igc3RvcHBpbmcgaW5zdGFuY2VzLiAqL1xuICByZWFkb25seSBzdG9wU2NoZWR1bGU/OiBTY2hlZHVsZTtcbiAgLyoqIENyb24gc2NoZWR1bGUgZm9yIHN0YXJ0aW5nIGluc3RhbmNlcy4gKi9cbiAgcmVhZG9ubHkgc3RhcnRTY2hlZHVsZT86IFNjaGVkdWxlO1xufVxuXG4vKipcbiAqIENESyBTdGFjayB0aGF0IGRlcGxveXMgdGhlIEVDMiBpbnN0YW5jZSBydW5uaW5nIHNjaGVkdWxlciAoRXZlbnRCcmlkZ2UgU2NoZWR1bGVyICsgRHVyYWJsZSBMYW1iZGEpLlxuICovXG5leHBvcnQgY2xhc3MgRUMySW5zdGFuY2VSdW5uaW5nU2NoZWR1bGVTdGFjayBleHRlbmRzIFN0YWNrIHtcbiAgLyoqXG4gICAqIENyZWF0ZXMgdGhlIHN0YWNrIGFuZCB0aGUgRUMySW5zdGFuY2VSdW5uaW5nU2NoZWR1bGVyIGNvbnN0cnVjdC5cbiAgICpcbiAgICogQHBhcmFtIHNjb3BlIC0gUGFyZW50IGNvbnN0cnVjdC5cbiAgICogQHBhcmFtIGlkIC0gU3RhY2sgaWQuXG4gICAqIEBwYXJhbSBwcm9wcyAtIFN0YWNrIHByb3BzICh0YXJnZXQgcmVzb3VyY2UsIHNjaGVkdWxlcywgc2VjcmV0cykuXG4gICAqL1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogRUMySW5zdGFuY2VSdW5uaW5nU2NoZWR1bGVTdGFja1Byb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkLCBwcm9wcyk7XG5cbiAgICBuZXcgRUMySW5zdGFuY2VSdW5uaW5nU2NoZWR1bGVyKHRoaXMsICdFQzJJbnN0YW5jZVJ1bm5pbmdTY2hlZHVsZXInLCB7XG4gICAgICB0YXJnZXRSZXNvdXJjZTogcHJvcHMudGFyZ2V0UmVzb3VyY2UsXG4gICAgICBlbmFibGVTY2hlZHVsaW5nOiBwcm9wcy5lbmFibGVTY2hlZHVsaW5nLFxuICAgICAgc2VjcmV0czogcHJvcHMuc2VjcmV0cyxcbiAgICAgIHN0b3BTY2hlZHVsZTogcHJvcHMuc3RvcFNjaGVkdWxlLFxuICAgICAgc3RhcnRTY2hlZHVsZTogcHJvcHMuc3RhcnRTY2hlZHVsZSxcbiAgICB9KTtcbiAgfVxufSJdfQ==
package/package.json CHANGED
@@ -65,7 +65,7 @@
65
65
  "jsii-docgen": "^10.5.0",
66
66
  "jsii-pacmak": "^1.128.0",
67
67
  "jsii-rosetta": "5.9.x",
68
- "projen": "^0.99.48",
68
+ "projen": "^0.99.51",
69
69
  "safe-env-getter": "^0.2",
70
70
  "ts-jest": "^29.4.9",
71
71
  "ts-node": "^10.9.2",
@@ -100,7 +100,7 @@
100
100
  "publishConfig": {
101
101
  "access": "public"
102
102
  },
103
- "version": "3.1.2",
103
+ "version": "3.1.3",
104
104
  "jest": {
105
105
  "coverageProvider": "v8",
106
106
  "testMatch": [