cdk8s 2.2.11 → 2.2.15
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 +3 -3
- package/changelog.md +1 -1
- package/lib/api-object.d.ts +13 -48
- package/lib/api-object.js +12 -20
- package/lib/app.d.ts +12 -56
- package/lib/app.js +10 -19
- package/lib/chart.d.ts +3 -26
- package/lib/chart.js +3 -18
- package/lib/dependency.d.ts +3 -25
- package/lib/dependency.js +6 -28
- package/lib/duration.d.ts +16 -33
- package/lib/duration.js +16 -31
- package/lib/helm.d.ts +3 -18
- package/lib/helm.js +2 -7
- package/lib/include.d.ts +3 -15
- package/lib/include.js +4 -10
- package/lib/json-patch.d.ts +16 -45
- package/lib/json-patch.js +18 -47
- package/lib/lazy.d.ts +0 -15
- package/lib/lazy.js +2 -11
- package/lib/metadata.d.ts +21 -63
- package/lib/metadata.js +7 -21
- package/lib/names.d.ts +16 -26
- package/lib/names.js +18 -18
- package/lib/size.d.ts +4 -51
- package/lib/size.js +5 -31
- package/lib/testing.d.ts +2 -8
- package/lib/testing.js +4 -10
- package/lib/yaml.d.ts +9 -15
- package/lib/yaml.js +11 -17
- package/package.json +4 -4
- package/releasetag.txt +1 -1
- package/version.txt +1 -1
package/lib/duration.js
CHANGED
|
@@ -9,7 +9,6 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
|
9
9
|
* The amount can be specified either as a literal value (e.g: `10`) which
|
|
10
10
|
* cannot be negative.
|
|
11
11
|
*
|
|
12
|
-
* @stability stable
|
|
13
12
|
*/
|
|
14
13
|
class Duration {
|
|
15
14
|
constructor(amount, unit) {
|
|
@@ -20,62 +19,56 @@ class Duration {
|
|
|
20
19
|
this.unit = unit;
|
|
21
20
|
}
|
|
22
21
|
/**
|
|
23
|
-
* Create a Duration representing an amount of milliseconds
|
|
22
|
+
* Create a Duration representing an amount of milliseconds
|
|
24
23
|
*
|
|
25
24
|
* @param amount the amount of Milliseconds the `Duration` will represent.
|
|
26
25
|
* @returns a new `Duration` representing `amount` ms.
|
|
27
|
-
* @stability stable
|
|
28
26
|
*/
|
|
29
27
|
static millis(amount) {
|
|
30
28
|
return new Duration(amount, TimeUnit.Milliseconds);
|
|
31
29
|
}
|
|
32
30
|
/**
|
|
33
|
-
* Create a Duration representing an amount of seconds
|
|
31
|
+
* Create a Duration representing an amount of seconds
|
|
34
32
|
*
|
|
35
33
|
* @param amount the amount of Seconds the `Duration` will represent.
|
|
36
34
|
* @returns a new `Duration` representing `amount` Seconds.
|
|
37
|
-
* @stability stable
|
|
38
35
|
*/
|
|
39
36
|
static seconds(amount) {
|
|
40
37
|
return new Duration(amount, TimeUnit.Seconds);
|
|
41
38
|
}
|
|
42
39
|
/**
|
|
43
|
-
* Create a Duration representing an amount of minutes
|
|
40
|
+
* Create a Duration representing an amount of minutes
|
|
44
41
|
*
|
|
45
42
|
* @param amount the amount of Minutes the `Duration` will represent.
|
|
46
43
|
* @returns a new `Duration` representing `amount` Minutes.
|
|
47
|
-
* @stability stable
|
|
48
44
|
*/
|
|
49
45
|
static minutes(amount) {
|
|
50
46
|
return new Duration(amount, TimeUnit.Minutes);
|
|
51
47
|
}
|
|
52
48
|
/**
|
|
53
|
-
* Create a Duration representing an amount of hours
|
|
49
|
+
* Create a Duration representing an amount of hours
|
|
54
50
|
*
|
|
55
51
|
* @param amount the amount of Hours the `Duration` will represent.
|
|
56
52
|
* @returns a new `Duration` representing `amount` Hours.
|
|
57
|
-
* @stability stable
|
|
58
53
|
*/
|
|
59
54
|
static hours(amount) {
|
|
60
55
|
return new Duration(amount, TimeUnit.Hours);
|
|
61
56
|
}
|
|
62
57
|
/**
|
|
63
|
-
* Create a Duration representing an amount of days
|
|
58
|
+
* Create a Duration representing an amount of days
|
|
64
59
|
*
|
|
65
60
|
* @param amount the amount of Days the `Duration` will represent.
|
|
66
61
|
* @returns a new `Duration` representing `amount` Days.
|
|
67
|
-
* @stability stable
|
|
68
62
|
*/
|
|
69
63
|
static days(amount) {
|
|
70
64
|
return new Duration(amount, TimeUnit.Days);
|
|
71
65
|
}
|
|
72
66
|
/**
|
|
73
|
-
* Parse a period formatted according to the ISO 8601 standard
|
|
67
|
+
* Parse a period formatted according to the ISO 8601 standard
|
|
74
68
|
*
|
|
69
|
+
* @see https://www.iso.org/fr/standard/70907.html
|
|
75
70
|
* @param duration an ISO-formtted duration to be parsed.
|
|
76
71
|
* @returns the parsed `Duration`.
|
|
77
|
-
* @see https://www.iso.org/fr/standard/70907.html
|
|
78
|
-
* @stability stable
|
|
79
72
|
*/
|
|
80
73
|
static parse(duration) {
|
|
81
74
|
const matches = duration.match(/^PT(?:(\d+)D)?(?:(\d+)H)?(?:(\d+)M)?(?:(\d+)S)?$/);
|
|
@@ -98,56 +91,50 @@ class Duration {
|
|
|
98
91
|
}
|
|
99
92
|
}
|
|
100
93
|
/**
|
|
101
|
-
* Return the total number of milliseconds in this Duration
|
|
94
|
+
* Return the total number of milliseconds in this Duration
|
|
102
95
|
*
|
|
103
96
|
* @returns the value of this `Duration` expressed in Milliseconds.
|
|
104
|
-
* @stability stable
|
|
105
97
|
*/
|
|
106
98
|
toMilliseconds(opts = {}) {
|
|
107
99
|
return convert(this.amount, this.unit, TimeUnit.Milliseconds, opts);
|
|
108
100
|
}
|
|
109
101
|
/**
|
|
110
|
-
* Return the total number of seconds in this Duration
|
|
102
|
+
* Return the total number of seconds in this Duration
|
|
111
103
|
*
|
|
112
104
|
* @returns the value of this `Duration` expressed in Seconds.
|
|
113
|
-
* @stability stable
|
|
114
105
|
*/
|
|
115
106
|
toSeconds(opts = {}) {
|
|
116
107
|
return convert(this.amount, this.unit, TimeUnit.Seconds, opts);
|
|
117
108
|
}
|
|
118
109
|
/**
|
|
119
|
-
* Return the total number of minutes in this Duration
|
|
110
|
+
* Return the total number of minutes in this Duration
|
|
120
111
|
*
|
|
121
112
|
* @returns the value of this `Duration` expressed in Minutes.
|
|
122
|
-
* @stability stable
|
|
123
113
|
*/
|
|
124
114
|
toMinutes(opts = {}) {
|
|
125
115
|
return convert(this.amount, this.unit, TimeUnit.Minutes, opts);
|
|
126
116
|
}
|
|
127
117
|
/**
|
|
128
|
-
* Return the total number of hours in this Duration
|
|
118
|
+
* Return the total number of hours in this Duration
|
|
129
119
|
*
|
|
130
120
|
* @returns the value of this `Duration` expressed in Hours.
|
|
131
|
-
* @stability stable
|
|
132
121
|
*/
|
|
133
122
|
toHours(opts = {}) {
|
|
134
123
|
return convert(this.amount, this.unit, TimeUnit.Hours, opts);
|
|
135
124
|
}
|
|
136
125
|
/**
|
|
137
|
-
* Return the total number of days in this Duration
|
|
126
|
+
* Return the total number of days in this Duration
|
|
138
127
|
*
|
|
139
128
|
* @returns the value of this `Duration` expressed in Days.
|
|
140
|
-
* @stability stable
|
|
141
129
|
*/
|
|
142
130
|
toDays(opts = {}) {
|
|
143
131
|
return convert(this.amount, this.unit, TimeUnit.Days, opts);
|
|
144
132
|
}
|
|
145
133
|
/**
|
|
146
|
-
* Return an ISO 8601 representation of this period
|
|
134
|
+
* Return an ISO 8601 representation of this period
|
|
147
135
|
*
|
|
148
136
|
* @returns a string starting with 'PT' describing the period
|
|
149
137
|
* @see https://www.iso.org/fr/standard/70907.html
|
|
150
|
-
* @stability stable
|
|
151
138
|
*/
|
|
152
139
|
toIsoString() {
|
|
153
140
|
if (this.amount === 0) {
|
|
@@ -163,9 +150,7 @@ class Duration {
|
|
|
163
150
|
}
|
|
164
151
|
}
|
|
165
152
|
/**
|
|
166
|
-
* Turn this duration into a human-readable string
|
|
167
|
-
*
|
|
168
|
-
* @stability stable
|
|
153
|
+
* Turn this duration into a human-readable string
|
|
169
154
|
*/
|
|
170
155
|
toHumanString() {
|
|
171
156
|
if (this.amount === 0) {
|
|
@@ -207,7 +192,7 @@ class Duration {
|
|
|
207
192
|
}
|
|
208
193
|
exports.Duration = Duration;
|
|
209
194
|
_a = JSII_RTTI_SYMBOL_1;
|
|
210
|
-
Duration[_a] = { fqn: "cdk8s.Duration", version: "2.2.
|
|
195
|
+
Duration[_a] = { fqn: "cdk8s.Duration", version: "2.2.15" };
|
|
211
196
|
class TimeUnit {
|
|
212
197
|
constructor(label, inMillis) {
|
|
213
198
|
this.label = label;
|
|
@@ -236,4 +221,4 @@ function convert(amount, fromUnit, toUnit, { integral = true }) {
|
|
|
236
221
|
}
|
|
237
222
|
return value;
|
|
238
223
|
}
|
|
239
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"duration.js","sourceRoot":"","sources":["../src/duration.ts"],"names":[],"mappings":"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","sourcesContent":["                                                                                                                                               \nexport class Duration {\n                                                                                                                                                                                                                    \n  public static millis(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Milliseconds);\n  }\n\n                                                                                                                                                                                                               \n  public static seconds(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Seconds);\n  }\n\n                                                                                                                                                                                                               \n  public static minutes(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Minutes);\n  }\n\n                                                                                                                                                                                                         \n  public static hours(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Hours);\n  }\n\n                                                                                                                                                                                                      \n  public static days(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Days);\n  }\n\n                                                                                                                                                                                                                                       \n  public static parse(duration: string): Duration {\n    const matches = duration.match(/^PT(?:(\\d+)D)?(?:(\\d+)H)?(?:(\\d+)M)?(?:(\\d+)S)?$/);\n    if (!matches) {\n      throw new Error(`Not a valid ISO duration: ${duration}`);\n    }\n    const [, days, hours, minutes, seconds] = matches;\n    if (!days && !hours && !minutes && !seconds) {\n      throw new Error(`Not a valid ISO duration: ${duration}`);\n    }\n    return Duration.millis(\n      _toInt(seconds) * TimeUnit.Seconds.inMillis\n      + (_toInt(minutes) * TimeUnit.Minutes.inMillis)\n      + (_toInt(hours) * TimeUnit.Hours.inMillis)\n      + (_toInt(days) * TimeUnit.Days.inMillis),\n    );\n\n    function _toInt(str: string): number {\n      if (!str) { return 0; }\n      return Number(str);\n    }\n  }\n\n  private readonly amount: number;\n  private readonly unit: TimeUnit;\n\n  private constructor(amount: number, unit: TimeUnit) {\n    if (amount < 0) {\n      throw new Error(`Duration amounts cannot be negative. Received: ${amount}`);\n    }\n\n    this.amount = amount;\n    this.unit = unit;\n  }\n\n                                                                                                                                                    \n  public toMilliseconds(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Milliseconds, opts);\n  }\n\n                                                                                                                                          \n  public toSeconds(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Seconds, opts);\n  }\n\n                                                                                                                                          \n  public toMinutes(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Minutes, opts);\n  }\n\n                                                                                                                                      \n  public toHours(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Hours, opts);\n  }\n\n                                                                                                                                    \n  public toDays(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Days, opts);\n  }\n\n                                                                                                                                                                                           \n  public toIsoString(): string {\n    if (this.amount === 0) { return 'PT0S'; }\n    switch (this.unit) {\n      case TimeUnit.Seconds: return `PT${this.fractionDuration('S', 60, Duration.minutes)}`;\n      case TimeUnit.Minutes: return `PT${this.fractionDuration('M', 60, Duration.hours)}`;\n      case TimeUnit.Hours: return `PT${this.fractionDuration('H', 24, Duration.days)}`;\n      case TimeUnit.Days: return `PT${this.amount}D`;\n      default:\n        throw new Error(`Unexpected time unit: ${this.unit}`);\n    }\n  }\n\n                                                                \n  public toHumanString(): string {\n    if (this.amount === 0) { return fmtUnit(0, this.unit); }\n\n    let millis = convert(this.amount, this.unit, TimeUnit.Milliseconds, { integral: false });\n    const parts = new Array<string>();\n\n    for (const unit of [TimeUnit.Days, TimeUnit.Hours, TimeUnit.Hours, TimeUnit.Minutes, TimeUnit.Seconds]) {\n      const wholeCount = Math.floor(convert(millis, TimeUnit.Milliseconds, unit, { integral: false }));\n      if (wholeCount > 0) {\n        parts.push(fmtUnit(wholeCount, unit));\n        millis -= wholeCount * unit.inMillis;\n      }\n    }\n\n    // Remainder in millis\n    if (millis > 0) {\n      parts.push(fmtUnit(millis, TimeUnit.Milliseconds));\n    }\n\n    // 2 significant parts, that's totally enough for humans\n    return parts.slice(0, 2).join(' ');\n\n    function fmtUnit(amount: number, unit: TimeUnit) {\n      if (amount === 1) {\n        // All of the labels end in 's'\n        return `${amount} ${unit.label.substring(0, unit.label.length - 1)}`;\n      }\n      return `${amount} ${unit.label}`;\n    }\n  }\n\n  private fractionDuration(symbol: string, modulus: number, next: (amount: number) => Duration): string {\n    if (this.amount < modulus) {\n      return `${this.amount}${symbol}`;\n    }\n    const remainder = this.amount % modulus;\n    const quotient = next((this.amount - remainder) / modulus).toIsoString().slice(2);\n    return remainder > 0\n      ? `${quotient}${remainder}${symbol}`\n      : quotient;\n  }\n}\n\n                                                               \nexport interface TimeConversionOptions {\n                                                                                                                                                                     \n  readonly integral?: boolean;\n}\n\nclass TimeUnit {\n  public static readonly Milliseconds = new TimeUnit('millis', 1);\n  public static readonly Seconds = new TimeUnit('seconds', 1_000);\n  public static readonly Minutes = new TimeUnit('minutes', 60_000);\n  public static readonly Hours = new TimeUnit('hours', 3_600_000);\n  public static readonly Days = new TimeUnit('days', 86_400_000);\n\n  private constructor(public readonly label: string, public readonly inMillis: number) {\n    // MAX_SAFE_INTEGER is 2^53, so by representing our duration in millis (the lowest\n    // common unit) the highest duration we can represent is\n    // 2^53 / 86*10^6 ~= 104 * 10^6 days (about 100 million days).\n  }\n\n  public toString() {\n    return this.label;\n  }\n}\n\nfunction convert(amount: number, fromUnit: TimeUnit, toUnit: TimeUnit, { integral = true }: TimeConversionOptions) {\n  if (fromUnit.inMillis === toUnit.inMillis) { return amount; }\n  const multiplier = fromUnit.inMillis / toUnit.inMillis;\n\n  const value = amount * multiplier;\n  if (!Number.isInteger(value) && integral) {\n    throw new Error(`'${amount} ${fromUnit}' cannot be converted into a whole number of ${toUnit}.`);\n  }\n  return value;\n}"]}
|
|
224
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"duration.js","sourceRoot":"","sources":["../src/duration.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Represents a length of time.\n *\n * The amount can be specified either as a literal value (e.g: `10`) which\n * cannot be negative.\n *\n */\nexport class Duration {\n  /**\n   * Create a Duration representing an amount of milliseconds\n   *\n   * @param amount the amount of Milliseconds the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` ms.\n   */\n  public static millis(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Milliseconds);\n  }\n\n  /**\n   * Create a Duration representing an amount of seconds\n   *\n   * @param amount the amount of Seconds the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` Seconds.\n   */\n  public static seconds(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Seconds);\n  }\n\n  /**\n   * Create a Duration representing an amount of minutes\n   *\n   * @param amount the amount of Minutes the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` Minutes.\n   */\n  public static minutes(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Minutes);\n  }\n\n  /**\n   * Create a Duration representing an amount of hours\n   *\n   * @param amount the amount of Hours the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` Hours.\n   */\n  public static hours(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Hours);\n  }\n\n  /**\n   * Create a Duration representing an amount of days\n   *\n   * @param amount the amount of Days the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` Days.\n   */\n  public static days(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Days);\n  }\n\n  /**\n   * Parse a period formatted according to the ISO 8601 standard\n   *\n   * @see https://www.iso.org/fr/standard/70907.html\n   * @param duration an ISO-formtted duration to be parsed.\n   * @returns the parsed `Duration`.\n   */\n  public static parse(duration: string): Duration {\n    const matches = duration.match(/^PT(?:(\\d+)D)?(?:(\\d+)H)?(?:(\\d+)M)?(?:(\\d+)S)?$/);\n    if (!matches) {\n      throw new Error(`Not a valid ISO duration: ${duration}`);\n    }\n    const [, days, hours, minutes, seconds] = matches;\n    if (!days && !hours && !minutes && !seconds) {\n      throw new Error(`Not a valid ISO duration: ${duration}`);\n    }\n    return Duration.millis(\n      _toInt(seconds) * TimeUnit.Seconds.inMillis\n      + (_toInt(minutes) * TimeUnit.Minutes.inMillis)\n      + (_toInt(hours) * TimeUnit.Hours.inMillis)\n      + (_toInt(days) * TimeUnit.Days.inMillis),\n    );\n\n    function _toInt(str: string): number {\n      if (!str) { return 0; }\n      return Number(str);\n    }\n  }\n\n  private readonly amount: number;\n  private readonly unit: TimeUnit;\n\n  private constructor(amount: number, unit: TimeUnit) {\n    if (amount < 0) {\n      throw new Error(`Duration amounts cannot be negative. Received: ${amount}`);\n    }\n\n    this.amount = amount;\n    this.unit = unit;\n  }\n\n  /**\n   * Return the total number of milliseconds in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Milliseconds.\n   */\n  public toMilliseconds(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Milliseconds, opts);\n  }\n\n  /**\n   * Return the total number of seconds in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Seconds.\n   */\n  public toSeconds(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Seconds, opts);\n  }\n\n  /**\n   * Return the total number of minutes in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Minutes.\n   */\n  public toMinutes(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Minutes, opts);\n  }\n\n  /**\n   * Return the total number of hours in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Hours.\n   */\n  public toHours(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Hours, opts);\n  }\n\n  /**\n   * Return the total number of days in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Days.\n   */\n  public toDays(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Days, opts);\n  }\n\n  /**\n   * Return an ISO 8601 representation of this period\n   *\n   * @returns a string starting with 'PT' describing the period\n   * @see https://www.iso.org/fr/standard/70907.html\n   */\n  public toIsoString(): string {\n    if (this.amount === 0) { return 'PT0S'; }\n    switch (this.unit) {\n      case TimeUnit.Seconds: return `PT${this.fractionDuration('S', 60, Duration.minutes)}`;\n      case TimeUnit.Minutes: return `PT${this.fractionDuration('M', 60, Duration.hours)}`;\n      case TimeUnit.Hours: return `PT${this.fractionDuration('H', 24, Duration.days)}`;\n      case TimeUnit.Days: return `PT${this.amount}D`;\n      default:\n        throw new Error(`Unexpected time unit: ${this.unit}`);\n    }\n  }\n\n  /**\n   * Turn this duration into a human-readable string\n   */\n  public toHumanString(): string {\n    if (this.amount === 0) { return fmtUnit(0, this.unit); }\n\n    let millis = convert(this.amount, this.unit, TimeUnit.Milliseconds, { integral: false });\n    const parts = new Array<string>();\n\n    for (const unit of [TimeUnit.Days, TimeUnit.Hours, TimeUnit.Hours, TimeUnit.Minutes, TimeUnit.Seconds]) {\n      const wholeCount = Math.floor(convert(millis, TimeUnit.Milliseconds, unit, { integral: false }));\n      if (wholeCount > 0) {\n        parts.push(fmtUnit(wholeCount, unit));\n        millis -= wholeCount * unit.inMillis;\n      }\n    }\n\n    // Remainder in millis\n    if (millis > 0) {\n      parts.push(fmtUnit(millis, TimeUnit.Milliseconds));\n    }\n\n    // 2 significant parts, that's totally enough for humans\n    return parts.slice(0, 2).join(' ');\n\n    function fmtUnit(amount: number, unit: TimeUnit) {\n      if (amount === 1) {\n        // All of the labels end in 's'\n        return `${amount} ${unit.label.substring(0, unit.label.length - 1)}`;\n      }\n      return `${amount} ${unit.label}`;\n    }\n  }\n\n  private fractionDuration(symbol: string, modulus: number, next: (amount: number) => Duration): string {\n    if (this.amount < modulus) {\n      return `${this.amount}${symbol}`;\n    }\n    const remainder = this.amount % modulus;\n    const quotient = next((this.amount - remainder) / modulus).toIsoString().slice(2);\n    return remainder > 0\n      ? `${quotient}${remainder}${symbol}`\n      : quotient;\n  }\n}\n\n/**\n * Options for how to convert time to a different unit.\n */\nexport interface TimeConversionOptions {\n  /**\n   * If `true`, conversions into a larger time unit (e.g. `Seconds` to `Minutes`) will fail if the result is not an\n   * integer.\n   *\n   * @default true\n   */\n  readonly integral?: boolean;\n}\n\nclass TimeUnit {\n  public static readonly Milliseconds = new TimeUnit('millis', 1);\n  public static readonly Seconds = new TimeUnit('seconds', 1_000);\n  public static readonly Minutes = new TimeUnit('minutes', 60_000);\n  public static readonly Hours = new TimeUnit('hours', 3_600_000);\n  public static readonly Days = new TimeUnit('days', 86_400_000);\n\n  private constructor(public readonly label: string, public readonly inMillis: number) {\n    // MAX_SAFE_INTEGER is 2^53, so by representing our duration in millis (the lowest\n    // common unit) the highest duration we can represent is\n    // 2^53 / 86*10^6 ~= 104 * 10^6 days (about 100 million days).\n  }\n\n  public toString() {\n    return this.label;\n  }\n}\n\nfunction convert(amount: number, fromUnit: TimeUnit, toUnit: TimeUnit, { integral = true }: TimeConversionOptions) {\n  if (fromUnit.inMillis === toUnit.inMillis) { return amount; }\n  const multiplier = fromUnit.inMillis / toUnit.inMillis;\n\n  const value = amount * multiplier;\n  if (!Number.isInteger(value) && integral) {\n    throw new Error(`'${amount} ${fromUnit}' cannot be converted into a whole number of ${toUnit}.`);\n  }\n  return value;\n}"]}
|
package/lib/helm.d.ts
CHANGED
|
@@ -2,8 +2,6 @@ import { Construct } from 'constructs';
|
|
|
2
2
|
import { Include } from './include';
|
|
3
3
|
/**
|
|
4
4
|
* Options for `Helm`.
|
|
5
|
-
*
|
|
6
|
-
* @stability stable
|
|
7
5
|
*/
|
|
8
6
|
export interface HelmProps {
|
|
9
7
|
/**
|
|
@@ -11,25 +9,21 @@ export interface HelmProps {
|
|
|
11
9
|
*
|
|
12
10
|
* This name is passed to `helm template` and has all the relevant semantics.
|
|
13
11
|
*
|
|
14
|
-
* @
|
|
15
|
-
* @example
|
|
16
|
-
*
|
|
17
|
-
* "bitnami/redis"
|
|
12
|
+
* @example "./mysql"
|
|
13
|
+
* @example "bitnami/redis"
|
|
18
14
|
*/
|
|
19
15
|
readonly chart: string;
|
|
20
16
|
/**
|
|
21
17
|
* The release name.
|
|
22
18
|
*
|
|
23
|
-
* @default - if unspecified, a name will be allocated based on the construct path
|
|
24
19
|
* @see https://helm.sh/docs/intro/using_helm/#three-big-concepts
|
|
25
|
-
* @
|
|
20
|
+
* @default - if unspecified, a name will be allocated based on the construct path
|
|
26
21
|
*/
|
|
27
22
|
readonly releaseName?: string;
|
|
28
23
|
/**
|
|
29
24
|
* Values to pass to the chart.
|
|
30
25
|
*
|
|
31
26
|
* @default - If no values are specified, chart will use the defaults.
|
|
32
|
-
* @stability stable
|
|
33
27
|
*/
|
|
34
28
|
readonly values?: {
|
|
35
29
|
[key: string]: any;
|
|
@@ -38,14 +32,12 @@ export interface HelmProps {
|
|
|
38
32
|
* The local helm executable to use in order to create the manifest the chart.
|
|
39
33
|
*
|
|
40
34
|
* @default "helm"
|
|
41
|
-
* @stability stable
|
|
42
35
|
*/
|
|
43
36
|
readonly helmExecutable?: string;
|
|
44
37
|
/**
|
|
45
38
|
* Additional flags to add to the `helm` execution.
|
|
46
39
|
*
|
|
47
40
|
* @default []
|
|
48
|
-
* @stability stable
|
|
49
41
|
*/
|
|
50
42
|
readonly helmFlags?: string[];
|
|
51
43
|
}
|
|
@@ -53,18 +45,11 @@ export interface HelmProps {
|
|
|
53
45
|
* Represents a Helm deployment.
|
|
54
46
|
*
|
|
55
47
|
* Use this construct to import an existing Helm chart and incorporate it into your constructs.
|
|
56
|
-
*
|
|
57
|
-
* @stability stable
|
|
58
48
|
*/
|
|
59
49
|
export declare class Helm extends Include {
|
|
60
50
|
/**
|
|
61
51
|
* The helm release name.
|
|
62
|
-
*
|
|
63
|
-
* @stability stable
|
|
64
52
|
*/
|
|
65
53
|
readonly releaseName: string;
|
|
66
|
-
/**
|
|
67
|
-
* @stability stable
|
|
68
|
-
*/
|
|
69
54
|
constructor(scope: Construct, id: string, props: HelmProps);
|
|
70
55
|
}
|
package/lib/helm.js
CHANGED
|
@@ -15,13 +15,8 @@ const MAX_HELM_BUFFER = 10 * 1024 * 1024;
|
|
|
15
15
|
* Represents a Helm deployment.
|
|
16
16
|
*
|
|
17
17
|
* Use this construct to import an existing Helm chart and incorporate it into your constructs.
|
|
18
|
-
*
|
|
19
|
-
* @stability stable
|
|
20
18
|
*/
|
|
21
19
|
class Helm extends include_1.Include {
|
|
22
|
-
/**
|
|
23
|
-
* @stability stable
|
|
24
|
-
*/
|
|
25
20
|
constructor(scope, id, props) {
|
|
26
21
|
var _b, _c;
|
|
27
22
|
const workdir = fs.mkdtempSync(path.join(os.tmpdir(), 'cdk8s-helm-'));
|
|
@@ -51,7 +46,7 @@ class Helm extends include_1.Include {
|
|
|
51
46
|
}
|
|
52
47
|
exports.Helm = Helm;
|
|
53
48
|
_a = JSII_RTTI_SYMBOL_1;
|
|
54
|
-
Helm[_a] = { fqn: "cdk8s.Helm", version: "2.2.
|
|
49
|
+
Helm[_a] = { fqn: "cdk8s.Helm", version: "2.2.15" };
|
|
55
50
|
function renderTemplate(workdir, prog, args) {
|
|
56
51
|
const helm = _child_process_1._child_process.spawnSync(prog, args, {
|
|
57
52
|
maxBuffer: MAX_HELM_BUFFER,
|
|
@@ -71,4 +66,4 @@ function renderTemplate(workdir, prog, args) {
|
|
|
71
66
|
fs.writeFileSync(outputFile, stdout);
|
|
72
67
|
return outputFile;
|
|
73
68
|
}
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVsbS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9oZWxtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEseUJBQXlCO0FBQ3pCLHlCQUF5QjtBQUN6Qiw2QkFBNkI7QUFFN0IsNkJBQTZCO0FBQzdCLHFEQUFrRDtBQUNsRCx1Q0FBb0M7QUFDcEMsbUNBQWdDO0FBRWhDLE1BQU0sZUFBZSxHQUFHLEVBQUUsR0FBRyxJQUFJLEdBQUcsSUFBSSxDQUFDO0FBOEN6Qzs7OztHQUlHO0FBQ0gsTUFBYSxJQUFLLFNBQVEsaUJBQU87SUFNL0IsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUFnQjs7UUFDeEQsTUFBTSxPQUFPLEdBQUcsRUFBRSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsRUFBRSxhQUFhLENBQUMsQ0FBQyxDQUFDO1FBRXRFLE1BQU0sSUFBSSxHQUFHLElBQUksS0FBSyxFQUFVLENBQUM7UUFDakMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUV0QixTQUFTO1FBQ1QsSUFBSSxLQUFLLENBQUMsTUFBTSxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7WUFDeEQsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztZQUN4RCxFQUFFLENBQUMsYUFBYSxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1lBQzNELElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1NBQzdCO1FBRUQsZUFBZTtRQUNmLElBQUksS0FBSyxDQUFDLFNBQVMsRUFBRTtZQUNuQixJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1NBQy9CO1FBRUQsZUFBZTtRQUNmLHdEQUF3RDtRQUN4RCxNQUFNLFdBQVcsU0FBRyxLQUFLLENBQUMsV0FBVyxtQ0FBSSxhQUFLLENBQUMsVUFBVSxDQUFDLEtBQUssRUFBRSxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzlGLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7UUFFdkIsUUFBUTtRQUNSLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRXZCLE1BQU0sSUFBSSxTQUFHLEtBQUssQ0FBQyxjQUFjLG1DQUFJLE1BQU0sQ0FBQztRQUM1QyxNQUFNLFVBQVUsR0FBRyxjQUFjLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztRQUV2RCxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRSxFQUFFLEdBQUcsRUFBRSxVQUFVLEVBQUUsQ0FBQyxDQUFDO1FBRXRDLElBQUksQ0FBQyxXQUFXLEdBQUcsV0FBVyxDQUFDO0lBQ2pDLENBQUM7O0FBdENILG9CQXVDQzs7O0FBRUQsU0FBUyxjQUFjLENBQUMsT0FBZSxFQUFFLElBQVksRUFBRSxJQUFjO0lBQ25FLE1BQU0sSUFBSSxHQUFHLCtCQUFjLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUU7UUFDaEQsU0FBUyxFQUFFLGVBQWU7S0FDM0IsQ0FBQyxDQUFDO0lBRUgsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO1FBQ2QsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUM7UUFDL0IsSUFBSSxHQUFHLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxFQUFFO1lBQzFCLE1BQU0sSUFBSSxLQUFLLENBQUMsc0JBQXNCLElBQUkseURBQXlELENBQUMsQ0FBQztTQUN0RztRQUVELE1BQU0sSUFBSSxLQUFLLENBQUMsdUNBQXVDLEdBQUcsRUFBRSxDQUFDLENBQUM7S0FDL0Q7SUFFRCxJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1FBQ3JCLE1BQU0sSUFBSSxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO0tBQ3pDO0lBRUQsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsWUFBWSxDQUFDLENBQUM7SUFDcEQsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUMzQixFQUFFLENBQUMsYUFBYSxDQUFDLFVBQVUsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNyQyxPQUFPLFVBQVUsQ0FBQztBQUNwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZnMgZnJvbSAnZnMnO1xuaW1wb3J0ICogYXMgb3MgZnJvbSAnb3MnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0ICogYXMgeWFtbCBmcm9tICd5YW1sJztcbmltcG9ydCB7IF9jaGlsZF9wcm9jZXNzIH0gZnJvbSAnLi9fY2hpbGRfcHJvY2Vzcyc7XG5pbXBvcnQgeyBJbmNsdWRlIH0gZnJvbSAnLi9pbmNsdWRlJztcbmltcG9ydCB7IE5hbWVzIH0gZnJvbSAnLi9uYW1lcyc7XG5cbmNvbnN0IE1BWF9IRUxNX0JVRkZFUiA9IDEwICogMTAyNCAqIDEwMjQ7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgYEhlbG1gLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEhlbG1Qcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgY2hhcnQgbmFtZSB0byB1c2UuIEl0IGNhbiBiZSBhIGNoYXJ0IGZyb20gYSBoZWxtIHJlcG9zaXRvcnkgb3IgYSBsb2NhbCBkaXJlY3RvcnkuXG4gICAqXG4gICAqIFRoaXMgbmFtZSBpcyBwYXNzZWQgdG8gYGhlbG0gdGVtcGxhdGVgIGFuZCBoYXMgYWxsIHRoZSByZWxldmFudCBzZW1hbnRpY3MuXG4gICAqXG4gICAqIEBleGFtcGxlIFwiLi9teXNxbFwiXG4gICAqIEBleGFtcGxlIFwiYml0bmFtaS9yZWRpc1wiXG4gICAqL1xuICByZWFkb25seSBjaGFydDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgcmVsZWFzZSBuYW1lLlxuICAgKlxuICAgKiBAc2VlIGh0dHBzOi8vaGVsbS5zaC9kb2NzL2ludHJvL3VzaW5nX2hlbG0vI3RocmVlLWJpZy1jb25jZXB0c1xuICAgKiBAZGVmYXVsdCAtIGlmIHVuc3BlY2lmaWVkLCBhIG5hbWUgd2lsbCBiZSBhbGxvY2F0ZWQgYmFzZWQgb24gdGhlIGNvbnN0cnVjdCBwYXRoXG4gICAqL1xuICByZWFkb25seSByZWxlYXNlTmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogVmFsdWVzIHRvIHBhc3MgdG8gdGhlIGNoYXJ0LlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIElmIG5vIHZhbHVlcyBhcmUgc3BlY2lmaWVkLCBjaGFydCB3aWxsIHVzZSB0aGUgZGVmYXVsdHMuXG4gICAqL1xuICByZWFkb25seSB2YWx1ZXM/OiB7IFtrZXk6IHN0cmluZ106IGFueSB9O1xuXG4gIC8qKlxuICAgKiBUaGUgbG9jYWwgaGVsbSBleGVjdXRhYmxlIHRvIHVzZSBpbiBvcmRlciB0byBjcmVhdGUgdGhlIG1hbmlmZXN0IHRoZSBjaGFydC5cbiAgICpcbiAgICogQGRlZmF1bHQgXCJoZWxtXCJcbiAgICovXG4gIHJlYWRvbmx5IGhlbG1FeGVjdXRhYmxlPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBBZGRpdGlvbmFsIGZsYWdzIHRvIGFkZCB0byB0aGUgYGhlbG1gIGV4ZWN1dGlvbi5cbiAgICpcbiAgICogQGRlZmF1bHQgW11cbiAgICovXG4gIHJlYWRvbmx5IGhlbG1GbGFncz86IHN0cmluZ1tdO1xufVxuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBIZWxtIGRlcGxveW1lbnQuXG4gKlxuICogVXNlIHRoaXMgY29uc3RydWN0IHRvIGltcG9ydCBhbiBleGlzdGluZyBIZWxtIGNoYXJ0IGFuZCBpbmNvcnBvcmF0ZSBpdCBpbnRvIHlvdXIgY29uc3RydWN0cy5cbiAqL1xuZXhwb3J0IGNsYXNzIEhlbG0gZXh0ZW5kcyBJbmNsdWRlIHtcbiAgLyoqXG4gICAqIFRoZSBoZWxtIHJlbGVhc2UgbmFtZS5cbiAgICovXG4gIHB1YmxpYyByZWFkb25seSByZWxlYXNlTmFtZTogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBIZWxtUHJvcHMpIHtcbiAgICBjb25zdCB3b3JrZGlyID0gZnMubWtkdGVtcFN5bmMocGF0aC5qb2luKG9zLnRtcGRpcigpLCAnY2RrOHMtaGVsbS0nKSk7XG5cbiAgICBjb25zdCBhcmdzID0gbmV3IEFycmF5PHN0cmluZz4oKTtcbiAgICBhcmdzLnB1c2goJ3RlbXBsYXRlJyk7XG5cbiAgICAvLyB2YWx1ZXNcbiAgICBpZiAocHJvcHMudmFsdWVzICYmIE9iamVjdC5rZXlzKHByb3BzLnZhbHVlcykubGVuZ3RoID4gMCkge1xuICAgICAgY29uc3QgdmFsdWVzUGF0aCA9IHBhdGguam9pbih3b3JrZGlyLCAnb3ZlcnJpZGVzLnlhbWwnKTtcbiAgICAgIGZzLndyaXRlRmlsZVN5bmModmFsdWVzUGF0aCwgeWFtbC5zdHJpbmdpZnkocHJvcHMudmFsdWVzKSk7XG4gICAgICBhcmdzLnB1c2goJy1mJywgdmFsdWVzUGF0aCk7XG4gICAgfVxuXG4gICAgLy8gY3VzdG9tIGZsYWdzXG4gICAgaWYgKHByb3BzLmhlbG1GbGFncykge1xuICAgICAgYXJncy5wdXNoKC4uLnByb3BzLmhlbG1GbGFncyk7XG4gICAgfVxuXG4gICAgLy8gcmVsZWFzZSBuYW1lXG4gICAgLy8gY29uc3RyYWludHM6IGh0dHBzOi8vZ2l0aHViLmNvbS9oZWxtL2hlbG0vaXNzdWVzLzYwMDZcbiAgICBjb25zdCByZWxlYXNlTmFtZSA9IHByb3BzLnJlbGVhc2VOYW1lID8/IE5hbWVzLnRvRG5zTGFiZWwoc2NvcGUsIHsgbWF4TGVuOiA1MywgZXh0cmE6IFtpZF0gfSk7XG4gICAgYXJncy5wdXNoKHJlbGVhc2VOYW1lKTtcblxuICAgIC8vIGNoYXJ0XG4gICAgYXJncy5wdXNoKHByb3BzLmNoYXJ0KTtcblxuICAgIGNvbnN0IHByb2cgPSBwcm9wcy5oZWxtRXhlY3V0YWJsZSA/PyAnaGVsbSc7XG4gICAgY29uc3Qgb3V0cHV0RmlsZSA9IHJlbmRlclRlbXBsYXRlKHdvcmtkaXIsIHByb2csIGFyZ3MpO1xuXG4gICAgc3VwZXIoc2NvcGUsIGlkLCB7IHVybDogb3V0cHV0RmlsZSB9KTtcblxuICAgIHRoaXMucmVsZWFzZU5hbWUgPSByZWxlYXNlTmFtZTtcbiAgfVxufVxuXG5mdW5jdGlvbiByZW5kZXJUZW1wbGF0ZSh3b3JrZGlyOiBzdHJpbmcsIHByb2c6IHN0cmluZywgYXJnczogc3RyaW5nW10pIHtcbiAgY29uc3QgaGVsbSA9IF9jaGlsZF9wcm9jZXNzLnNwYXduU3luYyhwcm9nLCBhcmdzLCB7XG4gICAgbWF4QnVmZmVyOiBNQVhfSEVMTV9CVUZGRVIsXG4gIH0pO1xuXG4gIGlmIChoZWxtLmVycm9yKSB7XG4gICAgY29uc3QgZXJyID0gaGVsbS5lcnJvci5tZXNzYWdlO1xuICAgIGlmIChlcnIuaW5jbHVkZXMoJ0VOT0VOVCcpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYHVuYWJsZSB0byBleGVjdXRlICcke3Byb2d9JyB0byByZW5kZXIgSGVsbSBjaGFydC4gSXMgaXQgaW5zdGFsbGVkIG9uIHlvdXIgc3lzdGVtP2ApO1xuICAgIH1cblxuICAgIHRocm93IG5ldyBFcnJvcihgZXJyb3Igd2hpbGUgcmVuZGVyaW5nIGEgaGVsbSBjaGFydDogJHtlcnJ9YCk7XG4gIH1cblxuICBpZiAoaGVsbS5zdGF0dXMgIT09IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoaGVsbS5zdGRlcnIudG9TdHJpbmcoKSk7XG4gIH1cblxuICBjb25zdCBvdXRwdXRGaWxlID0gcGF0aC5qb2luKHdvcmtkaXIsICdjaGFydC55YW1sJyk7XG4gIGNvbnN0IHN0ZG91dCA9IGhlbG0uc3Rkb3V0O1xuICBmcy53cml0ZUZpbGVTeW5jKG91dHB1dEZpbGUsIHN0ZG91dCk7XG4gIHJldHVybiBvdXRwdXRGaWxlO1xufVxuIl19
|
package/lib/include.d.ts
CHANGED
|
@@ -1,36 +1,24 @@
|
|
|
1
1
|
import { Construct } from 'constructs';
|
|
2
2
|
import { ApiObject } from './api-object';
|
|
3
|
-
/**
|
|
4
|
-
* @stability stable
|
|
5
|
-
*/
|
|
6
3
|
export interface IncludeProps {
|
|
7
4
|
/**
|
|
8
5
|
* Local file path or URL which includes a Kubernetes YAML manifest.
|
|
9
6
|
*
|
|
10
|
-
* @
|
|
11
|
-
* @example
|
|
12
|
-
*
|
|
13
|
-
* mymanifest.yaml
|
|
7
|
+
* @example mymanifest.yaml
|
|
14
8
|
*/
|
|
15
9
|
readonly url: string;
|
|
16
10
|
}
|
|
17
11
|
/**
|
|
18
|
-
* Reads a YAML manifest from a file or a URL and defines all resources as API
|
|
12
|
+
* Reads a YAML manifest from a file or a URL and defines all resources as API
|
|
13
|
+
* objects within the defined scope.
|
|
19
14
|
*
|
|
20
15
|
* The names (`metadata.name`) of imported resources will be preserved as-is
|
|
21
16
|
* from the manifest.
|
|
22
|
-
*
|
|
23
|
-
* @stability stable
|
|
24
17
|
*/
|
|
25
18
|
export declare class Include extends Construct {
|
|
26
|
-
/**
|
|
27
|
-
* @stability stable
|
|
28
|
-
*/
|
|
29
19
|
constructor(scope: Construct, id: string, props: IncludeProps);
|
|
30
20
|
/**
|
|
31
21
|
* Returns all the included API objects.
|
|
32
|
-
*
|
|
33
|
-
* @stability stable
|
|
34
22
|
*/
|
|
35
23
|
get apiObjects(): ApiObject[];
|
|
36
24
|
}
|
package/lib/include.js
CHANGED
|
@@ -7,17 +7,13 @@ const constructs_1 = require("constructs");
|
|
|
7
7
|
const api_object_1 = require("./api-object");
|
|
8
8
|
const yaml_1 = require("./yaml");
|
|
9
9
|
/**
|
|
10
|
-
* Reads a YAML manifest from a file or a URL and defines all resources as API
|
|
10
|
+
* Reads a YAML manifest from a file or a URL and defines all resources as API
|
|
11
|
+
* objects within the defined scope.
|
|
11
12
|
*
|
|
12
13
|
* The names (`metadata.name`) of imported resources will be preserved as-is
|
|
13
14
|
* from the manifest.
|
|
14
|
-
*
|
|
15
|
-
* @stability stable
|
|
16
15
|
*/
|
|
17
16
|
class Include extends constructs_1.Construct {
|
|
18
|
-
/**
|
|
19
|
-
* @stability stable
|
|
20
|
-
*/
|
|
21
17
|
constructor(scope, id, props) {
|
|
22
18
|
var _b, _c, _d, _e;
|
|
23
19
|
super(scope, id);
|
|
@@ -32,8 +28,6 @@ class Include extends constructs_1.Construct {
|
|
|
32
28
|
}
|
|
33
29
|
/**
|
|
34
30
|
* Returns all the included API objects.
|
|
35
|
-
*
|
|
36
|
-
* @stability stable
|
|
37
31
|
*/
|
|
38
32
|
get apiObjects() {
|
|
39
33
|
return constructs_1.Node.of(this).children.filter(o => o instanceof api_object_1.ApiObject);
|
|
@@ -41,5 +35,5 @@ class Include extends constructs_1.Construct {
|
|
|
41
35
|
}
|
|
42
36
|
exports.Include = Include;
|
|
43
37
|
_a = JSII_RTTI_SYMBOL_1;
|
|
44
|
-
Include[_a] = { fqn: "cdk8s.Include", version: "2.2.
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
Include[_a] = { fqn: "cdk8s.Include", version: "2.2.15" };
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5jbHVkZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmNsdWRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsMkNBQTZDO0FBQzdDLDZDQUF5QztBQUN6QyxpQ0FBOEI7QUFXOUI7Ozs7OztHQU1HO0FBQ0gsTUFBYSxPQUFRLFNBQVEsc0JBQVM7SUFDcEMsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUFtQjs7UUFDM0QsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixNQUFNLE9BQU8sR0FBRyxXQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUVyQyxJQUFJLEtBQUssR0FBRyxDQUFDLENBQUM7UUFDZCxLQUFLLE1BQU0sR0FBRyxJQUFJLE9BQU8sRUFBRTtZQUN6QixNQUFNLE9BQU8sZUFBRyxHQUFHLENBQUMsUUFBUSwwQ0FBRSxJQUFJLG1DQUFJLFNBQVMsS0FBSyxFQUFFLEVBQUUsQ0FBQztZQUV6RCx3Q0FBd0M7WUFDeEMsTUFBTSxLQUFLLEdBQUcsQ0FBQyxPQUFPLFFBQUUsR0FBRyxDQUFDLElBQUksMENBQUUsV0FBVyxVQUFJLEdBQUcsQ0FBQyxRQUFRLDBDQUFFLFNBQVMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNuRyxJQUFJLHNCQUFTLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRSxHQUFHLENBQUMsQ0FBQztTQUNqQztJQUNILENBQUM7SUFFRDs7T0FFRztJQUNILElBQVcsVUFBVTtRQUNuQixPQUFPLGlCQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLFlBQVksc0JBQVMsQ0FBZ0IsQ0FBQztJQUNuRixDQUFDOztBQXJCSCwwQkFzQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3QsIE5vZGUgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IEFwaU9iamVjdCB9IGZyb20gJy4vYXBpLW9iamVjdCc7XG5pbXBvcnQgeyBZYW1sIH0gZnJvbSAnLi95YW1sJztcblxuZXhwb3J0IGludGVyZmFjZSBJbmNsdWRlUHJvcHMge1xuICAvKipcbiAgICogTG9jYWwgZmlsZSBwYXRoIG9yIFVSTCB3aGljaCBpbmNsdWRlcyBhIEt1YmVybmV0ZXMgWUFNTCBtYW5pZmVzdC5cbiAgICpcbiAgICogQGV4YW1wbGUgbXltYW5pZmVzdC55YW1sXG4gICAqL1xuICByZWFkb25seSB1cmw6IHN0cmluZztcbn1cblxuLyoqXG4gKiBSZWFkcyBhIFlBTUwgbWFuaWZlc3QgZnJvbSBhIGZpbGUgb3IgYSBVUkwgYW5kIGRlZmluZXMgYWxsIHJlc291cmNlcyBhcyBBUElcbiAqIG9iamVjdHMgd2l0aGluIHRoZSBkZWZpbmVkIHNjb3BlLlxuICpcbiAqIFRoZSBuYW1lcyAoYG1ldGFkYXRhLm5hbWVgKSBvZiBpbXBvcnRlZCByZXNvdXJjZXMgd2lsbCBiZSBwcmVzZXJ2ZWQgYXMtaXNcbiAqIGZyb20gdGhlIG1hbmlmZXN0LlxuICovXG5leHBvcnQgY2xhc3MgSW5jbHVkZSBleHRlbmRzIENvbnN0cnVjdCB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBJbmNsdWRlUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgY29uc3Qgb2JqZWN0cyA9IFlhbWwubG9hZChwcm9wcy51cmwpO1xuXG4gICAgbGV0IG9yZGVyID0gMDtcbiAgICBmb3IgKGNvbnN0IG9iaiBvZiBvYmplY3RzKSB7XG4gICAgICBjb25zdCBvYmpuYW1lID0gb2JqLm1ldGFkYXRhPy5uYW1lID8/IGBvYmplY3Qke29yZGVyKyt9YDtcblxuICAgICAgLy8gcmVuZGVyIGFuIGlkOiBuYW1lWy1raW5kXVstbmFtZXNwYWNlXVxuICAgICAgY29uc3Qgb2JqaWQgPSBbb2JqbmFtZSwgb2JqLmtpbmQ/LnRvTG93ZXJDYXNlKCksIG9iai5tZXRhZGF0YT8ubmFtZXNwYWNlXS5maWx0ZXIoeCA9PiB4KS5qb2luKCctJyk7XG4gICAgICBuZXcgQXBpT2JqZWN0KHRoaXMsIG9iamlkLCBvYmopO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGFsbCB0aGUgaW5jbHVkZWQgQVBJIG9iamVjdHMuXG4gICAqL1xuICBwdWJsaWMgZ2V0IGFwaU9iamVjdHMoKTogQXBpT2JqZWN0W10ge1xuICAgIHJldHVybiBOb2RlLm9mKHRoaXMpLmNoaWxkcmVuLmZpbHRlcihvID0+IG8gaW5zdGFuY2VvZiBBcGlPYmplY3QpIGFzIEFwaU9iamVjdFtdO1xuICB9XG59XG4iXX0=
|
package/lib/json-patch.d.ts
CHANGED
|
@@ -7,91 +7,62 @@
|
|
|
7
7
|
* Operations can be created using the factory methods `JsonPatch.add()`,
|
|
8
8
|
* `JsonPatch.remove()`, etc.
|
|
9
9
|
*
|
|
10
|
-
* @stability stable
|
|
11
10
|
* @example
|
|
12
11
|
*
|
|
13
|
-
*
|
|
12
|
+
*const output = JsonPatch.apply(input,
|
|
14
13
|
* JsonPatch.replace('/world/hi/there', 'goodbye'),
|
|
15
14
|
* JsonPatch.add('/world/foo/', 'boom'),
|
|
16
15
|
* JsonPatch.remove('/hello'));
|
|
16
|
+
*
|
|
17
17
|
*/
|
|
18
18
|
export declare class JsonPatch {
|
|
19
19
|
private readonly operation;
|
|
20
20
|
/**
|
|
21
21
|
* Applies a set of JSON-Patch (RFC-6902) operations to `document` and returns the result.
|
|
22
|
-
*
|
|
23
|
-
* @param
|
|
24
|
-
* @param ops The operations to apply.
|
|
22
|
+
* @param document The document to patch
|
|
23
|
+
* @param ops The operations to apply
|
|
25
24
|
* @returns The result document
|
|
26
|
-
* @stability stable
|
|
27
25
|
*/
|
|
28
26
|
static apply(document: any, ...ops: JsonPatch[]): any;
|
|
29
27
|
/**
|
|
30
|
-
* Adds a value to an object or inserts it into an array.
|
|
31
|
-
*
|
|
32
|
-
* In the case of an
|
|
28
|
+
* Adds a value to an object or inserts it into an array. In the case of an
|
|
33
29
|
* array, the value is inserted before the given index. The - character can be
|
|
34
30
|
* used instead of an index to insert at the end of an array.
|
|
35
31
|
*
|
|
36
|
-
* @
|
|
37
|
-
* @example
|
|
38
|
-
*
|
|
39
|
-
* JsonPatch.add('/biscuits/1', { "name": "Ginger Nut" })
|
|
32
|
+
* @example JsonPatch.add('/biscuits/1', { "name": "Ginger Nut" })
|
|
40
33
|
*/
|
|
41
34
|
static add(path: string, value: any): JsonPatch;
|
|
42
35
|
/**
|
|
43
36
|
* Removes a value from an object or array.
|
|
44
37
|
*
|
|
45
|
-
* @
|
|
46
|
-
* @example
|
|
47
|
-
*
|
|
48
|
-
* JsonPatch.remove('/biscuits/0')
|
|
38
|
+
* @example JsonPatch.remove('/biscuits')
|
|
39
|
+
* @example JsonPatch.remove('/biscuits/0')
|
|
49
40
|
*/
|
|
50
41
|
static remove(path: string): JsonPatch;
|
|
51
42
|
/**
|
|
52
|
-
* Replaces a value.
|
|
53
|
-
*
|
|
54
|
-
* Equivalent to a “remove” followed by an “add”.
|
|
55
|
-
*
|
|
56
|
-
* @stability stable
|
|
57
|
-
* @example
|
|
43
|
+
* Replaces a value. Equivalent to a “remove” followed by an “add”.
|
|
58
44
|
*
|
|
59
|
-
* JsonPatch.replace('/biscuits/0/name', 'Chocolate Digestive')
|
|
45
|
+
* @example JsonPatch.replace('/biscuits/0/name', 'Chocolate Digestive')
|
|
60
46
|
*/
|
|
61
47
|
static replace(path: string, value: any): JsonPatch;
|
|
62
48
|
/**
|
|
63
|
-
* Copies a value from one location to another within the JSON document.
|
|
64
|
-
*
|
|
65
|
-
* Both
|
|
49
|
+
* Copies a value from one location to another within the JSON document. Both
|
|
66
50
|
* from and path are JSON Pointers.
|
|
67
51
|
*
|
|
68
|
-
* @
|
|
69
|
-
* @example
|
|
70
|
-
*
|
|
71
|
-
* JsonPatch.copy('/biscuits/0', '/best_biscuit')
|
|
52
|
+
* @example JsonPatch.copy('/biscuits/0', '/best_biscuit')
|
|
72
53
|
*/
|
|
73
54
|
static copy(from: string, path: string): JsonPatch;
|
|
74
55
|
/**
|
|
75
|
-
* Moves a value from one location to the other.
|
|
76
|
-
*
|
|
77
|
-
* Both from and path are JSON Pointers.
|
|
56
|
+
* Moves a value from one location to the other. Both from and path are JSON Pointers.
|
|
78
57
|
*
|
|
79
|
-
* @
|
|
80
|
-
* @example
|
|
81
|
-
*
|
|
82
|
-
* JsonPatch.move('/biscuits', '/cookies')
|
|
58
|
+
* @example JsonPatch.move('/biscuits', '/cookies')
|
|
83
59
|
*/
|
|
84
60
|
static move(from: string, path: string): JsonPatch;
|
|
85
61
|
/**
|
|
86
|
-
* Tests that the specified value is set in the document.
|
|
87
|
-
*
|
|
88
|
-
* If the test fails,
|
|
62
|
+
* Tests that the specified value is set in the document. If the test fails,
|
|
89
63
|
* then the patch as a whole should not apply.
|
|
90
64
|
*
|
|
91
|
-
* @
|
|
92
|
-
* @example
|
|
93
|
-
*
|
|
94
|
-
* JsonPatch.test('/best_biscuit/name', 'Choco Leibniz')
|
|
65
|
+
* @example JsonPatch.test('/best_biscuit/name', 'Choco Leibniz')
|
|
95
66
|
*/
|
|
96
67
|
static test(path: string, value: any): JsonPatch;
|
|
97
68
|
private constructor();
|