@gitpod/gitpod-protocol 0.1.5-to-code-reading.1 → 0.1.5-to-monitor-delete.18
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/data/gitpod-schema.json +124 -5
- package/lib/accounting-protocol.d.ts +18 -10
- package/lib/accounting-protocol.d.ts.map +1 -1
- package/lib/accounting-protocol.js +34 -32
- package/lib/accounting-protocol.js.map +1 -1
- package/lib/admin-protocol.d.ts +19 -0
- package/lib/admin-protocol.d.ts.map +1 -1
- package/lib/admin-protocol.js.map +1 -1
- package/lib/analytics.d.ts +4 -5
- package/lib/analytics.d.ts.map +1 -1
- package/lib/analytics.js.map +1 -1
- package/lib/attribution.d.ts +24 -0
- package/lib/attribution.d.ts.map +1 -0
- package/lib/attribution.js +54 -0
- package/lib/attribution.js.map +1 -0
- package/lib/auth.d.ts.map +1 -1
- package/lib/billing-mode.d.ts +45 -0
- package/lib/billing-mode.d.ts.map +1 -0
- package/lib/billing-mode.js +44 -0
- package/lib/billing-mode.js.map +1 -0
- package/lib/blocked-repositories-protocol.d.ts +13 -0
- package/lib/blocked-repositories-protocol.d.ts.map +1 -0
- package/lib/blocked-repositories-protocol.js +8 -0
- package/lib/blocked-repositories-protocol.js.map +1 -0
- package/lib/context-url.d.ts +18 -5
- package/lib/context-url.d.ts.map +1 -1
- package/lib/context-url.js +59 -6
- package/lib/context-url.js.map +1 -1
- package/lib/context-url.spec.d.ts +2 -0
- package/lib/context-url.spec.d.ts.map +1 -1
- package/lib/context-url.spec.js +40 -4
- package/lib/context-url.spec.js.map +1 -1
- package/lib/encryption/container-module.d.ts.map +1 -1
- package/lib/encryption/container-module.js +1 -1
- package/lib/encryption/container-module.js.map +1 -1
- package/lib/encryption/encryption-engine.d.ts.map +1 -1
- package/lib/encryption/encryption-engine.js +9 -9
- package/lib/encryption/encryption-engine.js.map +1 -1
- package/lib/encryption/encryption-engine.spec.d.ts.map +1 -1
- package/lib/encryption/encryption-engine.spec.js +2 -3
- package/lib/encryption/encryption-engine.spec.js.map +1 -1
- package/lib/encryption/encryption-service.d.ts.map +1 -1
- package/lib/encryption/encryption-service.js +1 -1
- package/lib/encryption/encryption-service.js.map +1 -1
- package/lib/encryption/key-provider.d.ts.map +1 -1
- package/lib/encryption/key-provider.js +7 -9
- package/lib/encryption/key-provider.js.map +1 -1
- package/lib/env.d.ts +0 -5
- package/lib/env.d.ts.map +1 -1
- package/lib/env.js +1 -20
- package/lib/env.js.map +1 -1
- package/lib/experiments/always-default.d.ts +8 -0
- package/lib/experiments/always-default.d.ts.map +1 -0
- package/lib/experiments/always-default.js +20 -0
- package/lib/experiments/always-default.js.map +1 -0
- package/lib/experiments/configcat-server.d.ts +10 -0
- package/lib/experiments/configcat-server.d.ts.map +1 -0
- package/lib/experiments/configcat-server.js +36 -0
- package/lib/experiments/configcat-server.js.map +1 -0
- package/lib/experiments/configcat.d.ts +21 -0
- package/lib/experiments/configcat.d.ts.map +1 -0
- package/lib/experiments/configcat.js +51 -0
- package/lib/experiments/configcat.js.map +1 -0
- package/lib/experiments/types.d.ts +22 -0
- package/lib/experiments/types.d.ts.map +1 -0
- package/lib/experiments/types.js +10 -0
- package/lib/experiments/types.js.map +1 -0
- package/lib/gitpod-file-parser.d.ts.map +1 -1
- package/lib/gitpod-file-parser.js +6 -6
- package/lib/gitpod-file-parser.js.map +1 -1
- package/lib/gitpod-file-parser.spec.js +42 -39
- package/lib/gitpod-file-parser.spec.js.map +1 -1
- package/lib/gitpod-service.d.ts +83 -45
- package/lib/gitpod-service.d.ts.map +1 -1
- package/lib/gitpod-service.js +52 -33
- package/lib/gitpod-service.js.map +1 -1
- package/lib/headless-workspace-log.d.ts +1 -0
- package/lib/headless-workspace-log.d.ts.map +1 -1
- package/lib/headless-workspace-log.js +2 -1
- package/lib/headless-workspace-log.js.map +1 -1
- package/lib/ide-frontend-service.d.ts +1 -1
- package/lib/ide-protocol.d.ts +38 -6
- package/lib/ide-protocol.d.ts.map +1 -1
- package/lib/index.d.ts +16 -15
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +2 -1
- package/lib/index.js.map +1 -1
- package/lib/installation-admin-protocol.d.ts +30 -0
- package/lib/installation-admin-protocol.d.ts.map +1 -0
- package/lib/installation-admin-protocol.js +31 -0
- package/lib/installation-admin-protocol.js.map +1 -0
- package/lib/license-protocol.d.ts +7 -0
- package/lib/license-protocol.d.ts.map +1 -1
- package/lib/license-protocol.js.map +1 -1
- package/lib/messaging/browser/connection.d.ts +1 -1
- package/lib/messaging/browser/connection.d.ts.map +1 -1
- package/lib/messaging/browser/connection.js +19 -19
- package/lib/messaging/browser/connection.js.map +1 -1
- package/lib/messaging/browser/window-connection.d.ts +4 -4
- package/lib/messaging/browser/window-connection.d.ts.map +1 -1
- package/lib/messaging/browser/window-connection.js +9 -6
- package/lib/messaging/browser/window-connection.js.map +1 -1
- package/lib/messaging/client-call-metrics.d.ts +2 -18
- package/lib/messaging/client-call-metrics.d.ts.map +1 -1
- package/lib/messaging/client-call-metrics.js +21 -22
- package/lib/messaging/client-call-metrics.js.map +1 -1
- package/lib/messaging/error.d.ts +8 -1
- package/lib/messaging/error.d.ts.map +1 -1
- package/lib/messaging/error.js +17 -3
- package/lib/messaging/error.js.map +1 -1
- package/lib/messaging/handler.d.ts.map +1 -1
- package/lib/messaging/handler.js +1 -1
- package/lib/messaging/node/connection.js +8 -8
- package/lib/messaging/node/connection.js.map +1 -1
- package/lib/messaging/proxy-factory.d.ts +1 -1
- package/lib/messaging/proxy-factory.d.ts.map +1 -1
- package/lib/messaging/proxy-factory.js +7 -9
- package/lib/messaging/proxy-factory.js.map +1 -1
- package/lib/payment-protocol.d.ts.map +1 -1
- package/lib/payment-protocol.js +1 -1
- package/lib/payment-protocol.js.map +1 -1
- package/lib/permission.d.ts +9 -3
- package/lib/permission.d.ts.map +1 -1
- package/lib/permission.js +34 -25
- package/lib/permission.js.map +1 -1
- package/lib/plans.d.ts +4 -3
- package/lib/plans.d.ts.map +1 -1
- package/lib/plans.js +210 -171
- package/lib/plans.js.map +1 -1
- package/lib/protocol.d.ts +192 -59
- package/lib/protocol.d.ts.map +1 -1
- package/lib/protocol.js +292 -104
- package/lib/protocol.js.map +1 -1
- package/{src/theia-plugins.ts → lib/protocol.spec.d.ts} +2 -6
- package/lib/protocol.spec.d.ts.map +1 -0
- package/lib/protocol.spec.js +127 -0
- package/lib/protocol.spec.js.map +1 -0
- package/lib/snapshot-url.spec.js.map +1 -1
- package/lib/team-subscription-protocol.d.ts +22 -3
- package/lib/team-subscription-protocol.d.ts.map +1 -1
- package/lib/team-subscription-protocol.js +20 -5
- package/lib/team-subscription-protocol.js.map +1 -1
- package/lib/teams-projects-protocol.d.ts +29 -5
- package/lib/teams-projects-protocol.d.ts.map +1 -1
- package/lib/teams-projects-protocol.js +8 -1
- package/lib/teams-projects-protocol.js.map +1 -1
- package/lib/typings/globals.d.ts +2 -2
- package/lib/typings/globals.d.ts.map +1 -1
- package/lib/usage.d.ts +61 -0
- package/lib/usage.d.ts.map +1 -0
- package/lib/usage.js +14 -0
- package/lib/usage.js.map +1 -0
- package/lib/util/analytics.d.ts.map +1 -1
- package/lib/util/analytics.js +12 -3
- package/lib/util/analytics.js.map +1 -1
- package/lib/util/async-iterator.d.ts.map +1 -1
- package/lib/util/async-iterator.js +3 -3
- package/lib/util/async-iterator.js.map +1 -1
- package/lib/util/cancelable.js.map +1 -1
- package/lib/util/date-time.js +6 -6
- package/lib/util/date-time.js.map +1 -1
- package/lib/util/debug-app.d.ts +25 -0
- package/lib/util/debug-app.d.ts.map +1 -0
- package/lib/util/debug-app.js +100 -0
- package/lib/util/debug-app.js.map +1 -0
- package/lib/util/deferred.js.map +1 -1
- package/lib/util/disposable.d.ts.map +1 -1
- package/lib/util/disposable.js +2 -2
- package/lib/util/disposable.js.map +1 -1
- package/lib/util/event.d.ts.map +1 -1
- package/lib/util/event.js +5 -3
- package/lib/util/event.js.map +1 -1
- package/lib/util/garbage-collected-cache.d.ts.map +1 -1
- package/lib/util/garbage-collected-cache.js +6 -1
- package/lib/util/garbage-collected-cache.js.map +1 -1
- package/lib/util/generate-workspace-id.d.ts +5 -0
- package/lib/util/generate-workspace-id.d.ts.map +1 -1
- package/lib/util/generate-workspace-id.js +446 -442
- package/lib/util/generate-workspace-id.js.map +1 -1
- package/lib/util/generate-workspace-id.spec.js +18 -7
- package/lib/util/generate-workspace-id.spec.js.map +1 -1
- package/lib/util/gitpod-cookie.d.ts +1 -1
- package/lib/util/gitpod-cookie.d.ts.map +1 -1
- package/lib/util/gitpod-cookie.js +0 -3
- package/lib/util/gitpod-cookie.js.map +1 -1
- package/lib/util/gitpod-host-url.d.ts +3 -0
- package/lib/util/gitpod-host-url.d.ts.map +1 -1
- package/lib/util/gitpod-host-url.js +49 -29
- package/lib/util/gitpod-host-url.js.map +1 -1
- package/lib/util/gitpod-host-url.spec.d.ts.map +1 -1
- package/lib/util/gitpod-host-url.spec.js +15 -5
- package/lib/util/gitpod-host-url.spec.js.map +1 -1
- package/lib/util/grpc.d.ts +19 -0
- package/lib/util/grpc.d.ts.map +1 -1
- package/lib/util/grpc.js +73 -1
- package/lib/util/grpc.js.map +1 -1
- package/lib/util/jaeger-client-types.d.ts.map +1 -1
- package/lib/util/logging.d.ts +1 -1
- package/lib/util/logging.d.ts.map +1 -1
- package/lib/util/logging.js +31 -25
- package/lib/util/logging.js.map +1 -1
- package/lib/util/logging.spec.d.ts +7 -0
- package/lib/util/logging.spec.d.ts.map +1 -0
- package/lib/util/logging.spec.js +52 -0
- package/lib/util/logging.spec.js.map +1 -0
- package/lib/util/make-link.js +5 -5
- package/lib/util/make-link.js.map +1 -1
- package/lib/util/nice-grpc.d.ts +9 -0
- package/lib/util/nice-grpc.d.ts.map +1 -0
- package/lib/util/nice-grpc.js +119 -0
- package/lib/util/nice-grpc.js.map +1 -0
- package/lib/util/parse-workspace-id.d.ts.map +1 -1
- package/lib/util/parse-workspace-id.js +1 -2
- package/lib/util/parse-workspace-id.js.map +1 -1
- package/lib/util/parse-workspace-id.spec.d.ts.map +1 -1
- package/lib/util/parse-workspace-id.spec.js.map +1 -1
- package/lib/util/queue.spec.js +9 -6
- package/lib/util/queue.spec.js.map +1 -1
- package/lib/util/semaphore.d.ts.map +1 -1
- package/lib/util/semaphore.js.map +1 -1
- package/lib/util/skip-if.d.ts.map +1 -1
- package/lib/util/skip-if.js.map +1 -1
- package/lib/util/timeutil.d.ts +2 -0
- package/lib/util/timeutil.d.ts.map +1 -1
- package/lib/util/timeutil.js +15 -3
- package/lib/util/timeutil.js.map +1 -1
- package/lib/util/timeutil.spec.d.ts +2 -0
- package/lib/util/timeutil.spec.d.ts.map +1 -1
- package/lib/util/timeutil.spec.js +34 -0
- package/lib/util/timeutil.spec.js.map +1 -1
- package/lib/util/tracing.d.ts +8 -8
- package/lib/util/tracing.d.ts.map +1 -1
- package/lib/util/tracing.js +19 -20
- package/lib/util/tracing.js.map +1 -1
- package/lib/util/tracing.spec.js +3 -3
- package/lib/util/tracing.spec.js.map +1 -1
- package/lib/util/workspace-port-authentication.d.ts +7 -7
- package/lib/util/workspace-port-authentication.d.ts.map +1 -1
- package/lib/util/workspace-port-authentication.js +8 -11
- package/lib/util/workspace-port-authentication.js.map +1 -1
- package/lib/webhook-event.d.ts +44 -0
- package/lib/webhook-event.d.ts.map +1 -0
- package/lib/{theia-plugins.js → webhook-event.js} +2 -2
- package/lib/webhook-event.js.map +1 -0
- package/lib/workspace-class.d.ts +14 -0
- package/lib/workspace-class.d.ts.map +1 -0
- package/lib/workspace-class.js +8 -0
- package/lib/workspace-class.js.map +1 -0
- package/lib/workspace-cluster.d.ts +18 -17
- package/lib/workspace-cluster.d.ts.map +1 -1
- package/lib/workspace-cluster.js +16 -1
- package/lib/workspace-cluster.js.map +1 -1
- package/lib/workspace-instance.d.ts +39 -3
- package/lib/workspace-instance.d.ts.map +1 -1
- package/lib/wsready.d.ts +1 -1
- package/lib/wsready.d.ts.map +1 -1
- package/lib/wsready.js +2 -2
- package/package.json +15 -7
- package/pkg-yarn.lock +11 -6
- package/provenance-bundle.jsonl +3 -1
- package/src/accounting-protocol.ts +66 -51
- package/src/admin-protocol.ts +45 -18
- package/src/analytics.ts +26 -28
- package/src/attribution.ts +63 -0
- package/src/auth.ts +2 -2
- package/src/billing-mode.ts +84 -0
- package/src/blocked-repositories-protocol.ts +13 -0
- package/src/context-url.spec.ts +37 -9
- package/src/context-url.ts +94 -36
- package/src/encryption/container-module.ts +2 -3
- package/src/encryption/encryption-engine.spec.ts +9 -8
- package/src/encryption/encryption-engine.ts +20 -16
- package/src/encryption/encryption-service.ts +4 -5
- package/src/encryption/key-provider.ts +16 -19
- package/src/env.ts +0 -22
- package/src/experiments/always-default.ts +24 -0
- package/src/experiments/configcat-server.ts +41 -0
- package/src/experiments/configcat.ts +56 -0
- package/src/experiments/types.ts +34 -0
- package/src/gitpod-file-parser.spec.ts +55 -61
- package/src/gitpod-file-parser.ts +16 -17
- package/src/gitpod-service.ts +228 -129
- package/src/headless-workspace-log.ts +6 -4
- package/src/ide-frontend-service.ts +2 -2
- package/src/ide-protocol.ts +43 -6
- package/src/index.ts +16 -15
- package/src/installation-admin-protocol.ts +45 -0
- package/src/license-protocol.ts +12 -6
- package/src/messaging/browser/connection.ts +45 -47
- package/src/messaging/browser/window-connection.ts +39 -29
- package/src/messaging/client-call-metrics.ts +62 -82
- package/src/messaging/error.ts +26 -7
- package/src/messaging/handler.ts +6 -6
- package/src/messaging/node/connection.ts +8 -8
- package/src/messaging/proxy-factory.ts +23 -30
- package/src/oss-allowlist.ts +3 -3
- package/src/payment-protocol.ts +2 -2
- package/src/permission.ts +40 -32
- package/src/plans.ts +240 -189
- package/src/protocol.spec.ts +97 -0
- package/src/protocol.ts +556 -258
- package/src/snapshot-url.spec.ts +9 -7
- package/src/team-subscription-protocol.ts +59 -22
- package/src/teams-projects-protocol.ts +43 -12
- package/src/typings/globals.ts +4 -4
- package/src/usage.ts +71 -0
- package/src/util/analytics.ts +46 -24
- package/src/util/async-iterator.ts +4 -5
- package/src/util/cancelable.ts +3 -3
- package/src/util/date-time.ts +8 -8
- package/src/util/debug-app.ts +81 -0
- package/src/util/deferred.ts +6 -6
- package/src/util/disposable.ts +3 -6
- package/src/util/event.ts +9 -11
- package/src/util/garbage-collected-cache.ts +8 -6
- package/src/util/generate-workspace-id.spec.ts +26 -16
- package/src/util/generate-workspace-id.ts +460 -454
- package/src/util/gitpod-cookie.ts +8 -9
- package/src/util/gitpod-host-url.spec.ts +40 -13
- package/src/util/gitpod-host-url.ts +57 -33
- package/src/util/grpc.ts +90 -1
- package/src/util/jaeger-client-types.ts +2 -2
- package/src/util/logging.spec.ts +23 -0
- package/src/util/logging.ts +60 -42
- package/src/util/make-link.ts +6 -7
- package/src/util/nice-grpc.ts +93 -0
- package/src/util/parse-workspace-id.spec.ts +17 -8
- package/src/util/parse-workspace-id.ts +5 -6
- package/src/util/queue.spec.ts +27 -25
- package/src/util/repeat.ts +1 -1
- package/src/util/semaphore.ts +4 -6
- package/src/util/skip-if.ts +9 -6
- package/src/util/timeutil.spec.ts +40 -14
- package/src/util/timeutil.ts +27 -11
- package/src/util/tracing.spec.ts +28 -23
- package/src/util/tracing.ts +58 -54
- package/src/util/workspace-port-authentication.ts +10 -13
- package/src/webhook-event.ts +55 -0
- package/src/workspace-class.ts +14 -0
- package/src/workspace-cluster.ts +34 -20
- package/src/workspace-instance.ts +76 -20
- package/src/wsready.ts +3 -3
- package/data/builtin-theia-plugins.json +0 -372
- package/lib/email-protocol.d.ts +0 -49
- package/lib/email-protocol.d.ts.map +0 -1
- package/lib/email-protocol.js +0 -28
- package/lib/email-protocol.js.map +0 -1
- package/lib/messaging/connection-error-handler.d.ts +0 -27
- package/lib/messaging/connection-error-handler.d.ts.map +0 -1
- package/lib/messaging/connection-error-handler.js +0 -34
- package/lib/messaging/connection-error-handler.js.map +0 -1
- package/lib/theia-plugins.d.ts +0 -11
- package/lib/theia-plugins.d.ts.map +0 -1
- package/lib/theia-plugins.js.map +0 -1
- package/lib/util/safe-promise.d.ts +0 -11
- package/lib/util/safe-promise.d.ts.map +0 -1
- package/lib/util/safe-promise.js +0 -31
- package/lib/util/safe-promise.js.map +0 -1
- package/src/email-protocol.ts +0 -66
- package/src/messaging/connection-error-handler.ts +0 -62
- package/src/util/safe-promise.ts +0 -26
|
@@ -4,40 +4,66 @@
|
|
|
4
4
|
* See License-AGPL.txt in the project root for license information.
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
import * as chai from
|
|
7
|
+
import * as chai from "chai";
|
|
8
8
|
const expect = chai.expect;
|
|
9
|
-
import { suite, test } from
|
|
10
|
-
import { oneMonthLater } from
|
|
9
|
+
import { suite, test } from "mocha-typescript";
|
|
10
|
+
import { daysBefore, hoursBefore, oneMonthLater } from "./timeutil";
|
|
11
11
|
|
|
12
12
|
@suite()
|
|
13
13
|
export class TimeutilSpec {
|
|
14
|
+
@test
|
|
15
|
+
testDaysBefore() {
|
|
16
|
+
const now = new Date().toISOString();
|
|
17
|
+
expect(daysBefore(now, 2)).to.be.eq(hoursBefore(now, 48));
|
|
18
|
+
}
|
|
14
19
|
|
|
15
20
|
@test
|
|
16
21
|
testTimeutil() {
|
|
17
22
|
// targeting a 1st, 1th of Jan => 1st of Feb
|
|
18
|
-
this.isOneMonthLater(new Date(2000, 0, 1), 1, new Date(2000, 1, 1))
|
|
23
|
+
this.isOneMonthLater(new Date(2000, 0, 1), 1, new Date(2000, 1, 1));
|
|
19
24
|
|
|
20
25
|
// targeting a 31th, 30th of Apr => 31st of May
|
|
21
|
-
this.isOneMonthLater(new Date(2000, 3, 30), 31, new Date(2000, 4, 31))
|
|
26
|
+
this.isOneMonthLater(new Date(2000, 3, 30), 31, new Date(2000, 4, 31));
|
|
22
27
|
|
|
23
28
|
// targeting a 31th, 31th of Mar => 30th of Apr
|
|
24
|
-
this.isOneMonthLater(new Date(2000, 2, 31), 31, new Date(2000, 3, 30))
|
|
29
|
+
this.isOneMonthLater(new Date(2000, 2, 31), 31, new Date(2000, 3, 30));
|
|
25
30
|
|
|
26
31
|
// targeting a 30th, 30th of Mar => 30th of Apr
|
|
27
|
-
this.isOneMonthLater(new Date(2000, 2, 30), 30, new Date(2000, 3, 30))
|
|
32
|
+
this.isOneMonthLater(new Date(2000, 2, 30), 30, new Date(2000, 3, 30));
|
|
28
33
|
|
|
29
34
|
// next year
|
|
30
|
-
this.isOneMonthLater(new Date(2000, 11, 1), 1, new Date(2001, 0, 1))
|
|
31
|
-
this.isOneMonthLater(new Date(2000, 11, 31), 31, new Date(2001, 0, 31))
|
|
35
|
+
this.isOneMonthLater(new Date(2000, 11, 1), 1, new Date(2001, 0, 1));
|
|
36
|
+
this.isOneMonthLater(new Date(2000, 11, 31), 31, new Date(2001, 0, 31));
|
|
32
37
|
|
|
33
38
|
// Feb
|
|
34
|
-
this.isOneMonthLater(new Date(2001, 0, 31), 31, new Date(2001, 1, 28))
|
|
39
|
+
this.isOneMonthLater(new Date(2001, 0, 31), 31, new Date(2001, 1, 28));
|
|
35
40
|
// Feb leap year
|
|
36
|
-
this.isOneMonthLater(new Date(2000, 0, 31), 31, new Date(2000, 1, 29))
|
|
41
|
+
this.isOneMonthLater(new Date(2000, 0, 31), 31, new Date(2000, 1, 29));
|
|
37
42
|
}
|
|
38
43
|
|
|
39
44
|
isOneMonthLater(from: Date, day: number, expectation: Date) {
|
|
40
|
-
const later = oneMonthLater(from.toISOString(), day)
|
|
41
|
-
expect(later, `expected ${later} to be equal ${expectation}`).to.be.equal(expectation.toISOString())
|
|
45
|
+
const later = oneMonthLater(from.toISOString(), day);
|
|
46
|
+
expect(later, `expected ${later} to be equal ${expectation}`).to.be.equal(expectation.toISOString());
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
@test
|
|
50
|
+
testDaysBefore2() {
|
|
51
|
+
const tests: { date: Date; daysEarlier: number; expectation: string }[] = [
|
|
52
|
+
{
|
|
53
|
+
date: new Date("2021-07-13T00:00:00.000Z"),
|
|
54
|
+
daysEarlier: 365,
|
|
55
|
+
expectation: "2020-07-13T00:00:00.000Z",
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
date: new Date("2019-02-01T00:00:00.000Z"),
|
|
59
|
+
daysEarlier: 365,
|
|
60
|
+
expectation: "2018-02-01T00:00:00.000Z",
|
|
61
|
+
},
|
|
62
|
+
];
|
|
63
|
+
|
|
64
|
+
for (const t of tests) {
|
|
65
|
+
const actual = daysBefore(t.date.toISOString(), t.daysEarlier);
|
|
66
|
+
expect(actual).to.equal(t.expectation, `expected ${actual} to be equal ${t.expectation}`);
|
|
67
|
+
}
|
|
42
68
|
}
|
|
43
|
-
}
|
|
69
|
+
}
|
package/src/util/timeutil.ts
CHANGED
|
@@ -24,28 +24,44 @@ export function oneMonthLater(fromDate: string, day?: number): string {
|
|
|
24
24
|
}
|
|
25
25
|
return later.toISOString();
|
|
26
26
|
}
|
|
27
|
-
export const yearsLater = (fromDate: string, years: number): string =>
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
27
|
+
export const yearsLater = (fromDate: string, years: number): string =>
|
|
28
|
+
liftDate1(fromDate, (d) => {
|
|
29
|
+
d.setUTCFullYear(d.getUTCFullYear() + years);
|
|
30
|
+
return d.toISOString();
|
|
31
|
+
});
|
|
31
32
|
|
|
32
33
|
// tslint:disable-next-line:no-shadowed-variable
|
|
33
|
-
export const addMillis = (d1: string, millis: number) =>
|
|
34
|
-
|
|
34
|
+
export const addMillis = (d1: string, millis: number) =>
|
|
35
|
+
liftDate1(d1, (d1) => new Date(d1.getTime() + millis).toISOString());
|
|
36
|
+
export const durationInHours = (d1: string, d2: string) =>
|
|
37
|
+
liftDate(d1, d2, (d1, d2) => millisecondsToHours(d1.getTime() - d2.getTime()));
|
|
35
38
|
export const durationInMillis = (d1: string, d2: string) => liftDate(d1, d2, (d1, d2) => d1.getTime() - d2.getTime());
|
|
36
39
|
// tslint:disable-next-line:no-shadowed-variable
|
|
37
|
-
export const isDateGreaterOrEqual = (d1: string, d2: string): boolean =>
|
|
40
|
+
export const isDateGreaterOrEqual = (d1: string, d2: string): boolean =>
|
|
41
|
+
liftDate(d1, d2, (d1, d2) => d1.getTime() >= d2.getTime());
|
|
38
42
|
export const isDateSmallerOrEqual = (d1: string, d2: string | undefined) => !d2 || d1 <= d2;
|
|
39
43
|
export const isDateSmaller = (d1: string, d2: string | undefined) => !d2 || d1 < d2;
|
|
40
|
-
export const oldest = (d1: string, d2: string): string => d1 > d2 ? d1 : d2;
|
|
41
|
-
export const earliest = (d1: string, d2: string): string => d1 < d2 ? d1 : d2;
|
|
44
|
+
export const oldest = (d1: string, d2: string): string => (d1 > d2 ? d1 : d2);
|
|
45
|
+
export const earliest = (d1: string, d2: string): string => (d1 < d2 ? d1 : d2);
|
|
42
46
|
export const orderAsc = (d1: string, d2: string): number => liftDate(d1, d2, (d1, d2) => d1.getTime() - d2.getTime());
|
|
43
47
|
export const liftDate1 = <T>(d1: string, f: (d1: Date) => T): T => f(new Date(d1));
|
|
44
48
|
export const liftDate = <T>(d1: string, d2: string, f: (d1: Date, d2: Date) => T): T => f(new Date(d1), new Date(d2));
|
|
45
49
|
|
|
50
|
+
export function daysBefore(date: string, days: number): string {
|
|
51
|
+
const result = new Date(date);
|
|
52
|
+
result.setDate(result.getDate() - days);
|
|
53
|
+
return result.toISOString();
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
export function hoursBefore(date: string, hours: number): string {
|
|
57
|
+
const result = new Date(date);
|
|
58
|
+
result.setHours(result.getHours() - hours);
|
|
59
|
+
return result.toISOString();
|
|
60
|
+
}
|
|
61
|
+
|
|
46
62
|
export function hoursLater(date: string, hours: number): string {
|
|
47
|
-
const result = new Date(date)
|
|
48
|
-
result.setHours(result.getHours() + hours)
|
|
63
|
+
const result = new Date(date);
|
|
64
|
+
result.setHours(result.getHours() + hours);
|
|
49
65
|
return result.toISOString();
|
|
50
66
|
}
|
|
51
67
|
|
package/src/util/tracing.spec.ts
CHANGED
|
@@ -4,28 +4,31 @@
|
|
|
4
4
|
* See License-AGPL.txt in the project root for license information.
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
import { suite, test } from "mocha-typescript"
|
|
8
|
-
import * as chai from "chai"
|
|
7
|
+
import { suite, test } from "mocha-typescript";
|
|
8
|
+
import * as chai from "chai";
|
|
9
9
|
import { TraceContext } from "./tracing";
|
|
10
10
|
import { MockTracer } from "opentracing";
|
|
11
11
|
|
|
12
|
-
const expect = chai.expect
|
|
13
|
-
|
|
14
|
-
@suite class TestTracing {
|
|
12
|
+
const expect = chai.expect;
|
|
15
13
|
|
|
14
|
+
@suite
|
|
15
|
+
class TestTracing {
|
|
16
16
|
@test public async testTracingContext_addNestedTags() {
|
|
17
17
|
const tracer = new MockTracer();
|
|
18
|
-
const span = tracer.startSpan(
|
|
19
|
-
TraceContext.addNestedTags(
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
18
|
+
const span = tracer.startSpan("testTracingContext_addNestedTags");
|
|
19
|
+
TraceContext.addNestedTags(
|
|
20
|
+
{ span },
|
|
21
|
+
{
|
|
22
|
+
rpc: {
|
|
23
|
+
system: "jsonrpc",
|
|
24
|
+
jsonrpc: {
|
|
25
|
+
version: "1.0",
|
|
26
|
+
method: "test",
|
|
27
|
+
parameters: ["abc", "def"],
|
|
28
|
+
},
|
|
26
29
|
},
|
|
27
30
|
},
|
|
28
|
-
|
|
31
|
+
);
|
|
29
32
|
|
|
30
33
|
const mockSpan = tracer.report().spans[0];
|
|
31
34
|
expect(mockSpan.tags()).to.deep.equal({
|
|
@@ -39,13 +42,16 @@ const expect = chai.expect
|
|
|
39
42
|
|
|
40
43
|
@test public async testTracingContext_addNestedTags_null() {
|
|
41
44
|
const tracer = new MockTracer();
|
|
42
|
-
const span = tracer.startSpan(
|
|
43
|
-
TraceContext.addNestedTags(
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
45
|
+
const span = tracer.startSpan("testTracingContext_addNestedTags_null");
|
|
46
|
+
TraceContext.addNestedTags(
|
|
47
|
+
{ span },
|
|
48
|
+
{
|
|
49
|
+
someShape: {
|
|
50
|
+
thisIsNull: null,
|
|
51
|
+
thisIsUndefined: undefined,
|
|
52
|
+
},
|
|
47
53
|
},
|
|
48
|
-
|
|
54
|
+
);
|
|
49
55
|
|
|
50
56
|
const mockSpan = tracer.report().spans[0];
|
|
51
57
|
expect(mockSpan.tags()).to.deep.equal({
|
|
@@ -56,7 +62,7 @@ const expect = chai.expect
|
|
|
56
62
|
|
|
57
63
|
@test public async testTracingContext_addJsonRPCParameters() {
|
|
58
64
|
const tracer = new MockTracer();
|
|
59
|
-
const span = tracer.startSpan(
|
|
65
|
+
const span = tracer.startSpan("testTracingContext_addJsonRPCParameters");
|
|
60
66
|
const ctx = { span };
|
|
61
67
|
TraceContext.addJsonRPCParameters(ctx, {
|
|
62
68
|
one: "one",
|
|
@@ -78,6 +84,5 @@ const expect = chai.expect
|
|
|
78
84
|
"rpc.system": "jsonrpc",
|
|
79
85
|
});
|
|
80
86
|
}
|
|
81
|
-
|
|
82
87
|
}
|
|
83
|
-
module.exports = new TestTracing()
|
|
88
|
+
module.exports = new TestTracing();
|
package/src/util/tracing.ts
CHANGED
|
@@ -4,35 +4,32 @@
|
|
|
4
4
|
* See License-AGPL.txt in the project root for license information.
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
|
|
8
|
-
import
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
13
|
-
import {
|
|
14
|
-
import { log, LogContext } from './logging';
|
|
7
|
+
import * as opentracing from "opentracing";
|
|
8
|
+
import { TracingConfig, initTracerFromEnv } from "jaeger-client";
|
|
9
|
+
import { Sampler, SamplingDecision } from "./jaeger-client-types";
|
|
10
|
+
import { initGlobalTracer } from "opentracing";
|
|
11
|
+
import { injectable } from "inversify";
|
|
12
|
+
import { ResponseError } from "vscode-jsonrpc";
|
|
13
|
+
import { log, LogContext } from "./logging";
|
|
15
14
|
|
|
16
15
|
export interface TraceContext {
|
|
17
|
-
span?: opentracing.Span
|
|
16
|
+
span?: opentracing.Span;
|
|
18
17
|
}
|
|
19
18
|
export type TraceContextWithSpan = TraceContext & {
|
|
20
|
-
span: opentracing.Span
|
|
21
|
-
}
|
|
22
|
-
|
|
19
|
+
span: opentracing.Span;
|
|
20
|
+
};
|
|
23
21
|
|
|
24
22
|
export namespace TraceContext {
|
|
25
|
-
export function startSpan(operation: string, parentCtx?: TraceContext
|
|
23
|
+
export function startSpan(operation: string, parentCtx?: TraceContext): opentracing.Span {
|
|
26
24
|
const options: opentracing.SpanOptions = {};
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
if (
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
.map(s => followsFrom(s!.context()));
|
|
25
|
+
|
|
26
|
+
// references should contain span id.
|
|
27
|
+
// cf. https://github.com/jaegertracing/jaeger-client-node/issues/432
|
|
28
|
+
if (!!parentCtx?.span) {
|
|
29
|
+
const ctx = parentCtx?.span?.context();
|
|
30
|
+
if (ctx && !!ctx.toTraceId() && !!ctx.toSpanId()) {
|
|
31
|
+
options.references = [opentracing.followsFrom(ctx)];
|
|
32
|
+
}
|
|
36
33
|
}
|
|
37
34
|
|
|
38
35
|
return opentracing.globalTracer().startSpan(operation, options);
|
|
@@ -43,18 +40,18 @@ export namespace TraceContext {
|
|
|
43
40
|
return { span };
|
|
44
41
|
}
|
|
45
42
|
|
|
46
|
-
export function withSpan(operation: string, callback: () => void, ctx?: TraceContext
|
|
43
|
+
export function withSpan(operation: string, callback: (ctx: TraceContext) => void, ctx?: TraceContext): void {
|
|
47
44
|
// if we don't have a parent span, don't create a trace here as those <trace-without-root-spans> are not useful.
|
|
48
45
|
if (!ctx || !ctx.span || !ctx.span.context()) {
|
|
49
|
-
callback();
|
|
46
|
+
callback({});
|
|
50
47
|
return;
|
|
51
48
|
}
|
|
52
49
|
|
|
53
|
-
const span = TraceContext.startSpan(operation, ctx
|
|
50
|
+
const span = TraceContext.startSpan(operation, ctx);
|
|
54
51
|
try {
|
|
55
|
-
callback();
|
|
52
|
+
callback({ span });
|
|
56
53
|
} catch (e) {
|
|
57
|
-
TraceContext.setError({span}, e);
|
|
54
|
+
TraceContext.setError({ span }, e);
|
|
58
55
|
throw e;
|
|
59
56
|
} finally {
|
|
60
57
|
span.finish();
|
|
@@ -92,7 +89,12 @@ export namespace TraceContext {
|
|
|
92
89
|
addNestedTags(ctx, tags);
|
|
93
90
|
}
|
|
94
91
|
|
|
95
|
-
export function setJsonRPCError(
|
|
92
|
+
export function setJsonRPCError(
|
|
93
|
+
ctx: TraceContext,
|
|
94
|
+
method: string,
|
|
95
|
+
err: ResponseError<any>,
|
|
96
|
+
withStatusCode: boolean = false,
|
|
97
|
+
) {
|
|
96
98
|
if (!ctx.span) {
|
|
97
99
|
return;
|
|
98
100
|
}
|
|
@@ -159,7 +161,7 @@ export namespace TraceContext {
|
|
|
159
161
|
if (!ctx.span) {
|
|
160
162
|
return;
|
|
161
163
|
}
|
|
162
|
-
const namespace = _namespace ? `${_namespace}.` :
|
|
164
|
+
const namespace = _namespace ? `${_namespace}.` : "";
|
|
163
165
|
|
|
164
166
|
try {
|
|
165
167
|
for (const k of Object.keys(keyValueMap)) {
|
|
@@ -188,7 +190,6 @@ export namespace TraceContext {
|
|
|
188
190
|
|
|
189
191
|
@injectable()
|
|
190
192
|
export class TracingManager {
|
|
191
|
-
|
|
192
193
|
public setup(serviceName: string, opts?: CustomTracerOpts) {
|
|
193
194
|
initGlobalTracer(this.getTracerForService(serviceName, opts));
|
|
194
195
|
}
|
|
@@ -197,16 +198,16 @@ export class TracingManager {
|
|
|
197
198
|
const config: TracingConfig = {
|
|
198
199
|
disable: false,
|
|
199
200
|
reporter: {
|
|
200
|
-
logSpans: false
|
|
201
|
+
logSpans: false,
|
|
201
202
|
},
|
|
202
203
|
serviceName,
|
|
203
|
-
}
|
|
204
|
+
};
|
|
204
205
|
const t = initTracerFromEnv(config, {
|
|
205
206
|
logger: console,
|
|
206
207
|
tags: {
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
}
|
|
208
|
+
"service.build.commit": process.env.GITPOD_BUILD_GIT_COMMIT,
|
|
209
|
+
"service.build.version": process.env.GITPOD_BUILD_VERSION,
|
|
210
|
+
},
|
|
210
211
|
});
|
|
211
212
|
|
|
212
213
|
if (opts) {
|
|
@@ -216,24 +217,22 @@ export class TracingManager {
|
|
|
216
217
|
}
|
|
217
218
|
return t;
|
|
218
219
|
}
|
|
219
|
-
|
|
220
220
|
}
|
|
221
221
|
|
|
222
222
|
export interface CustomTracerOpts {
|
|
223
|
-
perOpSampling?: PerOperationSampling
|
|
223
|
+
perOpSampling?: PerOperationSampling;
|
|
224
224
|
}
|
|
225
225
|
|
|
226
|
-
|
|
227
226
|
// has to conform to https://github.com/jaegertracing/jaeger-client-node/blob/0042b1c0a0796bb655eb93e77ff76ab5e94c2bb6/src/_flow/sampler-thrift.js#L32
|
|
228
227
|
export interface PerOperationSampling {
|
|
229
|
-
[key: string]: boolean
|
|
228
|
+
[key: string]: boolean;
|
|
230
229
|
}
|
|
231
230
|
|
|
232
231
|
export class PerOperationSampler implements Sampler {
|
|
233
232
|
constructor(protected readonly fallback: Sampler, protected readonly strategies: PerOperationSampling) {}
|
|
234
233
|
|
|
235
234
|
name(): string {
|
|
236
|
-
return
|
|
235
|
+
return "PerOperationSampler";
|
|
237
236
|
}
|
|
238
237
|
|
|
239
238
|
toString(): string {
|
|
@@ -273,7 +272,7 @@ export class PerOperationSampler implements Sampler {
|
|
|
273
272
|
return false; // TODO equal should be removed
|
|
274
273
|
}
|
|
275
274
|
|
|
276
|
-
close(callback: ()=>void): void {
|
|
275
|
+
close(callback: () => void): void {
|
|
277
276
|
// all nested samplers are of simple types, so we do not need to Close them
|
|
278
277
|
if (callback) {
|
|
279
278
|
callback();
|
|
@@ -282,18 +281,23 @@ export class PerOperationSampler implements Sampler {
|
|
|
282
281
|
}
|
|
283
282
|
|
|
284
283
|
// Augment interfaces with an leading parameter "TraceContext" on every method
|
|
285
|
-
type IsValidArg<T> = T extends object ? keyof T extends never ? false : true : true;
|
|
286
|
-
type AddTraceContext<T> =
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
IsValidArg<E> extends true
|
|
290
|
-
|
|
291
|
-
IsValidArg<
|
|
292
|
-
|
|
293
|
-
IsValidArg<
|
|
294
|
-
(ctx: TraceContextWithSpan) =>
|
|
295
|
-
|
|
284
|
+
type IsValidArg<T> = T extends object ? (keyof T extends never ? false : true) : true;
|
|
285
|
+
type AddTraceContext<T> = T extends (a: infer A, b: infer B, c: infer C, d: infer D, e: infer E, f: infer F) => infer R
|
|
286
|
+
? IsValidArg<F> extends true
|
|
287
|
+
? (ctx: TraceContextWithSpan, a: A, b: B, c: C, d: D, e: E, f: F) => R
|
|
288
|
+
: IsValidArg<E> extends true
|
|
289
|
+
? (ctx: TraceContextWithSpan, a: A, b: B, c: C, d: D, e: E) => R
|
|
290
|
+
: IsValidArg<D> extends true
|
|
291
|
+
? (ctx: TraceContextWithSpan, a: A, b: B, c: C, d: D) => R
|
|
292
|
+
: IsValidArg<C> extends true
|
|
293
|
+
? (ctx: TraceContextWithSpan, a: A, b: B, c: C) => R
|
|
294
|
+
: IsValidArg<B> extends true
|
|
295
|
+
? (ctx: TraceContextWithSpan, a: A, b: B) => R
|
|
296
|
+
: IsValidArg<A> extends true
|
|
297
|
+
? (ctx: TraceContextWithSpan, a: A) => R
|
|
298
|
+
: (ctx: TraceContextWithSpan) => Promise<R>
|
|
299
|
+
: never;
|
|
296
300
|
|
|
297
301
|
export type InterfaceWithTraceContext<T> = {
|
|
298
|
-
[P in keyof T]: AddTraceContext<T[P]
|
|
299
|
-
};
|
|
302
|
+
[P in keyof T]: AddTraceContext<T[P]>;
|
|
303
|
+
};
|
|
@@ -5,16 +5,13 @@
|
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
|
-
* These cookies are set in the Theia frontend. This pattern is relied upon in:
|
|
9
|
-
* - proxy:
|
|
10
|
-
* - to filter it out on port locations
|
|
11
|
-
* - to forward it to the server for authentication
|
|
12
|
-
* - server:
|
|
13
|
-
* - to authenticate access to port locations
|
|
14
|
-
*/
|
|
15
|
-
export const worspacePortAuthCookieName = function(host: string, workspaceId: string): string {
|
|
16
|
-
return host
|
|
17
|
-
|
|
18
|
-
.replace(/[\W_]+/g, "_")
|
|
19
|
-
+ `_ws_${workspaceId}_port_auth_`;
|
|
20
|
-
};
|
|
8
|
+
* These cookies are set in the Theia frontend. This pattern is relied upon in:
|
|
9
|
+
* - proxy:
|
|
10
|
+
* - to filter it out on port locations
|
|
11
|
+
* - to forward it to the server for authentication
|
|
12
|
+
* - server:
|
|
13
|
+
* - to authenticate access to port locations
|
|
14
|
+
*/
|
|
15
|
+
export const worspacePortAuthCookieName = function (host: string, workspaceId: string): string {
|
|
16
|
+
return host.replace(/https?/, "").replace(/[\W_]+/g, "_") + `_ws_${workspaceId}_port_auth_`;
|
|
17
|
+
};
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2022 Gitpod GmbH. All rights reserved.
|
|
3
|
+
* Licensed under the GNU Affero General Public License (AGPL).
|
|
4
|
+
* See License-AGPL.txt in the project root for license information.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
export interface WebhookEvent {
|
|
8
|
+
id: string;
|
|
9
|
+
creationTime: string;
|
|
10
|
+
type: "push" | string;
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Typically the webhook installer is referenced here.
|
|
14
|
+
*/
|
|
15
|
+
authorizedUserId?: string;
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* webhook event's payload
|
|
19
|
+
*/
|
|
20
|
+
rawEvent: string;
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* The general status of the received webhook event.
|
|
24
|
+
*/
|
|
25
|
+
status: WebhookEvent.Status;
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Optional message to help understand errors with handling events.
|
|
29
|
+
*/
|
|
30
|
+
message?: string;
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* If the webhook event is considered to trigger a prebuild, the `prebuildStatus`
|
|
34
|
+
* contains a more specific status.
|
|
35
|
+
*/
|
|
36
|
+
prebuildStatus?: WebhookEvent.PrebuildStatus;
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* If `prebuildStatus` is `prebuild_triggered` this points to a prebuild.
|
|
40
|
+
*/
|
|
41
|
+
prebuildId?: string;
|
|
42
|
+
|
|
43
|
+
projectId?: string;
|
|
44
|
+
|
|
45
|
+
cloneUrl?: string;
|
|
46
|
+
|
|
47
|
+
branch?: string;
|
|
48
|
+
|
|
49
|
+
commit?: string;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
export namespace WebhookEvent {
|
|
53
|
+
export type Status = "received" | "dismissed_unauthorized" | "ignored" | "processed";
|
|
54
|
+
export type PrebuildStatus = "ignored_unconfigured" | "prebuild_trigger_failed" | "prebuild_triggered";
|
|
55
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2022 Gitpod GmbH. All rights reserved.
|
|
3
|
+
* Licensed under the GNU Affero General Public License (AGPL).
|
|
4
|
+
* See License-AGPL.txt in the project root for license information.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
export interface SupportedWorkspaceClass {
|
|
8
|
+
id: string;
|
|
9
|
+
category: string;
|
|
10
|
+
displayName: string;
|
|
11
|
+
description: string;
|
|
12
|
+
powerups: number;
|
|
13
|
+
isSelected: boolean;
|
|
14
|
+
}
|
package/src/workspace-cluster.ts
CHANGED
|
@@ -4,10 +4,10 @@
|
|
|
4
4
|
* See License-AGPL.txt in the project root for license information.
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
import * as fs from
|
|
8
|
-
import { filePathTelepresenceAware } from
|
|
7
|
+
import * as fs from "fs";
|
|
8
|
+
import { filePathTelepresenceAware } from "./env";
|
|
9
9
|
import { DeepPartial } from "./util/deep-partial";
|
|
10
|
-
import { PermissionName } from
|
|
10
|
+
import { PermissionName } from "./permission";
|
|
11
11
|
|
|
12
12
|
export interface WorkspaceCluster {
|
|
13
13
|
// Name of the workspace cluster.
|
|
@@ -15,6 +15,10 @@ export interface WorkspaceCluster {
|
|
|
15
15
|
// Must be identical to the installationShortname of the cluster it represents!
|
|
16
16
|
name: string;
|
|
17
17
|
|
|
18
|
+
// The name of the application cluster to which this cluster should be registered.
|
|
19
|
+
// The name can be at most 60 characters.
|
|
20
|
+
applicationCluster: string;
|
|
21
|
+
|
|
18
22
|
// URL of the cluster's ws-manager API
|
|
19
23
|
url: string;
|
|
20
24
|
|
|
@@ -35,9 +39,6 @@ export interface WorkspaceCluster {
|
|
|
35
39
|
|
|
36
40
|
// An optional set of constraints that limit who can start workspaces on the cluster
|
|
37
41
|
admissionConstraints?: AdmissionConstraint[];
|
|
38
|
-
|
|
39
|
-
// An optional set of admission preferences that guide cluster selection
|
|
40
|
-
admissionPreferences?: AdmissionPreference[];
|
|
41
42
|
}
|
|
42
43
|
|
|
43
44
|
export type WorkspaceClusterState = "available" | "cordoned" | "draining";
|
|
@@ -50,19 +51,31 @@ export interface TLSConfig {
|
|
|
50
51
|
crt: string;
|
|
51
52
|
}
|
|
52
53
|
export namespace TLSConfig {
|
|
53
|
-
export const loadFromBase64File = (path: string): string =>
|
|
54
|
+
export const loadFromBase64File = (path: string): string =>
|
|
55
|
+
fs.readFileSync(filePathTelepresenceAware(path)).toString("base64");
|
|
54
56
|
}
|
|
55
57
|
export type WorkspaceClusterWoTLS = Omit<WorkspaceCluster, "tls">;
|
|
56
58
|
export type WorkspaceManagerConnectionInfo = Pick<WorkspaceCluster, "name" | "url" | "tls">;
|
|
57
59
|
|
|
58
|
-
export type AdmissionConstraint =
|
|
60
|
+
export type AdmissionConstraint =
|
|
61
|
+
| AdmissionConstraintFeaturePreview
|
|
62
|
+
| AdmissionConstraintHasPermission
|
|
63
|
+
| AdmissionConstraintHasClass;
|
|
59
64
|
export type AdmissionConstraintFeaturePreview = { type: "has-feature-preview" };
|
|
60
|
-
export type
|
|
61
|
-
export type
|
|
62
|
-
|
|
63
|
-
export
|
|
64
|
-
export
|
|
65
|
-
|
|
65
|
+
export type AdmissionConstraintHasPermission = { type: "has-permission"; permission: PermissionName };
|
|
66
|
+
export type AdmissionConstraintHasClass = { type: "has-class"; id: string; displayName: string };
|
|
67
|
+
|
|
68
|
+
export namespace AdmissionConstraint {
|
|
69
|
+
export function is(o: any): o is AdmissionConstraint {
|
|
70
|
+
return !!o && "type" in o;
|
|
71
|
+
}
|
|
72
|
+
export function isHasPermissionConstraint(o: any): o is AdmissionConstraintHasPermission {
|
|
73
|
+
return is(o) && o.type === "has-permission";
|
|
74
|
+
}
|
|
75
|
+
export function hasPermission(ac: AdmissionConstraint, permission: PermissionName): boolean {
|
|
76
|
+
return isHasPermissionConstraint(ac) && ac.permission === permission;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
66
79
|
|
|
67
80
|
export const WorkspaceClusterDB = Symbol("WorkspaceClusterDB");
|
|
68
81
|
export interface WorkspaceClusterDB {
|
|
@@ -77,20 +90,21 @@ export interface WorkspaceClusterDB {
|
|
|
77
90
|
* Deletes the cluster identified by this name, if any.
|
|
78
91
|
* @param name
|
|
79
92
|
*/
|
|
80
|
-
deleteByName(name: string): Promise<void>;
|
|
93
|
+
deleteByName(name: string, applicationCluster: string): Promise<void>;
|
|
81
94
|
|
|
82
95
|
/**
|
|
83
96
|
* Finds a WorkspaceCluster with the given name. If there is none, `undefined` is returned.
|
|
84
97
|
* @param name
|
|
85
98
|
*/
|
|
86
|
-
findByName(name: string): Promise<WorkspaceCluster | undefined>;
|
|
99
|
+
findByName(name: string, applicationCluster: string): Promise<WorkspaceCluster | undefined>;
|
|
87
100
|
|
|
88
101
|
/**
|
|
89
102
|
* Lists all WorkspaceClusterWoTls for which the given predicate is true (does not return TLS for size/speed concerns)
|
|
90
103
|
* @param predicate
|
|
91
104
|
*/
|
|
92
|
-
findFiltered(predicate:
|
|
105
|
+
findFiltered(predicate: WorkspaceClusterFilter): Promise<WorkspaceClusterWoTLS[]>;
|
|
93
106
|
}
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
107
|
+
|
|
108
|
+
export type WorkspaceClusterFilter = Pick<WorkspaceCluster, "applicationCluster"> &
|
|
109
|
+
DeepPartial<Pick<WorkspaceCluster, "name" | "state" | "govern" | "url">> &
|
|
110
|
+
Partial<{ minScore: number }>;
|