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.
- package/README.md +42 -108
- package/bin/dev +17 -0
- package/bin/run +5 -0
- package/bin/run.cmd +3 -0
- package/constructs.d.ts +1 -0
- package/constructs.js +1 -0
- package/dist/auth/index.d.ts +15 -0
- package/dist/auth/index.js +228 -0
- package/dist/auth/index.js.map +1 -0
- package/dist/commands/authCommand.d.ts +5 -0
- package/dist/commands/authCommand.js +14 -0
- package/dist/commands/authCommand.js.map +1 -0
- package/dist/commands/baseCommand.d.ts +9 -0
- package/dist/commands/baseCommand.js +21 -0
- package/dist/commands/baseCommand.js.map +1 -0
- package/dist/commands/deploy.d.ts +13 -0
- package/dist/commands/deploy.js +171 -0
- package/dist/commands/deploy.js.map +1 -0
- package/dist/commands/destroy.d.ts +10 -0
- package/dist/commands/destroy.js +47 -0
- package/dist/commands/destroy.js.map +1 -0
- package/dist/commands/env/add.d.ts +13 -0
- package/dist/commands/env/add.js +54 -0
- package/dist/commands/env/add.js.map +1 -0
- package/dist/commands/env/ls.d.ts +6 -0
- package/dist/commands/env/ls.js +21 -0
- package/dist/commands/env/ls.js.map +1 -0
- package/dist/commands/env/pull.d.ts +12 -0
- package/dist/commands/env/pull.js +63 -0
- package/dist/commands/env/pull.js.map +1 -0
- package/dist/commands/env/rm.d.ts +12 -0
- package/dist/commands/env/rm.js +56 -0
- package/dist/commands/env/rm.js.map +1 -0
- package/dist/commands/env/update.d.ts +13 -0
- package/dist/commands/env/update.js +54 -0
- package/dist/commands/env/update.js.map +1 -0
- package/dist/commands/login.d.ts +13 -0
- package/dist/commands/login.js +129 -0
- package/dist/commands/login.js.map +1 -0
- package/dist/commands/logout.d.ts +9 -0
- package/dist/commands/logout.js +40 -0
- package/dist/commands/logout.js.map +1 -0
- package/dist/commands/runtimes.d.ts +6 -0
- package/dist/commands/runtimes.js +26 -0
- package/dist/commands/runtimes.js.map +1 -0
- package/dist/commands/switch.d.ts +9 -0
- package/dist/commands/switch.js +59 -0
- package/dist/commands/switch.js.map +1 -0
- package/dist/commands/test.d.ts +36 -0
- package/dist/commands/test.js +247 -0
- package/dist/commands/test.js.map +1 -0
- package/dist/commands/whoami.d.ts +6 -0
- package/dist/commands/whoami.js +16 -0
- package/dist/commands/whoami.js.map +1 -0
- package/dist/config.d.ts +31 -0
- package/dist/config.js +8 -0
- package/dist/config.js.map +1 -0
- package/dist/constructs/alert-channel-subscription.d.ts +44 -0
- package/dist/constructs/alert-channel-subscription.js +39 -0
- package/dist/constructs/alert-channel-subscription.js.map +1 -0
- package/dist/constructs/alert-channel.d.ts +53 -0
- package/dist/constructs/alert-channel.js +55 -0
- package/dist/constructs/alert-channel.js.map +1 -0
- package/dist/constructs/api-check.d.ts +179 -0
- package/dist/constructs/api-check.js +248 -0
- package/dist/constructs/api-check.js.map +1 -0
- package/dist/constructs/browser-check.d.ts +59 -0
- package/dist/constructs/browser-check.js +102 -0
- package/dist/constructs/browser-check.js.map +1 -0
- package/dist/constructs/check-group.d.ts +116 -0
- package/dist/constructs/check-group.js +113 -0
- package/dist/constructs/check-group.js.map +1 -0
- package/dist/constructs/check.d.ts +111 -0
- package/dist/constructs/check.js +88 -0
- package/dist/constructs/check.js.map +1 -0
- package/dist/constructs/construct.d.ts +17 -0
- package/dist/constructs/construct.js +22 -0
- package/dist/constructs/construct.js.map +1 -0
- package/dist/constructs/email-alert-channel.d.ts +26 -0
- package/dist/constructs/email-alert-channel.js +37 -0
- package/dist/constructs/email-alert-channel.js.map +1 -0
- package/dist/constructs/environment-variable.d.ts +2 -0
- package/dist/constructs/environment-variable.js +3 -0
- package/dist/constructs/environment-variable.js.map +1 -0
- package/dist/constructs/frequency.d.ts +20 -0
- package/dist/constructs/frequency.js +26 -0
- package/dist/constructs/frequency.js.map +1 -0
- package/dist/constructs/http-header.d.ts +2 -0
- package/dist/constructs/http-header.js +3 -0
- package/dist/constructs/http-header.js.map +1 -0
- package/dist/constructs/index.d.ts +15 -0
- package/dist/constructs/index.js +32 -0
- package/dist/constructs/index.js.map +1 -0
- package/dist/constructs/key-value-pair.d.ts +5 -0
- package/dist/constructs/key-value-pair.js +3 -0
- package/dist/constructs/key-value-pair.js.map +1 -0
- package/dist/constructs/opsgenie-alert-channel.d.ts +45 -0
- package/dist/constructs/opsgenie-alert-channel.js +44 -0
- package/dist/constructs/opsgenie-alert-channel.js.map +1 -0
- package/dist/constructs/pagerduty-alert-channel.d.ts +39 -0
- package/dist/constructs/pagerduty-alert-channel.js +42 -0
- package/dist/constructs/pagerduty-alert-channel.js.map +1 -0
- package/dist/constructs/project.d.ts +57 -0
- package/dist/constructs/project.js +100 -0
- package/dist/constructs/project.js.map +1 -0
- package/dist/constructs/query-param.d.ts +2 -0
- package/dist/constructs/query-param.js +3 -0
- package/dist/constructs/query-param.js.map +1 -0
- package/dist/constructs/ref.d.ts +5 -0
- package/dist/constructs/ref.js +13 -0
- package/dist/constructs/ref.js.map +1 -0
- package/dist/constructs/slack-alert-channel.d.ts +26 -0
- package/dist/constructs/slack-alert-channel.js +40 -0
- package/dist/constructs/slack-alert-channel.js.map +1 -0
- package/dist/constructs/sms-alert-channel.d.ts +27 -0
- package/dist/constructs/sms-alert-channel.js +38 -0
- package/dist/constructs/sms-alert-channel.js.map +1 -0
- package/dist/constructs/validator-error.d.ts +2 -0
- package/dist/constructs/validator-error.js +7 -0
- package/dist/constructs/validator-error.js.map +1 -0
- package/dist/constructs/webhook-alert-channel.d.ts +59 -0
- package/dist/constructs/webhook-alert-channel.js +50 -0
- package/dist/constructs/webhook-alert-channel.js.map +1 -0
- package/dist/help/examples.d.ts +6 -0
- package/dist/help/examples.js +22 -0
- package/dist/help/examples.js.map +1 -0
- package/dist/help/help-extension.d.ts +4 -0
- package/dist/help/help-extension.js +41 -0
- package/dist/help/help-extension.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/messages/common-messages.d.ts +5 -0
- package/dist/messages/common-messages.js +9 -0
- package/dist/messages/common-messages.js.map +1 -0
- package/dist/reporters/abstract-list.d.ts +34 -0
- package/dist/reporters/abstract-list.js +122 -0
- package/dist/reporters/abstract-list.js.map +1 -0
- package/dist/reporters/ci.d.ts +12 -0
- package/dist/reporters/ci.js +29 -0
- package/dist/reporters/ci.js.map +1 -0
- package/dist/reporters/dot.d.ts +12 -0
- package/dist/reporters/dot.js +28 -0
- package/dist/reporters/dot.js.map +1 -0
- package/dist/reporters/github.d.ts +33 -0
- package/dist/reporters/github.js +93 -0
- package/dist/reporters/github.js.map +1 -0
- package/dist/reporters/list.d.ts +13 -0
- package/dist/reporters/list.js +57 -0
- package/dist/reporters/list.js.map +1 -0
- package/dist/reporters/reporter.d.ts +14 -0
- package/dist/reporters/reporter.js +23 -0
- package/dist/reporters/reporter.js.map +1 -0
- package/dist/reporters/util.d.ts +15 -0
- package/dist/reporters/util.js +283 -0
- package/dist/reporters/util.js.map +1 -0
- package/dist/rest/accounts.d.ts +12 -0
- package/dist/rest/accounts.js +15 -0
- package/dist/rest/accounts.js.map +1 -0
- package/dist/rest/api.d.ts +27 -0
- package/dist/rest/api.js +90 -0
- package/dist/rest/api.js.map +1 -0
- package/dist/rest/assets.d.ts +13 -0
- package/dist/rest/assets.js +30 -0
- package/dist/rest/assets.js.map +1 -0
- package/dist/rest/environment-variables.d.ts +16 -0
- package/dist/rest/environment-variables.js +25 -0
- package/dist/rest/environment-variables.js.map +1 -0
- package/dist/rest/locations.d.ts +11 -0
- package/dist/rest/locations.js +12 -0
- package/dist/rest/locations.js.map +1 -0
- package/dist/rest/private-locations.d.ts +11 -0
- package/dist/rest/private-locations.js +12 -0
- package/dist/rest/private-locations.js.map +1 -0
- package/dist/rest/projects.d.ts +43 -0
- package/dist/rest/projects.js +24 -0
- package/dist/rest/projects.js.map +1 -0
- package/dist/rest/runtimes.d.ts +15 -0
- package/dist/rest/runtimes.js +15 -0
- package/dist/rest/runtimes.js.map +1 -0
- package/dist/rest/test-sessions.d.ts +26 -0
- package/dist/rest/test-sessions.js +12 -0
- package/dist/rest/test-sessions.js.map +1 -0
- package/dist/rest/users.d.ts +12 -0
- package/dist/rest/users.js +12 -0
- package/dist/rest/users.js.map +1 -0
- package/dist/services/abstract-check-runner.d.ts +50 -0
- package/dist/services/abstract-check-runner.js +151 -0
- package/dist/services/abstract-check-runner.js.map +1 -0
- package/dist/services/check-parser/collector.d.ts +33 -0
- package/dist/services/check-parser/collector.js +48 -0
- package/dist/services/check-parser/collector.js.map +1 -0
- package/dist/services/check-parser/errors.d.ts +8 -0
- package/dist/services/check-parser/errors.js +45 -0
- package/dist/services/check-parser/errors.js.map +1 -0
- package/dist/services/check-parser/parser.d.ts +39 -0
- package/dist/services/check-parser/parser.js +296 -0
- package/dist/services/check-parser/parser.js.map +1 -0
- package/dist/services/checkly-config-loader.d.ts +54 -0
- package/dist/services/checkly-config-loader.js +55 -0
- package/dist/services/checkly-config-loader.js.map +1 -0
- package/dist/services/config.d.ts +24 -0
- package/dist/services/config.js +73 -0
- package/dist/services/config.js.map +1 -0
- package/dist/services/project-parser.d.ts +19 -0
- package/dist/services/project-parser.js +87 -0
- package/dist/services/project-parser.js.map +1 -0
- package/dist/services/socket-client.d.ts +4 -0
- package/dist/services/socket-client.js +20 -0
- package/dist/services/socket-client.js.map +1 -0
- package/dist/services/test-filters.d.ts +2 -0
- package/dist/services/test-filters.js +16 -0
- package/dist/services/test-filters.js.map +1 -0
- package/dist/services/test-runner.d.ts +21 -0
- package/dist/services/test-runner.js +50 -0
- package/dist/services/test-runner.js.map +1 -0
- package/dist/services/util.d.ts +29 -0
- package/dist/services/util.js +147 -0
- package/dist/services/util.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/oclif.manifest.json +423 -0
- package/package.json +163 -18
- package/LICENSE +0 -121
- package/dist/checkly.min.js +0 -1
- package/index.js +0 -285
- package/logo.png +0 -0
- package/test.js +0 -183
package/README.md
CHANGED
|
@@ -1,108 +1,42 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
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
package/bin/run.cmd
ADDED
package/constructs.d.ts
ADDED
|
@@ -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":"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"}
|
|
@@ -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,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
|
+
}
|