checkly 3.1.0 → 4.0.0

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.
Files changed (227) hide show
  1. package/README.md +42 -108
  2. package/bin/dev +17 -0
  3. package/bin/run +5 -0
  4. package/bin/run.cmd +3 -0
  5. package/constructs.d.ts +1 -0
  6. package/constructs.js +1 -0
  7. package/dist/auth/index.d.ts +15 -0
  8. package/dist/auth/index.js +228 -0
  9. package/dist/auth/index.js.map +1 -0
  10. package/dist/commands/authCommand.d.ts +5 -0
  11. package/dist/commands/authCommand.js +14 -0
  12. package/dist/commands/authCommand.js.map +1 -0
  13. package/dist/commands/baseCommand.d.ts +9 -0
  14. package/dist/commands/baseCommand.js +21 -0
  15. package/dist/commands/baseCommand.js.map +1 -0
  16. package/dist/commands/deploy.d.ts +13 -0
  17. package/dist/commands/deploy.js +171 -0
  18. package/dist/commands/deploy.js.map +1 -0
  19. package/dist/commands/destroy.d.ts +10 -0
  20. package/dist/commands/destroy.js +47 -0
  21. package/dist/commands/destroy.js.map +1 -0
  22. package/dist/commands/env/add.d.ts +13 -0
  23. package/dist/commands/env/add.js +54 -0
  24. package/dist/commands/env/add.js.map +1 -0
  25. package/dist/commands/env/ls.d.ts +6 -0
  26. package/dist/commands/env/ls.js +21 -0
  27. package/dist/commands/env/ls.js.map +1 -0
  28. package/dist/commands/env/pull.d.ts +12 -0
  29. package/dist/commands/env/pull.js +63 -0
  30. package/dist/commands/env/pull.js.map +1 -0
  31. package/dist/commands/env/rm.d.ts +12 -0
  32. package/dist/commands/env/rm.js +56 -0
  33. package/dist/commands/env/rm.js.map +1 -0
  34. package/dist/commands/env/update.d.ts +13 -0
  35. package/dist/commands/env/update.js +54 -0
  36. package/dist/commands/env/update.js.map +1 -0
  37. package/dist/commands/login.d.ts +13 -0
  38. package/dist/commands/login.js +129 -0
  39. package/dist/commands/login.js.map +1 -0
  40. package/dist/commands/logout.d.ts +9 -0
  41. package/dist/commands/logout.js +40 -0
  42. package/dist/commands/logout.js.map +1 -0
  43. package/dist/commands/runtimes.d.ts +6 -0
  44. package/dist/commands/runtimes.js +26 -0
  45. package/dist/commands/runtimes.js.map +1 -0
  46. package/dist/commands/switch.d.ts +9 -0
  47. package/dist/commands/switch.js +59 -0
  48. package/dist/commands/switch.js.map +1 -0
  49. package/dist/commands/test.d.ts +36 -0
  50. package/dist/commands/test.js +247 -0
  51. package/dist/commands/test.js.map +1 -0
  52. package/dist/commands/whoami.d.ts +6 -0
  53. package/dist/commands/whoami.js +16 -0
  54. package/dist/commands/whoami.js.map +1 -0
  55. package/dist/config.d.ts +31 -0
  56. package/dist/config.js +8 -0
  57. package/dist/config.js.map +1 -0
  58. package/dist/constructs/alert-channel-subscription.d.ts +44 -0
  59. package/dist/constructs/alert-channel-subscription.js +39 -0
  60. package/dist/constructs/alert-channel-subscription.js.map +1 -0
  61. package/dist/constructs/alert-channel.d.ts +53 -0
  62. package/dist/constructs/alert-channel.js +55 -0
  63. package/dist/constructs/alert-channel.js.map +1 -0
  64. package/dist/constructs/api-check.d.ts +179 -0
  65. package/dist/constructs/api-check.js +248 -0
  66. package/dist/constructs/api-check.js.map +1 -0
  67. package/dist/constructs/browser-check.d.ts +59 -0
  68. package/dist/constructs/browser-check.js +102 -0
  69. package/dist/constructs/browser-check.js.map +1 -0
  70. package/dist/constructs/check-group.d.ts +116 -0
  71. package/dist/constructs/check-group.js +113 -0
  72. package/dist/constructs/check-group.js.map +1 -0
  73. package/dist/constructs/check.d.ts +111 -0
  74. package/dist/constructs/check.js +88 -0
  75. package/dist/constructs/check.js.map +1 -0
  76. package/dist/constructs/construct.d.ts +17 -0
  77. package/dist/constructs/construct.js +22 -0
  78. package/dist/constructs/construct.js.map +1 -0
  79. package/dist/constructs/email-alert-channel.d.ts +26 -0
  80. package/dist/constructs/email-alert-channel.js +37 -0
  81. package/dist/constructs/email-alert-channel.js.map +1 -0
  82. package/dist/constructs/environment-variable.d.ts +2 -0
  83. package/dist/constructs/environment-variable.js +3 -0
  84. package/dist/constructs/environment-variable.js.map +1 -0
  85. package/dist/constructs/frequency.d.ts +20 -0
  86. package/dist/constructs/frequency.js +26 -0
  87. package/dist/constructs/frequency.js.map +1 -0
  88. package/dist/constructs/http-header.d.ts +2 -0
  89. package/dist/constructs/http-header.js +3 -0
  90. package/dist/constructs/http-header.js.map +1 -0
  91. package/dist/constructs/index.d.ts +15 -0
  92. package/dist/constructs/index.js +32 -0
  93. package/dist/constructs/index.js.map +1 -0
  94. package/dist/constructs/key-value-pair.d.ts +5 -0
  95. package/dist/constructs/key-value-pair.js +3 -0
  96. package/dist/constructs/key-value-pair.js.map +1 -0
  97. package/dist/constructs/opsgenie-alert-channel.d.ts +45 -0
  98. package/dist/constructs/opsgenie-alert-channel.js +44 -0
  99. package/dist/constructs/opsgenie-alert-channel.js.map +1 -0
  100. package/dist/constructs/pagerduty-alert-channel.d.ts +39 -0
  101. package/dist/constructs/pagerduty-alert-channel.js +42 -0
  102. package/dist/constructs/pagerduty-alert-channel.js.map +1 -0
  103. package/dist/constructs/project.d.ts +57 -0
  104. package/dist/constructs/project.js +100 -0
  105. package/dist/constructs/project.js.map +1 -0
  106. package/dist/constructs/query-param.d.ts +2 -0
  107. package/dist/constructs/query-param.js +3 -0
  108. package/dist/constructs/query-param.js.map +1 -0
  109. package/dist/constructs/ref.d.ts +5 -0
  110. package/dist/constructs/ref.js +13 -0
  111. package/dist/constructs/ref.js.map +1 -0
  112. package/dist/constructs/slack-alert-channel.d.ts +26 -0
  113. package/dist/constructs/slack-alert-channel.js +40 -0
  114. package/dist/constructs/slack-alert-channel.js.map +1 -0
  115. package/dist/constructs/sms-alert-channel.d.ts +27 -0
  116. package/dist/constructs/sms-alert-channel.js +38 -0
  117. package/dist/constructs/sms-alert-channel.js.map +1 -0
  118. package/dist/constructs/validator-error.d.ts +2 -0
  119. package/dist/constructs/validator-error.js +7 -0
  120. package/dist/constructs/validator-error.js.map +1 -0
  121. package/dist/constructs/webhook-alert-channel.d.ts +59 -0
  122. package/dist/constructs/webhook-alert-channel.js +50 -0
  123. package/dist/constructs/webhook-alert-channel.js.map +1 -0
  124. package/dist/help/examples.d.ts +6 -0
  125. package/dist/help/examples.js +22 -0
  126. package/dist/help/examples.js.map +1 -0
  127. package/dist/help/help-extension.d.ts +4 -0
  128. package/dist/help/help-extension.js +41 -0
  129. package/dist/help/help-extension.js.map +1 -0
  130. package/dist/index.d.ts +3 -0
  131. package/dist/index.js +7 -0
  132. package/dist/index.js.map +1 -0
  133. package/dist/messages/common-messages.d.ts +5 -0
  134. package/dist/messages/common-messages.js +9 -0
  135. package/dist/messages/common-messages.js.map +1 -0
  136. package/dist/reporters/abstract-list.d.ts +34 -0
  137. package/dist/reporters/abstract-list.js +122 -0
  138. package/dist/reporters/abstract-list.js.map +1 -0
  139. package/dist/reporters/ci.d.ts +12 -0
  140. package/dist/reporters/ci.js +29 -0
  141. package/dist/reporters/ci.js.map +1 -0
  142. package/dist/reporters/dot.d.ts +12 -0
  143. package/dist/reporters/dot.js +28 -0
  144. package/dist/reporters/dot.js.map +1 -0
  145. package/dist/reporters/github.d.ts +33 -0
  146. package/dist/reporters/github.js +93 -0
  147. package/dist/reporters/github.js.map +1 -0
  148. package/dist/reporters/list.d.ts +13 -0
  149. package/dist/reporters/list.js +57 -0
  150. package/dist/reporters/list.js.map +1 -0
  151. package/dist/reporters/reporter.d.ts +14 -0
  152. package/dist/reporters/reporter.js +23 -0
  153. package/dist/reporters/reporter.js.map +1 -0
  154. package/dist/reporters/util.d.ts +15 -0
  155. package/dist/reporters/util.js +283 -0
  156. package/dist/reporters/util.js.map +1 -0
  157. package/dist/rest/accounts.d.ts +12 -0
  158. package/dist/rest/accounts.js +15 -0
  159. package/dist/rest/accounts.js.map +1 -0
  160. package/dist/rest/api.d.ts +27 -0
  161. package/dist/rest/api.js +90 -0
  162. package/dist/rest/api.js.map +1 -0
  163. package/dist/rest/assets.d.ts +13 -0
  164. package/dist/rest/assets.js +30 -0
  165. package/dist/rest/assets.js.map +1 -0
  166. package/dist/rest/environment-variables.d.ts +16 -0
  167. package/dist/rest/environment-variables.js +25 -0
  168. package/dist/rest/environment-variables.js.map +1 -0
  169. package/dist/rest/locations.d.ts +11 -0
  170. package/dist/rest/locations.js +12 -0
  171. package/dist/rest/locations.js.map +1 -0
  172. package/dist/rest/private-locations.d.ts +11 -0
  173. package/dist/rest/private-locations.js +12 -0
  174. package/dist/rest/private-locations.js.map +1 -0
  175. package/dist/rest/projects.d.ts +43 -0
  176. package/dist/rest/projects.js +24 -0
  177. package/dist/rest/projects.js.map +1 -0
  178. package/dist/rest/runtimes.d.ts +15 -0
  179. package/dist/rest/runtimes.js +15 -0
  180. package/dist/rest/runtimes.js.map +1 -0
  181. package/dist/rest/test-sessions.d.ts +26 -0
  182. package/dist/rest/test-sessions.js +12 -0
  183. package/dist/rest/test-sessions.js.map +1 -0
  184. package/dist/rest/users.d.ts +12 -0
  185. package/dist/rest/users.js +12 -0
  186. package/dist/rest/users.js.map +1 -0
  187. package/dist/services/abstract-check-runner.d.ts +50 -0
  188. package/dist/services/abstract-check-runner.js +151 -0
  189. package/dist/services/abstract-check-runner.js.map +1 -0
  190. package/dist/services/check-parser/collector.d.ts +33 -0
  191. package/dist/services/check-parser/collector.js +48 -0
  192. package/dist/services/check-parser/collector.js.map +1 -0
  193. package/dist/services/check-parser/errors.d.ts +8 -0
  194. package/dist/services/check-parser/errors.js +45 -0
  195. package/dist/services/check-parser/errors.js.map +1 -0
  196. package/dist/services/check-parser/parser.d.ts +39 -0
  197. package/dist/services/check-parser/parser.js +296 -0
  198. package/dist/services/check-parser/parser.js.map +1 -0
  199. package/dist/services/checkly-config-loader.d.ts +54 -0
  200. package/dist/services/checkly-config-loader.js +55 -0
  201. package/dist/services/checkly-config-loader.js.map +1 -0
  202. package/dist/services/config.d.ts +24 -0
  203. package/dist/services/config.js +73 -0
  204. package/dist/services/config.js.map +1 -0
  205. package/dist/services/project-parser.d.ts +19 -0
  206. package/dist/services/project-parser.js +87 -0
  207. package/dist/services/project-parser.js.map +1 -0
  208. package/dist/services/socket-client.d.ts +4 -0
  209. package/dist/services/socket-client.js +20 -0
  210. package/dist/services/socket-client.js.map +1 -0
  211. package/dist/services/test-filters.d.ts +2 -0
  212. package/dist/services/test-filters.js +16 -0
  213. package/dist/services/test-filters.js.map +1 -0
  214. package/dist/services/test-runner.d.ts +21 -0
  215. package/dist/services/test-runner.js +50 -0
  216. package/dist/services/test-runner.js.map +1 -0
  217. package/dist/services/util.d.ts +29 -0
  218. package/dist/services/util.js +147 -0
  219. package/dist/services/util.js.map +1 -0
  220. package/dist/tsconfig.tsbuildinfo +1 -0
  221. package/oclif.manifest.json +423 -0
  222. package/package.json +163 -18
  223. package/LICENSE +0 -121
  224. package/dist/checkly.min.js +0 -1
  225. package/index.js +0 -285
  226. package/logo.png +0 -0
  227. package/test.js +0 -183
package/README.md CHANGED
@@ -1,108 +1,42 @@
1
- # Checkly
2
-
3
- ![checkly](https://i.imgur.com/29tOS0o.png)
4
-
5
- Truthy, falsey & equality checks simplified.
6
-
7
- * Checks for:
8
- * truthiness
9
- * falseyness
10
- * equality
11
- * Perks
12
- * built-in argument iteration support for `.t()` and `.f()`
13
- * built-in pairwise argument iteration support for `.eq()` and `ineq`
14
- * built-in pairwise argument iteration support for `.g()`, `.l()`, `.ge()` and `.le()`
15
- * uses fast-deep equal for `.eq()` and `ineq()`
16
- * `.can().be().chained()`
17
- * just call `.check()` at the end
18
- * Returns the `.pass()` or `.fail()` function / promise once you call `check()`
19
- * Instance Methods
20
- * `new Checkly()` - new checker instance
21
- * `.t(...a)` - argument(s) must be truthy
22
- * `.f(...a)` - argument(s) must be falsey
23
- * `.eq(...a)` - argument(s) must be equal
24
- * `.ineq(...a)` - argument(s) must be inequal
25
- * `.g(...a)` - leading args must be greater than the following args
26
- * `.l(...a)` - leading args must be less than the following args
27
- * `.ge(...a)` - leading args must be greater than or equal to the following args
28
- * `.le(...a)` - leading args must be less than or equal to the following args
29
- * `.err(...a)` - add error helper text
30
- * Stored in `errors` array
31
- * `.pass(fn)` - sets the function / promise to call and return if all checks passed
32
- * `.fail(fn)` - sets the function / promise to call and return if all checks failed
33
- * receives `errors` array as argument
34
- * `.check()` - runs the checks, returns the function / promise called.
35
-
36
- #### Changelog
37
-
38
- * v3.1
39
- * Cleaned up redundant methods
40
- * Added new static checkers
41
- * Added new instance-based checkers
42
- * Updated LICENSE
43
- * v2.1
44
- * `/dist/checkly.min.js` for browser
45
- * v2
46
- * Stricter checks
47
-
48
- #### Static checkers & transforms
49
- * Static checkers return `true` or `false`.
50
- * Static because they can be accessed from Checkly itself.
51
- * i.e. `Checkly.str()`
52
- * or destructure it, `var { str } = Checkly;`
53
- * Checkers list
54
- * `str(a)`
55
- * typeof a === "string"
56
- * `num(a)` - if it's a number
57
- * typeof a === "number"
58
- * isNan(a) === false
59
- * `obj(a)` - if it's an object
60
- * typeof a === "object"
61
- * Array.isArray(a) === false
62
- * a !== null
63
- * if a.__proto__, __proto__ !== Map.prototype;
64
- * if a.__proto__, __proto__ !== Set.prototype;
65
- * `arr(a)` - if it's an array
66
- * Array.isArray(a) === true
67
- * `und(a)` - if it's undefined
68
- * typeof a === "undefined"
69
- * `nul(a)` - if it's null
70
- * a === null;
71
- * `nan(a)` - if it's NaN
72
- * isNaN(a) === true
73
- * typeof a !== "function"
74
- * typeof a !== "object"
75
- * `map(a)` - if it's instance of Map
76
- * a.__proto__ === Map.prototype;
77
- * `set(a)` - if it's instance of Set
78
- * a.__proto__ === Set.prototype;
79
- * `fnc(a)` - if it's a function
80
- * typeof a === "function"
81
- * `emp(a)`
82
- * if Array.isArray(a), a.length === 0;
83
- * if typeof a === "object", a.__proto__ === Map.prototype, a !== null, a.size === 0;
84
- * if typeof a === "object", a.__proto__ === Set.prototype, a !== null, a.size === 0;
85
- * if typeof a === "object" && a !== null, Object.keys(a).length === 0;
86
- * if typeof a === "string", a === '';
87
- * `equal(a, b)`
88
- * complicated, see source.
89
- * `.g(a, b)`
90
- * a > b
91
- * `.l(a, b)`
92
- * a < b
93
- * `.ge(a, b)`
94
- * a >= b
95
- * `.le(a, b)`
96
- * a >= b
97
- * Transforms list
98
- * `ti(a)` - shortened parseInt, works with args
99
- * `tf(a)` - shortened parseFloat, works with args
100
- * `ts(a)` - shortened .toString()
101
- * returns undefined if arg is null / undefined
102
- * Notes:
103
- * Doesn't mutate args, instead we return the transformed args.
104
- * Looking to transform circular json's? check out `circular-json`@npm
105
-
106
- #### Tests
107
-
108
- * Run `test.js` to see all tests.
1
+ The Checkly CLI (now in beta) gives you a JavaScript/TypeScript-native **workflow** for coding, testing and deploying synthetic
2
+ monitoring at scale, from your code base. We call this workflow **monitoring as code** (MaC).
3
+
4
+ - **Unite E2E testing & monitoring in one workflow.** No more silos between Dev, QA and Ops.
5
+ - **Codeable, testable, reviewable.** Works with your dev pipeline. From your IDE, via PR to CI.
6
+ - **Native `@playwright/test` support.** No lock-in, just write standard `*.spec.ts` files.
7
+ - **Alerting baked in.** Set alerts for Slack, SMS and many more channels.
8
+ - **Typescript-first.** Fully typed for easy refactoring and code completion.
9
+ - **Run in the cloud or on-prem.** Run on the Checkly cloud or in your network using the [Private Locations](https://www.checklyhq.com/docs/private-locations/)
10
+
11
+
12
+ # Installation
13
+
14
+ First, make sure you sign up for a [free Checkly account](https://app.checklyhq.com/signup).
15
+
16
+ Then, the **easiest** way to get started is to install the CLI using the following command:
17
+
18
+ ```bash
19
+ npm create @checkly/cli
20
+ ```
21
+ This command will guide you through some simple steps and set up a fully working example project for you. Should take
22
+ ~1 minute.
23
+
24
+ You can also set up the CLI **from scratch** by running:
25
+
26
+ ```bash
27
+ npm install --save-dev @checkly/cli
28
+ ```
29
+
30
+ # Docs
31
+
32
+ Official docs are over at [checklyhq.com/docs/cli](https://checklyhq.com/docs/cli/)
33
+
34
+ ## Need help?
35
+
36
+ - Check out our [Getting Started Guide](https://checklyhq.com/docs/cli/)
37
+ - Join our [Slack Community](https://checklyhq.com/slack). The devs who built this hang out there.
38
+ - Found a bug? [File an issue on this repo](https://github.com/checkly/checkly-cli/issues/new/choose)
39
+
40
+ # Local Development
41
+
42
+ To get started with local development check [CONTRIBUTING.MD](https://github.com/checkly/checkly-cli/blob/main/CONTRIBUTING.md)
package/bin/dev ADDED
@@ -0,0 +1,17 @@
1
+ #!/usr/bin/env node
2
+
3
+ const oclif = require('@oclif/core')
4
+
5
+ const path = require('path')
6
+ const project = path.join(__dirname, '..', 'tsconfig.json')
7
+
8
+ // In dev mode -> use ts-node and dev plugins
9
+ process.env.NODE_ENV = 'development'
10
+
11
+ require('ts-node').register({project})
12
+
13
+ // In dev mode, always show stack traces
14
+ oclif.settings.debug = true;
15
+
16
+ // Start the CLI
17
+ oclif.run().then(oclif.flush).catch(oclif.Errors.handle)
package/bin/run ADDED
@@ -0,0 +1,5 @@
1
+ #!/usr/bin/env node
2
+
3
+ const oclif = require('@oclif/core')
4
+
5
+ oclif.run().then(require('@oclif/core/flush')).catch(require('@oclif/core/handle'))
package/bin/run.cmd ADDED
@@ -0,0 +1,3 @@
1
+ @echo off
2
+
3
+ node "%~dp0\run" %*
@@ -0,0 +1 @@
1
+ export * from './dist/constructs'
package/constructs.js ADDED
@@ -0,0 +1 @@
1
+ module.exports = require('./dist').constructs
@@ -0,0 +1,15 @@
1
+ export type AuthMode = 'signup' | 'login';
2
+ export declare function generatePKCE(): {
3
+ codeChallenge: string;
4
+ codeVerifier: string;
5
+ };
6
+ export declare class AuthContext {
7
+ #private;
8
+ private mode;
9
+ authenticationUrl: string;
10
+ constructor(mode: AuthMode);
11
+ getAuth0Credentials(): Promise<{
12
+ name: any;
13
+ key: any;
14
+ }>;
15
+ }
@@ -0,0 +1,228 @@
1
+ "use strict";
2
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
3
+ if (kind === "m") throw new TypeError("Private method is not writable");
4
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
5
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
6
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
7
+ };
8
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
9
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
10
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
11
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
12
+ };
13
+ var _AuthContext_instances, _AuthContext_codeChallenge, _AuthContext_codeVerifier, _AuthContext_accessToken, _AuthContext_idToken, _AuthContext_generateAuthenticationUrl, _AuthContext_startServer, _AuthContext_fetchAccessToken, _AuthContext_getApiKey, _AuthContext_fetchUser, _AuthContext_registerUser, _AuthContext_axiosInstance_get;
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.AuthContext = exports.generatePKCE = void 0;
16
+ const axios_1 = require("axios");
17
+ const os = require("os");
18
+ const http = require("http");
19
+ const crypto = require("crypto");
20
+ const jwt_decode_1 = require("jwt-decode");
21
+ const api_1 = require("../rest/api");
22
+ const fs = require("fs");
23
+ const path = require("path");
24
+ const AUTH0_CLIENT_ID = 'mBtwLFVm39GVZ1HpSRBSdRiLFucYxmMb';
25
+ const AUTH0_AUTHORIZATION_URL = 'https://auth.checklyhq.com/authorize';
26
+ const AUTH0_SCOPES = 'openid profile email';
27
+ const AUTH0_CALLBACK_URL = 'http://localhost:4242';
28
+ function generatePKCE() {
29
+ const codeVerifier = crypto
30
+ .randomBytes(64)
31
+ .toString('base64')
32
+ .replace(/\+/g, '-')
33
+ .replace(/\//g, '_')
34
+ .replace(/=+$/, '');
35
+ const codeChallenge = crypto
36
+ .createHash('sha256')
37
+ .update(codeVerifier)
38
+ .digest('base64')
39
+ .replace(/\+/g, '-')
40
+ .replace(/\//g, '_')
41
+ .replace(/=+$/, '');
42
+ return {
43
+ codeChallenge,
44
+ codeVerifier,
45
+ };
46
+ }
47
+ exports.generatePKCE = generatePKCE;
48
+ class AuthContext {
49
+ constructor(mode) {
50
+ this.mode = mode;
51
+ _AuthContext_instances.add(this);
52
+ _AuthContext_codeChallenge.set(this, void 0);
53
+ _AuthContext_codeVerifier.set(this, void 0);
54
+ _AuthContext_accessToken.set(this, void 0);
55
+ _AuthContext_idToken.set(this, void 0);
56
+ const { codeChallenge, codeVerifier } = generatePKCE();
57
+ __classPrivateFieldSet(this, _AuthContext_codeChallenge, codeChallenge, "f");
58
+ __classPrivateFieldSet(this, _AuthContext_codeVerifier, codeVerifier, "f");
59
+ this.authenticationUrl = __classPrivateFieldGet(this, _AuthContext_instances, "m", _AuthContext_generateAuthenticationUrl).call(this);
60
+ }
61
+ async getAuth0Credentials() {
62
+ await __classPrivateFieldGet(this, _AuthContext_instances, "m", _AuthContext_fetchAccessToken).call(this);
63
+ if (!__classPrivateFieldGet(this, _AuthContext_accessToken, "f") || !__classPrivateFieldGet(this, _AuthContext_idToken, "f")) {
64
+ throw new Error('There was an unexpected error retrieving Auth0 token. Please try again or contact ' +
65
+ 'support@checklyhq.com if this problem persists');
66
+ }
67
+ const { name } = (0, jwt_decode_1.default)(__classPrivateFieldGet(this, _AuthContext_idToken, "f"));
68
+ const { key } = await __classPrivateFieldGet(this, _AuthContext_instances, "m", _AuthContext_getApiKey).call(this);
69
+ return {
70
+ name,
71
+ key,
72
+ };
73
+ }
74
+ }
75
+ exports.AuthContext = AuthContext;
76
+ _AuthContext_codeChallenge = new WeakMap(), _AuthContext_codeVerifier = new WeakMap(), _AuthContext_accessToken = new WeakMap(), _AuthContext_idToken = new WeakMap(), _AuthContext_instances = new WeakSet(), _AuthContext_generateAuthenticationUrl = function _AuthContext_generateAuthenticationUrl() {
77
+ const url = new URL(AUTH0_AUTHORIZATION_URL);
78
+ const params = new URLSearchParams({
79
+ client_id: AUTH0_CLIENT_ID,
80
+ code_challenge: __classPrivateFieldGet(this, _AuthContext_codeChallenge, "f"),
81
+ code_challenge_method: 'S256',
82
+ response_type: 'code',
83
+ redirect_uri: AUTH0_CALLBACK_URL,
84
+ scope: AUTH0_SCOPES,
85
+ state: __classPrivateFieldGet(this, _AuthContext_codeVerifier, "f"),
86
+ mode: this.mode === 'signup' ? 'signUp' : '',
87
+ allowLogin: this.mode === 'signup' ? 'false' : 'true',
88
+ allowSignUp: this.mode === 'signup' ? 'true' : 'false',
89
+ });
90
+ url.search = params.toString();
91
+ return url.toString();
92
+ }, _AuthContext_startServer = function _AuthContext_startServer() {
93
+ return new Promise((resolve, reject) => {
94
+ const server = http.createServer();
95
+ server.on('request', (req, res) => {
96
+ var _a, _b, _c;
97
+ if ((_a = req.url) === null || _a === void 0 ? void 0 : _a.endsWith('.svg')) {
98
+ res.writeHead(200, { 'Content-Type': 'image/svg+xml' });
99
+ fs.readFile(path.join(__dirname, `.${req.url}`), 'utf8', (err, data) => {
100
+ if (!err)
101
+ res.end(data);
102
+ });
103
+ // `req.url` has a '/' char at the beginning which needs removed to be valid searchParams input
104
+ }
105
+ else if (!((_b = req.url) === null || _b === void 0 ? void 0 : _b.includes('favicon.ico'))) {
106
+ const responseParams = new URLSearchParams((_c = req.url) === null || _c === void 0 ? void 0 : _c.substring(1));
107
+ const code = responseParams.get('code');
108
+ const state = responseParams.get('state');
109
+ const error = responseParams.get('error');
110
+ const errorDescription = responseParams.get('error_description');
111
+ if (code && state === __classPrivateFieldGet(this, _AuthContext_codeVerifier, "f")) {
112
+ res.write(`
113
+ <html>
114
+ <style>
115
+ html {
116
+ font-family: Inter, system-ui, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, Arial, sans-serif;
117
+ font-size: 16px;
118
+ }
119
+ @keyframes slide-in-top {
120
+ 0% {
121
+ transform: translateY(-100px);
122
+ opacity: 0;
123
+ }
124
+ 100% {
125
+ transform: translateY(0);
126
+ opacity: 1;
127
+ }
128
+ }
129
+ .slide-in {
130
+ animation: slide-in-top 1s cubic-bezier(0.230, 1.000, 0.320, 1.000) both;
131
+ }
132
+ </style>
133
+ <body>
134
+ <div style="height:100%;width:100%;inset:0;position:absolute;display:grid;place-items:center;background-color:#EFF2F7;text-align:center;">
135
+ <div>
136
+ <img class="slide-in" style="width: 140px; height: 140px;" src=''/>
137
+ <h3 style="font-size: 28px; font-weight: 600; margin-bottom: 3rem; margin-top: .5rem;">Successfully logged in</h3>
138
+ <div style="font-weight: 500;">
139
+ <div style="margin-bottom: 1rem;">You can go back to your terminal.</div>
140
+ <div>This window should close itself in 3 seconds.</div>
141
+ </div>
142
+ </div>
143
+ </div>
144
+ <script>setTimeout(function() {window.close()}, 3000);</script>
145
+ </body>
146
+ </html>
147
+ `);
148
+ resolve(code);
149
+ }
150
+ else {
151
+ res.write(`
152
+ <html>
153
+ <body>
154
+ <div style="height:100%;width:100%;inset:0;position:absolute;display:grid;place-items:center;background-color:#EFF2F7;text-align:center;font-family:Inter;">
155
+ <h3 style="font-weight:200;">Login failed, please try again!</h3>
156
+ <p>
157
+ <b>${error}</b>: ${errorDescription}
158
+ </p>
159
+ </div>
160
+ </body>
161
+ </html>
162
+ `);
163
+ }
164
+ res.end();
165
+ }
166
+ });
167
+ server.listen(4242).on('error', (err) => {
168
+ if (err.code === 'EADDRINUSE') {
169
+ reject(new Error('Unable to start a local server on port 4242.' +
170
+ ' Please check that `checkly login` isn\'t already running in a separate tab.' +
171
+ ' On OS X and Linux, you can run `lsof -i :4242` to see which process is blocking the port.'));
172
+ }
173
+ else {
174
+ reject(err);
175
+ }
176
+ });
177
+ });
178
+ }, _AuthContext_fetchAccessToken = async function _AuthContext_fetchAccessToken() {
179
+ const code = await __classPrivateFieldGet(this, _AuthContext_instances, "m", _AuthContext_startServer).call(this);
180
+ const tokenParams = new URLSearchParams({
181
+ grant_type: 'authorization_code',
182
+ client_id: AUTH0_CLIENT_ID,
183
+ code_verifier: __classPrivateFieldGet(this, _AuthContext_codeVerifier, "f"),
184
+ code,
185
+ redirect_uri: AUTH0_CALLBACK_URL,
186
+ });
187
+ const tokenResponse = await axios_1.default.post('https://auth.checklyhq.com/oauth/token', tokenParams, {
188
+ headers: {
189
+ 'Content-Type': 'application/x-www-form-urlencoded',
190
+ 'Accept-Encoding': '*',
191
+ },
192
+ });
193
+ const { access_token: accessToken, id_token: idToken } = tokenResponse.data;
194
+ __classPrivateFieldSet(this, _AuthContext_accessToken, accessToken, "f");
195
+ __classPrivateFieldSet(this, _AuthContext_idToken, idToken, "f");
196
+ }, _AuthContext_getApiKey = async function _AuthContext_getApiKey() {
197
+ var _a;
198
+ try {
199
+ await __classPrivateFieldGet(this, _AuthContext_instances, "m", _AuthContext_fetchUser).call(this);
200
+ }
201
+ catch (error) {
202
+ if (((_a = error.response) === null || _a === void 0 ? void 0 : _a.status) === 401) {
203
+ await __classPrivateFieldGet(this, _AuthContext_instances, "m", _AuthContext_registerUser).call(this);
204
+ }
205
+ else {
206
+ throw error;
207
+ }
208
+ }
209
+ const apiKeyName = `CLI User Key (${os.hostname()})`;
210
+ const { data } = await __classPrivateFieldGet(this, _AuthContext_instances, "a", _AuthContext_axiosInstance_get).post(`/users/me/api-keys?name=${apiKeyName}`);
211
+ return data;
212
+ }, _AuthContext_fetchUser = async function _AuthContext_fetchUser() {
213
+ const { data } = await __classPrivateFieldGet(this, _AuthContext_instances, "a", _AuthContext_axiosInstance_get).get('/users/me');
214
+ return data;
215
+ }, _AuthContext_registerUser = async function _AuthContext_registerUser() {
216
+ const { data } = await __classPrivateFieldGet(this, _AuthContext_instances, "a", _AuthContext_axiosInstance_get).post('/users/', { accessToken: __classPrivateFieldGet(this, _AuthContext_accessToken, "f") });
217
+ return data;
218
+ }, _AuthContext_axiosInstance_get = function _AuthContext_axiosInstance_get() {
219
+ // Keep axios instance stateless
220
+ return axios_1.default.create({
221
+ baseURL: (0, api_1.getDefaults)().baseURL,
222
+ headers: {
223
+ Accept: 'application/json, text/plain, */*',
224
+ Authorization: `Bearer ${__classPrivateFieldGet(this, _AuthContext_accessToken, "f")}`,
225
+ },
226
+ });
227
+ };
228
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/auth/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,iCAA8C;AAC9C,yBAAwB;AACxB,6BAA4B;AAC5B,iCAAgC;AAChC,2CAAkC;AAClC,qCAA2D;AAC3D,yBAAwB;AACxB,6BAA4B;AAI5B,MAAM,eAAe,GAAG,kCAAkC,CAAA;AAC1D,MAAM,uBAAuB,GAAG,sCAAsC,CAAA;AACtE,MAAM,YAAY,GAAG,sBAAsB,CAAA;AAC3C,MAAM,kBAAkB,GAAG,uBAAuB,CAAA;AAElD,SAAgB,YAAY;IAC1B,MAAM,YAAY,GAAG,MAAM;SACxB,WAAW,CAAC,EAAE,CAAC;SACf,QAAQ,CAAC,QAAQ,CAAC;SAClB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;SACnB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;SACnB,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;IAErB,MAAM,aAAa,GAAG,MAAM;SACzB,UAAU,CAAC,QAAQ,CAAC;SACpB,MAAM,CAAC,YAAY,CAAC;SACpB,MAAM,CAAC,QAAQ,CAAC;SAChB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;SACnB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;SACnB,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;IAErB,OAAO;QACL,aAAa;QACb,YAAY;KACb,CAAA;AACH,CAAC;AApBD,oCAoBC;AAED,MAAa,WAAW;IAStB,YAAqB,IAAc;QAAd,SAAI,GAAJ,IAAI,CAAU;;QANnC,6CAAsB;QACtB,4CAAqB;QAErB,2CAAqB;QACrB,uCAAiB;QAGf,MAAM,EAAE,aAAa,EAAE,YAAY,EAAE,GAAG,YAAY,EAAE,CAAA;QACtD,uBAAA,IAAI,8BAAkB,aAAa,MAAA,CAAA;QACnC,uBAAA,IAAI,6BAAiB,YAAY,MAAA,CAAA;QAEjC,IAAI,CAAC,iBAAiB,GAAG,uBAAA,IAAI,sEAA2B,MAA/B,IAAI,CAA6B,CAAA;IAC5D,CAAC;IAED,KAAK,CAAC,mBAAmB;QACvB,MAAM,uBAAA,IAAI,6DAAkB,MAAtB,IAAI,CAAoB,CAAA;QAE9B,IAAI,CAAC,uBAAA,IAAI,gCAAa,IAAI,CAAC,uBAAA,IAAI,4BAAS,EAAE;YACxC,MAAM,IAAI,KAAK,CAAC,oFAAoF;gBAChG,gDAAgD,CAAC,CAAA;SACtD;QAED,MAAM,EAAE,IAAI,EAAE,GAAG,IAAA,oBAAS,EAAM,uBAAA,IAAI,4BAAS,CAAC,CAAA;QAE9C,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,uBAAA,IAAI,sDAAW,MAAf,IAAI,CAAa,CAAA;QAEvC,OAAO;YACL,IAAI;YACJ,GAAG;SACJ,CAAA;IACH,CAAC;CAmLF;AApND,kCAoNC;;IAhLG,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,uBAAuB,CAAC,CAAA;IAE5C,MAAM,MAAM,GAAG,IAAI,eAAe,CAAC;QACjC,SAAS,EAAE,eAAe;QAC1B,cAAc,EAAE,uBAAA,IAAI,kCAAe;QACnC,qBAAqB,EAAE,MAAM;QAC7B,aAAa,EAAE,MAAM;QACrB,YAAY,EAAE,kBAAkB;QAChC,KAAK,EAAE,YAAY;QACnB,KAAK,EAAE,uBAAA,IAAI,iCAAc;QACzB,IAAI,EAAE,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE;QAC5C,UAAU,EAAE,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;QACrD,WAAW,EAAE,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO;KACvD,CAAC,CAAA;IAEF,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAA;IAC9B,OAAO,GAAG,CAAC,QAAQ,EAAE,CAAA;AACvB,CAAC;IAGC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,EAAE,CAAA;QAClC,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;;YAChC,IAAI,MAAA,GAAG,CAAC,GAAG,0CAAE,QAAQ,CAAC,MAAM,CAAC,EAAE;gBAC7B,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,cAAc,EAAE,eAAe,EAAE,CAAC,CAAA;gBAEvD,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,GAAG,CAAC,GAAG,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;oBACrE,IAAI,CAAC,GAAG;wBAAE,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;gBACzB,CAAC,CAAC,CAAA;gBAEJ,+FAA+F;aAC9F;iBAAM,IAAI,CAAC,CAAA,MAAA,GAAG,CAAC,GAAG,0CAAE,QAAQ,CAAC,aAAa,CAAC,CAAA,EAAE;gBAC5C,MAAM,cAAc,GAAG,IAAI,eAAe,CAAC,MAAA,GAAG,CAAC,GAAG,0CAAE,SAAS,CAAC,CAAC,CAAC,CAAC,CAAA;gBACjE,MAAM,IAAI,GAAG,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;gBACvC,MAAM,KAAK,GAAG,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;gBAEzC,MAAM,KAAK,GAAG,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;gBACzC,MAAM,gBAAgB,GAAG,cAAc,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAA;gBAEhE,IAAI,IAAI,IAAI,KAAK,KAAK,uBAAA,IAAI,iCAAc,EAAE;oBACxC,GAAG,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAmCf,CAAC,CAAA;oBACI,OAAO,CAAC,IAAI,CAAC,CAAA;iBACd;qBAAM;oBACL,GAAG,CAAC,KAAK,CAAC;;;;;;mBAMH,KAAK,SAAS,gBAAgB;;;;;OAK1C,CAAC,CAAA;iBACG;gBAED,GAAG,CAAC,GAAG,EAAE,CAAA;aACV;QACH,CAAC,CAAC,CAAA;QAEF,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAQ,EAAE,EAAE;YAC3C,IAAI,GAAG,CAAC,IAAI,KAAK,YAAY,EAAE;gBAC7B,MAAM,CAAC,IAAI,KAAK,CAAC,8CAA8C;oBAC7D,8EAA8E;oBAC9E,4FAA4F,CAAC,CAAC,CAAA;aACjG;iBAAM;gBACL,MAAM,CAAC,GAAG,CAAC,CAAA;aACZ;QACH,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,kCAED,KAAK;IACH,MAAM,IAAI,GAAG,MAAM,uBAAA,IAAI,wDAAa,MAAjB,IAAI,CAAe,CAAA;IAEtC,MAAM,WAAW,GAAG,IAAI,eAAe,CAAC;QACtC,UAAU,EAAE,oBAAoB;QAChC,SAAS,EAAE,eAAe;QAC1B,aAAa,EAAE,uBAAA,IAAI,iCAAc;QACjC,IAAI;QACJ,YAAY,EAAE,kBAAkB;KACjC,CAAC,CAAA;IAEF,MAAM,aAAa,GAAG,MAAM,eAAK,CAAC,IAAI,CACpC,wCAAwC,EACxC,WAAW,EACX;QACE,OAAO,EAAE;YACP,cAAc,EAAE,mCAAmC;YACnD,iBAAiB,EAAE,GAAG;SACvB;KACF,CACF,CAAA;IAED,MAAM,EAAE,YAAY,EAAE,WAAW,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,aAAa,CAAC,IAAI,CAAA;IAE3E,uBAAA,IAAI,4BAAgB,WAAW,MAAA,CAAA;IAC/B,uBAAA,IAAI,wBAAY,OAAO,MAAA,CAAA;AACzB,CAAC,2BAED,KAAK;;IACH,IAAI;QACF,MAAM,uBAAA,IAAI,sDAAW,MAAf,IAAI,CAAa,CAAA;KACxB;IAAC,OAAO,KAAc,EAAE;QACvB,IAAI,CAAA,MAAC,KAAoB,CAAC,QAAQ,0CAAE,MAAM,MAAK,GAAG,EAAE;YAClD,MAAM,uBAAA,IAAI,yDAAc,MAAlB,IAAI,CAAgB,CAAA;SAC3B;aAAM;YACL,MAAM,KAAK,CAAA;SACZ;KACF;IAED,MAAM,UAAU,GAAG,iBAAiB,EAAE,CAAC,QAAQ,EAAE,GAAG,CAAA;IAEpD,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,uBAAA,IAAI,8DAAe,CAAC,IAAI,CAAC,2BAA2B,UAAU,EAAE,CAAC,CAAA;IAExF,OAAO,IAAI,CAAA;AACb,CAAC,2BAED,KAAK;IACH,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,uBAAA,IAAI,8DAAe,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;IAE3D,OAAO,IAAI,CAAA;AACb,CAAC,8BAED,KAAK;IACH,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,uBAAA,IAAI,8DAAe,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,WAAW,EAAE,uBAAA,IAAI,gCAAa,EAAE,CAAC,CAAA;IAE9F,OAAO,IAAI,CAAA;AACb,CAAC;IAGC,gCAAgC;IAChC,OAAO,eAAK,CAAC,MAAM,CAAC;QAClB,OAAO,EAAE,IAAA,iBAAc,GAAE,CAAC,OAAO;QACjC,OAAO,EAAE;YACP,MAAM,EAAE,mCAAmC;YAC3C,aAAa,EAAE,UAAU,uBAAA,IAAI,gCAAa,EAAE;SAC7C;KACF,CAAC,CAAA;AACJ,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { BaseCommand } from './baseCommand';
2
+ export declare abstract class AuthCommand extends BaseCommand {
3
+ static hidden: boolean;
4
+ protected init(): Promise<any>;
5
+ }
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AuthCommand = void 0;
4
+ const baseCommand_1 = require("./baseCommand");
5
+ const api = require("../rest/api");
6
+ class AuthCommand extends baseCommand_1.BaseCommand {
7
+ async init() {
8
+ super.init();
9
+ await api.validateAuthentication();
10
+ }
11
+ }
12
+ exports.AuthCommand = AuthCommand;
13
+ AuthCommand.hidden = true;
14
+ //# sourceMappingURL=authCommand.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"authCommand.js","sourceRoot":"","sources":["../../src/commands/authCommand.ts"],"names":[],"mappings":";;;AAAA,+CAA2C;AAC3C,mCAAkC;AAElC,MAAsB,WAAY,SAAQ,yBAAW;IAGzC,KAAK,CAAC,IAAI;QAClB,KAAK,CAAC,IAAI,EAAE,CAAA;QACZ,MAAM,GAAG,CAAC,sBAAsB,EAAE,CAAA;IACpC,CAAC;;AANH,kCAOC;AANQ,kBAAM,GAAG,IAAI,CAAA"}
@@ -0,0 +1,9 @@
1
+ import { Command } from '@oclif/core';
2
+ export declare abstract class BaseCommand extends Command {
3
+ static hidden: boolean;
4
+ protected init(): Promise<void>;
5
+ run(): Promise<void>;
6
+ protected catch(err: Error & {
7
+ exitCode?: number;
8
+ }): Promise<any>;
9
+ }
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BaseCommand = void 0;
4
+ const core_1 = require("@oclif/core");
5
+ const api_1 = require("../rest/api");
6
+ class BaseCommand extends core_1.Command {
7
+ init() {
8
+ api_1.api.defaults.headers['x-checkly-cli-version'] = this.config.version;
9
+ return super.init();
10
+ }
11
+ async run() {
12
+ await this.exit(0);
13
+ }
14
+ catch(err) {
15
+ // TODO: we can add Sentry here and log critical errors.
16
+ return super.catch(err);
17
+ }
18
+ }
19
+ exports.BaseCommand = BaseCommand;
20
+ BaseCommand.hidden = true;
21
+ //# sourceMappingURL=baseCommand.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"baseCommand.js","sourceRoot":"","sources":["../../src/commands/baseCommand.ts"],"names":[],"mappings":";;;AAAA,sCAAqC;AACrC,qCAAiC;AAEjC,MAAsB,WAAY,SAAQ,cAAO;IAGrC,IAAI;QACZ,SAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,uBAAuB,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAA;QACnE,OAAO,KAAK,CAAC,IAAI,EAAE,CAAA;IACrB,CAAC;IAED,KAAK,CAAC,GAAG;QACP,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACpB,CAAC;IAES,KAAK,CAAE,GAAgC;QAC/C,wDAAwD;QACxD,OAAO,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IACzB,CAAC;;AAfH,kCAgBC;AAfQ,kBAAM,GAAG,IAAI,CAAA"}
@@ -0,0 +1,13 @@
1
+ import { AuthCommand } from './authCommand';
2
+ export default class Deploy extends AuthCommand {
3
+ static hidden: boolean;
4
+ static description: string;
5
+ static flags: {
6
+ preview: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
7
+ output: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
8
+ force: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
9
+ config: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
10
+ };
11
+ run(): Promise<void>;
12
+ private formatPreview;
13
+ }