@gitpod/gitpod-protocol 0.1.5-wth-test.80 → 0.1.5-yh-vmoptions-fork.1
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 +181 -4
- package/lib/accounting-protocol.d.ts +17 -10
- package/lib/accounting-protocol.d.ts.map +1 -1
- package/lib/accounting-protocol.js +30 -32
- package/lib/accounting-protocol.js.map +1 -1
- package/lib/admin-protocol.d.ts +1 -0
- package/lib/admin-protocol.d.ts.map +1 -1
- package/lib/admin-protocol.js.map +1 -1
- package/lib/analytics.d.ts.map +1 -1
- package/lib/analytics.js.map +1 -1
- package/lib/auth.d.ts.map +1 -1
- package/lib/context-url.d.ts.map +1 -1
- package/lib/context-url.js +3 -3
- package/lib/context-url.js.map +1 -1
- package/lib/context-url.spec.d.ts.map +1 -1
- package/lib/context-url.spec.js +20 -5
- package/lib/context-url.spec.js.map +1 -1
- package/lib/email-protocol.d.ts +1 -1
- package/lib/email-protocol.d.ts.map +1 -1
- package/lib/email-protocol.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 +7 -7
- 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/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 +32 -26
- package/lib/gitpod-service.d.ts.map +1 -1
- package/lib/gitpod-service.js +39 -32
- 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 +6 -6
- package/lib/ide-protocol.d.ts.map +1 -1
- package/lib/index.d.ts +16 -16
- package/lib/installation-admin-protocol.d.ts.map +1 -1
- package/lib/installation-admin-protocol.js +2 -2
- package/lib/installation-admin-protocol.js.map +1 -1
- 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 -2
- package/lib/messaging/client-call-metrics.d.ts.map +1 -1
- package/lib/messaging/client-call-metrics.js +20 -20
- package/lib/messaging/client-call-metrics.js.map +1 -1
- package/lib/messaging/error.d.ts +2 -0
- package/lib/messaging/error.d.ts.map +1 -1
- package/lib/messaging/error.js +4 -0
- 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 +2 -2
- package/lib/permission.d.ts.map +1 -1
- package/lib/permission.js +12 -23
- package/lib/permission.js.map +1 -1
- package/lib/plans.d.ts +3 -3
- package/lib/plans.d.ts.map +1 -1
- package/lib/plans.js +206 -171
- package/lib/plans.js.map +1 -1
- package/lib/protocol.d.ts +83 -36
- package/lib/protocol.d.ts.map +1 -1
- package/lib/protocol.js +165 -87
- package/lib/protocol.js.map +1 -1
- package/lib/snapshot-url.spec.js.map +1 -1
- package/lib/team-subscription-protocol.d.ts +21 -3
- package/lib/team-subscription-protocol.d.ts.map +1 -1
- package/lib/team-subscription-protocol.js +16 -5
- package/lib/team-subscription-protocol.js.map +1 -1
- package/lib/teams-projects-protocol.d.ts +8 -3
- package/lib/teams-projects-protocol.d.ts.map +1 -1
- package/lib/teams-projects-protocol.js +1 -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/util/analytics.d.ts.map +1 -1
- package/lib/util/analytics.js +6 -6
- 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/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 +1 -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.map +1 -1
- package/lib/util/gitpod-host-url.js +31 -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.map +1 -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 +23 -24
- package/lib/util/logging.js.map +1 -1
- package/lib/util/make-link.js +5 -5
- package/lib/util/make-link.js.map +1 -1
- 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 +1 -0
- package/lib/util/timeutil.d.ts.map +1 -1
- package/lib/util/timeutil.js +9 -3
- package/lib/util/timeutil.js.map +1 -1
- package/lib/util/timeutil.spec.d.ts.map +1 -1
- package/lib/util/timeutil.spec.js.map +1 -1
- package/lib/util/tracing.d.ts +6 -6
- package/lib/util/tracing.d.ts.map +1 -1
- package/lib/util/tracing.js +14 -16
- 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/workspace-cluster.d.ts +1 -1
- package/lib/workspace-cluster.d.ts.map +1 -1
- package/lib/workspace-cluster.js +2 -4
- package/lib/workspace-cluster.js.map +1 -1
- package/lib/workspace-instance.d.ts +19 -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 +6 -6
- package/pkg-yarn.lock +5 -5
- package/provenance-bundle.jsonl +1 -1
- package/src/accounting-protocol.ts +63 -51
- package/src/admin-protocol.ts +23 -20
- package/src/analytics.ts +21 -21
- package/src/auth.ts +2 -2
- package/src/context-url.spec.ts +25 -11
- package/src/context-url.ts +80 -78
- package/src/email-protocol.ts +5 -6
- package/src/encryption/container-module.ts +2 -3
- package/src/encryption/encryption-engine.spec.ts +9 -8
- package/src/encryption/encryption-engine.ts +14 -14
- package/src/encryption/encryption-service.ts +4 -5
- package/src/encryption/key-provider.ts +16 -19
- package/src/env.ts +0 -22
- package/src/gitpod-file-parser.spec.ts +55 -61
- package/src/gitpod-file-parser.ts +16 -17
- package/src/gitpod-service.ts +152 -110
- package/src/headless-workspace-log.ts +6 -4
- package/src/ide-frontend-service.ts +2 -2
- package/src/ide-protocol.ts +8 -8
- package/src/index.ts +16 -16
- package/src/installation-admin-protocol.ts +8 -8
- 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 +70 -71
- package/src/messaging/error.ts +7 -3
- 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 +20 -31
- package/src/plans.ts +236 -189
- package/src/protocol.ts +346 -239
- package/src/snapshot-url.spec.ts +9 -7
- package/src/team-subscription-protocol.ts +57 -23
- package/src/teams-projects-protocol.ts +14 -8
- package/src/typings/globals.ts +4 -4
- package/src/util/analytics.ts +46 -42
- 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/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 +3 -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 +37 -34
- package/src/util/grpc.ts +1 -1
- package/src/util/jaeger-client-types.ts +2 -2
- package/src/util/logging.ts +49 -40
- package/src/util/make-link.ts +6 -7
- 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 +14 -15
- package/src/util/timeutil.ts +21 -11
- package/src/util/tracing.spec.ts +28 -23
- package/src/util/tracing.ts +54 -51
- package/src/util/workspace-port-authentication.ts +10 -13
- package/src/workspace-cluster.ts +15 -12
- package/src/workspace-instance.ts +53 -24
- package/src/wsready.ts +3 -3
- package/data/builtin-theia-plugins.json +0 -372
- package/lib/theia-plugins.d.ts +0 -11
- package/lib/theia-plugins.d.ts.map +0 -1
- package/lib/theia-plugins.js +0 -8
- package/lib/theia-plugins.js.map +0 -1
- package/src/theia-plugins.ts +0 -11
package/src/snapshot-url.spec.ts
CHANGED
|
@@ -4,16 +4,18 @@
|
|
|
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 { SnapshotUrl } from ".";
|
|
10
10
|
|
|
11
|
-
const expect = chai.expect
|
|
12
|
-
|
|
13
|
-
@suite class TestSnapshotUrlParser {
|
|
11
|
+
const expect = chai.expect;
|
|
14
12
|
|
|
13
|
+
@suite
|
|
14
|
+
class TestSnapshotUrlParser {
|
|
15
15
|
@test public testPositive() {
|
|
16
|
-
const actual = SnapshotUrl.parse(
|
|
16
|
+
const actual = SnapshotUrl.parse(
|
|
17
|
+
"workspaces/c362d434-6faa-4ce0-9ad4-91b4a87c4abe/3f0556f7-4afa-11e9-98d5-52f8983b9279.tar@gitpod-prodcopy-user-e1e28f18-0354-4a5d-b6b4-8879a2ff73fd",
|
|
18
|
+
);
|
|
17
19
|
|
|
18
20
|
expect(actual).to.deep.equal(<SnapshotUrl>{
|
|
19
21
|
bucketId: "gitpod-prodcopy-user-e1e28f18-0354-4a5d-b6b4-8879a2ff73fd",
|
|
@@ -22,4 +24,4 @@ const expect = chai.expect
|
|
|
22
24
|
});
|
|
23
25
|
}
|
|
24
26
|
}
|
|
25
|
-
module.exports = new TestSnapshotUrlParser()
|
|
27
|
+
module.exports = new TestSnapshotUrlParser(); // Only to circumvent no usage warning :-/
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* See License-AGPL.txt in the project root for license information.
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
import { v4 as uuidv4 } from
|
|
7
|
+
import { v4 as uuidv4 } from "uuid";
|
|
8
8
|
import { Subscription } from "./accounting-protocol";
|
|
9
9
|
|
|
10
10
|
export interface TeamSubscription {
|
|
@@ -18,17 +18,43 @@ export interface TeamSubscription {
|
|
|
18
18
|
paymentReference: string;
|
|
19
19
|
cancellationDate?: string;
|
|
20
20
|
deleted?: boolean;
|
|
21
|
+
/** If this flag is set slots are not eligibile for clusters with "more-resources" - even if their plan might be */
|
|
22
|
+
excludeFromMoreResources: boolean;
|
|
21
23
|
}
|
|
22
24
|
|
|
23
25
|
export namespace TeamSubscription {
|
|
24
|
-
export const create = (ts: Omit<TeamSubscription,
|
|
26
|
+
export const create = (ts: Omit<TeamSubscription, "id">): TeamSubscription => {
|
|
25
27
|
const withId = ts as TeamSubscription;
|
|
26
28
|
withId.id = uuidv4();
|
|
27
29
|
return withId;
|
|
28
|
-
}
|
|
30
|
+
};
|
|
29
31
|
export const isActive = (ts: TeamSubscription, date: string): boolean => {
|
|
30
32
|
return ts.startDate <= date && (ts.endDate === undefined || date < ts.endDate);
|
|
31
|
-
}
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export interface TeamSubscription2 {
|
|
37
|
+
id: string;
|
|
38
|
+
teamId: string;
|
|
39
|
+
planId: string;
|
|
40
|
+
startDate: string;
|
|
41
|
+
endDate?: string;
|
|
42
|
+
quantity: number;
|
|
43
|
+
/** The Chargebee subscription id */
|
|
44
|
+
paymentReference: string;
|
|
45
|
+
cancellationDate?: string;
|
|
46
|
+
excludeFromMoreResources: boolean;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
export namespace TeamSubscription2 {
|
|
50
|
+
export const create = (ts2: Omit<TeamSubscription2, "id">): TeamSubscription2 => {
|
|
51
|
+
const withId = ts2 as TeamSubscription2;
|
|
52
|
+
withId.id = uuidv4();
|
|
53
|
+
return withId;
|
|
54
|
+
};
|
|
55
|
+
export const isActive = (ts2: TeamSubscription2, date: string): boolean => {
|
|
56
|
+
return ts2.startDate <= date && (ts2.endDate === undefined || date < ts2.endDate);
|
|
57
|
+
};
|
|
32
58
|
}
|
|
33
59
|
|
|
34
60
|
/**
|
|
@@ -42,49 +68,57 @@ export interface TeamSubscriptionSlot {
|
|
|
42
68
|
subscriptionId?: string;
|
|
43
69
|
cancellationDate?: string;
|
|
44
70
|
}
|
|
45
|
-
export type TeamSubscriptionSlotDeactivated = TeamSubscriptionSlot & {
|
|
46
|
-
|
|
71
|
+
export type TeamSubscriptionSlotDeactivated = TeamSubscriptionSlot & {
|
|
72
|
+
assigneeId: string;
|
|
73
|
+
assigneeIdentifier: AssigneeIdentifier;
|
|
74
|
+
};
|
|
75
|
+
export type TeamSubscriptionSlotAssigned = TeamSubscriptionSlot &
|
|
76
|
+
TeamSubscriptionSlotDeactivated & { subscriptionId: string };
|
|
47
77
|
|
|
48
|
-
export type TeamSubscriptionSlotState =
|
|
78
|
+
export type TeamSubscriptionSlotState = "unassigned" | "assigned" | "deactivated" | "cancelled";
|
|
49
79
|
|
|
50
80
|
export namespace TeamSubscriptionSlot {
|
|
51
|
-
export const create = (ts: Omit<TeamSubscriptionSlot,
|
|
81
|
+
export const create = (ts: Omit<TeamSubscriptionSlot, "id">): TeamSubscriptionSlot => {
|
|
52
82
|
const withId = ts as TeamSubscriptionSlot;
|
|
53
83
|
withId.id = uuidv4();
|
|
54
84
|
return withId;
|
|
55
|
-
}
|
|
56
|
-
export const assign = (
|
|
85
|
+
};
|
|
86
|
+
export const assign = (
|
|
87
|
+
slot: TeamSubscriptionSlot,
|
|
88
|
+
assigneeId: string,
|
|
89
|
+
subscriptionId: string,
|
|
90
|
+
assigneeIdentifier: AssigneeIdentifier,
|
|
91
|
+
) => {
|
|
57
92
|
slot.assigneeId = assigneeId;
|
|
58
93
|
slot.subscriptionId = subscriptionId;
|
|
59
94
|
slot.assigneeIdentifier = assigneeIdentifier;
|
|
60
|
-
}
|
|
95
|
+
};
|
|
61
96
|
export const deactivate = (slot: TeamSubscriptionSlot, cancellationDate: string) => {
|
|
62
97
|
slot.subscriptionId = undefined;
|
|
63
98
|
slot.cancellationDate = cancellationDate;
|
|
64
|
-
}
|
|
99
|
+
};
|
|
65
100
|
export const reactivate = (slot: TeamSubscriptionSlot, subscriptionId?: string) => {
|
|
66
101
|
slot.subscriptionId = subscriptionId;
|
|
67
102
|
slot.cancellationDate = undefined;
|
|
68
|
-
}
|
|
103
|
+
};
|
|
69
104
|
export const status = (slot: TeamSubscriptionSlot, now: string): TeamSubscriptionSlotState => {
|
|
70
105
|
if (slot.cancellationDate) {
|
|
71
106
|
if (slot.cancellationDate < now) {
|
|
72
|
-
return
|
|
107
|
+
return "cancelled";
|
|
73
108
|
} else {
|
|
74
|
-
return
|
|
109
|
+
return "deactivated";
|
|
75
110
|
}
|
|
76
111
|
} else {
|
|
77
112
|
if (slot.subscriptionId) {
|
|
78
|
-
return
|
|
113
|
+
return "assigned";
|
|
79
114
|
} else {
|
|
80
|
-
return
|
|
115
|
+
return "unassigned";
|
|
81
116
|
}
|
|
82
117
|
}
|
|
83
|
-
|
|
84
|
-
}
|
|
118
|
+
};
|
|
85
119
|
export const isActive = (slot: TeamSubscriptionSlot): boolean => {
|
|
86
120
|
return !slot.cancellationDate;
|
|
87
|
-
}
|
|
121
|
+
};
|
|
88
122
|
}
|
|
89
123
|
|
|
90
124
|
/**
|
|
@@ -107,7 +141,7 @@ export interface TeamSubscriptionSlotResolved {
|
|
|
107
141
|
export type AssigneeIdentifier = AssigneeIdentityIdentifier;
|
|
108
142
|
export interface AssigneeIdentityIdentifier {
|
|
109
143
|
identity: {
|
|
110
|
-
authHost: string
|
|
111
|
-
authName: string
|
|
112
|
-
}
|
|
144
|
+
authHost: string;
|
|
145
|
+
authName: string;
|
|
146
|
+
};
|
|
113
147
|
}
|
|
@@ -5,15 +5,16 @@
|
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
7
|
import { PrebuiltWorkspaceState } from "./protocol";
|
|
8
|
-
import { v4 as uuidv4 } from
|
|
8
|
+
import { v4 as uuidv4 } from "uuid";
|
|
9
9
|
import { DeepPartial } from "./util/deep-partial";
|
|
10
10
|
|
|
11
11
|
export interface ProjectConfig {
|
|
12
|
-
|
|
12
|
+
".gitpod.yml": string;
|
|
13
13
|
}
|
|
14
14
|
|
|
15
15
|
export interface ProjectSettings {
|
|
16
16
|
useIncrementalPrebuilds?: boolean;
|
|
17
|
+
usePersistentVolumeClaim?: boolean;
|
|
17
18
|
}
|
|
18
19
|
|
|
19
20
|
export interface Project {
|
|
@@ -33,13 +34,13 @@ export interface Project {
|
|
|
33
34
|
}
|
|
34
35
|
|
|
35
36
|
export namespace Project {
|
|
36
|
-
export const create = (project: Omit<Project,
|
|
37
|
+
export const create = (project: Omit<Project, "id" | "creationTime">): Project => {
|
|
37
38
|
return {
|
|
38
39
|
...project,
|
|
39
40
|
id: uuidv4(),
|
|
40
|
-
creationTime: new Date().toISOString()
|
|
41
|
+
creationTime: new Date().toISOString(),
|
|
41
42
|
};
|
|
42
|
-
}
|
|
43
|
+
};
|
|
43
44
|
|
|
44
45
|
export interface Overview {
|
|
45
46
|
branches: BranchDetails[];
|
|
@@ -67,7 +68,12 @@ export namespace Project {
|
|
|
67
68
|
}
|
|
68
69
|
}
|
|
69
70
|
|
|
70
|
-
export type PartialProject = DeepPartial<Project> & Pick<Project,
|
|
71
|
+
export type PartialProject = DeepPartial<Project> & Pick<Project, "id">;
|
|
72
|
+
|
|
73
|
+
export interface ProjectUsage {
|
|
74
|
+
lastWebhookReceived: string;
|
|
75
|
+
lastWorkspaceStart: string;
|
|
76
|
+
}
|
|
71
77
|
|
|
72
78
|
export interface PrebuildWithStatus {
|
|
73
79
|
info: PrebuildInfo;
|
|
@@ -103,7 +109,7 @@ export interface PrebuildInfo {
|
|
|
103
109
|
}
|
|
104
110
|
export namespace PrebuildInfo {
|
|
105
111
|
export function is(data?: any): data is PrebuildInfo {
|
|
106
|
-
return typeof data === "object" && ["id", "buildWorkspaceId", "projectId", "branch"].every(p => p in data);
|
|
112
|
+
return typeof data === "object" && ["id", "buildWorkspaceId", "projectId", "branch"].every((p) => p in data);
|
|
107
113
|
}
|
|
108
114
|
}
|
|
109
115
|
|
|
@@ -144,4 +150,4 @@ export interface TeamMembershipInvite {
|
|
|
144
150
|
|
|
145
151
|
/** This is a flag that triggers the HARD DELETION of this entity */
|
|
146
152
|
deleted?: boolean;
|
|
147
|
-
}
|
|
153
|
+
}
|
package/src/typings/globals.ts
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
|
|
7
7
|
interface Window {
|
|
8
8
|
gitpod: {
|
|
9
|
-
service: import(
|
|
10
|
-
ideService?: import(
|
|
11
|
-
}
|
|
12
|
-
}
|
|
9
|
+
service: import("../gitpod-service").GitpodService;
|
|
10
|
+
ideService?: import("../ide-frontend-service").IDEFrontendService;
|
|
11
|
+
};
|
|
12
|
+
}
|
package/src/util/analytics.ts
CHANGED
|
@@ -6,8 +6,7 @@
|
|
|
6
6
|
|
|
7
7
|
import Analytics = require("analytics-node");
|
|
8
8
|
import { IAnalyticsWriter, IdentifyMessage, TrackMessage, PageMessage } from "../analytics";
|
|
9
|
-
import { log } from
|
|
10
|
-
|
|
9
|
+
import { log } from "./logging";
|
|
11
10
|
|
|
12
11
|
export function newAnalyticsWriterFromEnv(): IAnalyticsWriter {
|
|
13
12
|
switch (process.env.GITPOD_ANALYTICS_WRITER) {
|
|
@@ -21,26 +20,28 @@ export function newAnalyticsWriterFromEnv(): IAnalyticsWriter {
|
|
|
21
20
|
}
|
|
22
21
|
|
|
23
22
|
class SegmentAnalyticsWriter implements IAnalyticsWriter {
|
|
24
|
-
|
|
25
23
|
protected readonly analytics: Analytics;
|
|
26
24
|
|
|
27
25
|
constructor(writeKey: string) {
|
|
28
26
|
this.analytics = new Analytics(writeKey);
|
|
29
27
|
}
|
|
30
28
|
|
|
31
|
-
|
|
29
|
+
identify(msg: IdentifyMessage) {
|
|
32
30
|
try {
|
|
33
|
-
this.analytics.identify(
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
31
|
+
this.analytics.identify(
|
|
32
|
+
{
|
|
33
|
+
...msg,
|
|
34
|
+
integrations: {
|
|
35
|
+
All: true,
|
|
36
|
+
Mixpanel: !!msg.userId,
|
|
37
|
+
},
|
|
38
|
+
},
|
|
39
|
+
(err: Error) => {
|
|
40
|
+
if (err) {
|
|
41
|
+
log.warn("analytics.identify failed", err);
|
|
42
|
+
}
|
|
43
|
+
},
|
|
44
|
+
);
|
|
44
45
|
} catch (err) {
|
|
45
46
|
log.warn("analytics.identify failed", err);
|
|
46
47
|
}
|
|
@@ -48,44 +49,48 @@ class SegmentAnalyticsWriter implements IAnalyticsWriter {
|
|
|
48
49
|
|
|
49
50
|
track(msg: TrackMessage) {
|
|
50
51
|
try {
|
|
51
|
-
this.analytics.track(
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
52
|
+
this.analytics.track(
|
|
53
|
+
{
|
|
54
|
+
...msg,
|
|
55
|
+
integrations: {
|
|
56
|
+
All: true,
|
|
57
|
+
Mixpanel: !!msg.userId,
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
(err: Error) => {
|
|
61
|
+
if (err) {
|
|
62
|
+
log.warn("analytics.track failed", err);
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
);
|
|
62
66
|
} catch (err) {
|
|
63
67
|
log.warn("analytics.track failed", err);
|
|
64
68
|
}
|
|
65
69
|
}
|
|
66
70
|
|
|
67
71
|
page(msg: PageMessage) {
|
|
68
|
-
try{
|
|
69
|
-
this.analytics.page(
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
72
|
+
try {
|
|
73
|
+
this.analytics.page(
|
|
74
|
+
{
|
|
75
|
+
...msg,
|
|
76
|
+
integrations: {
|
|
77
|
+
All: true,
|
|
78
|
+
Mixpanel: !!msg.userId,
|
|
79
|
+
},
|
|
80
|
+
},
|
|
81
|
+
(err: Error) => {
|
|
82
|
+
if (err) {
|
|
83
|
+
log.warn("analytics.page failed", err);
|
|
84
|
+
}
|
|
85
|
+
},
|
|
86
|
+
);
|
|
80
87
|
} catch (err) {
|
|
81
88
|
log.warn("analytics.page failed", err);
|
|
82
89
|
}
|
|
83
90
|
}
|
|
84
|
-
|
|
85
91
|
}
|
|
86
92
|
|
|
87
93
|
class LogAnalyticsWriter implements IAnalyticsWriter {
|
|
88
|
-
|
|
89
94
|
identify(msg: IdentifyMessage): void {
|
|
90
95
|
log.debug("analytics identify", msg);
|
|
91
96
|
}
|
|
@@ -95,11 +100,10 @@ class LogAnalyticsWriter implements IAnalyticsWriter {
|
|
|
95
100
|
page(msg: PageMessage): void {
|
|
96
101
|
log.debug("analytics page", msg);
|
|
97
102
|
}
|
|
98
|
-
|
|
99
103
|
}
|
|
100
104
|
|
|
101
105
|
class NoAnalyticsWriter implements IAnalyticsWriter {
|
|
102
106
|
identify(msg: IdentifyMessage): void {}
|
|
103
107
|
track(msg: TrackMessage): void {}
|
|
104
108
|
page(msg: PageMessage): void {}
|
|
105
|
-
}
|
|
109
|
+
}
|
|
@@ -5,8 +5,8 @@
|
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
7
|
// Use asyncIterators with es2015
|
|
8
|
-
if (typeof (Symbol as any).asyncIterator ===
|
|
9
|
-
(Symbol as any).asyncIterator = Symbol.asyncIterator || Symbol(
|
|
8
|
+
if (typeof (Symbol as any).asyncIterator === "undefined") {
|
|
9
|
+
(Symbol as any).asyncIterator = Symbol.asyncIterator || Symbol("asyncIterator");
|
|
10
10
|
}
|
|
11
11
|
|
|
12
12
|
export async function find<T>(it: AsyncIterableIterator<T>, predicate: (value: T) => boolean): Promise<T | undefined> {
|
|
@@ -31,12 +31,11 @@ export interface AsyncCachingIterator<T> extends AsyncIterableIterator<T> {
|
|
|
31
31
|
resetCursor(): void;
|
|
32
32
|
}
|
|
33
33
|
export class AsyncCachingIteratorImpl<T> implements AsyncIterableIterator<T>, AsyncCachingIterator<T> {
|
|
34
|
-
|
|
35
34
|
protected cache: T[] = [];
|
|
36
35
|
protected cursor = 0;
|
|
37
36
|
protected cacheRead = false;
|
|
38
37
|
|
|
39
|
-
constructor(protected readonly iterable: AsyncIterableIterator<T>) {
|
|
38
|
+
constructor(protected readonly iterable: AsyncIterableIterator<T>) {}
|
|
40
39
|
|
|
41
40
|
public resetCursor() {
|
|
42
41
|
this.cursor = 0;
|
|
@@ -47,7 +46,7 @@ export class AsyncCachingIteratorImpl<T> implements AsyncIterableIterator<T>, As
|
|
|
47
46
|
if (!this.cacheRead && this.cursor < this.cache.length) {
|
|
48
47
|
return {
|
|
49
48
|
done: false,
|
|
50
|
-
value: this.cache[this.cursor++]
|
|
49
|
+
value: this.cache[this.cursor++],
|
|
51
50
|
};
|
|
52
51
|
}
|
|
53
52
|
this.cacheRead = true;
|
package/src/util/cancelable.ts
CHANGED
|
@@ -9,10 +9,10 @@ import { Disposable } from "./disposable";
|
|
|
9
9
|
export class Cancelable<T> implements Disposable {
|
|
10
10
|
protected canceled: boolean;
|
|
11
11
|
|
|
12
|
-
constructor(protected readonly activity: (cancel: boolean) => Promise<T> | undefined) {
|
|
12
|
+
constructor(protected readonly activity: (cancel: boolean) => Promise<T> | undefined) {}
|
|
13
13
|
|
|
14
14
|
public async run(): Promise<T | undefined> {
|
|
15
|
-
for(let r = await this.activity(this.canceled); ; r = await this.activity(this.canceled)) {
|
|
15
|
+
for (let r = await this.activity(this.canceled); ; r = await this.activity(this.canceled)) {
|
|
16
16
|
if (this.canceled) {
|
|
17
17
|
return;
|
|
18
18
|
} else if (r !== undefined) {
|
|
@@ -28,4 +28,4 @@ export class Cancelable<T> implements Disposable {
|
|
|
28
28
|
dispose(): void {
|
|
29
29
|
this.cancel();
|
|
30
30
|
}
|
|
31
|
-
}
|
|
31
|
+
}
|
package/src/util/date-time.ts
CHANGED
|
@@ -5,26 +5,26 @@
|
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
7
|
export function formatDate(date?: string) {
|
|
8
|
-
return date ? new Date(date).toLocaleString() :
|
|
8
|
+
return date ? new Date(date).toLocaleString() : "";
|
|
9
9
|
}
|
|
10
10
|
|
|
11
11
|
export function formatHours(hours?: number) {
|
|
12
12
|
if (hours === undefined) {
|
|
13
|
-
return
|
|
13
|
+
return "";
|
|
14
14
|
}
|
|
15
15
|
const h = Math.floor(Math.abs(hours));
|
|
16
|
-
const rm = (Math.abs(hours) - h) * 60
|
|
16
|
+
const rm = (Math.abs(hours) - h) * 60;
|
|
17
17
|
const m = Math.floor(rm);
|
|
18
|
-
const rs = (rm - m) * 60
|
|
18
|
+
const rs = (rm - m) * 60;
|
|
19
19
|
const s = Math.floor(rs);
|
|
20
|
-
const result = h +
|
|
20
|
+
const result = h + ":" + pad2(m) + ":" + pad2(s);
|
|
21
21
|
if (hours < 0) {
|
|
22
|
-
return `-${result}
|
|
22
|
+
return `-${result}`;
|
|
23
23
|
} else {
|
|
24
|
-
return `${result}
|
|
24
|
+
return `${result}`;
|
|
25
25
|
}
|
|
26
26
|
}
|
|
27
27
|
|
|
28
28
|
function pad2(n: number) {
|
|
29
|
-
return n
|
|
29
|
+
return n < 10 ? "0" + n : "" + n;
|
|
30
30
|
}
|
package/src/util/deferred.ts
CHANGED
|
@@ -19,12 +19,12 @@ export class Deferred<T> {
|
|
|
19
19
|
promise = new Promise<T>((resolve, reject) => {
|
|
20
20
|
this.resolve = (o) => {
|
|
21
21
|
this.isResolved = true;
|
|
22
|
-
resolve(o as any)
|
|
23
|
-
clearTimeout(this.timer)
|
|
22
|
+
resolve(o as any);
|
|
23
|
+
clearTimeout(this.timer);
|
|
24
24
|
};
|
|
25
25
|
this.reject = (e) => {
|
|
26
|
-
reject(e)
|
|
27
|
-
clearTimeout(this.timer)
|
|
28
|
-
}
|
|
26
|
+
reject(e);
|
|
27
|
+
clearTimeout(this.timer);
|
|
28
|
+
};
|
|
29
29
|
});
|
|
30
|
-
}
|
|
30
|
+
}
|
package/src/util/disposable.ts
CHANGED
|
@@ -16,10 +16,10 @@ export interface Disposable {
|
|
|
16
16
|
export namespace Disposable {
|
|
17
17
|
export function create(func: () => void): Disposable {
|
|
18
18
|
return {
|
|
19
|
-
dispose: func
|
|
19
|
+
dispose: func,
|
|
20
20
|
};
|
|
21
21
|
}
|
|
22
|
-
export const NULL = create(() => {
|
|
22
|
+
export const NULL = create(() => {});
|
|
23
23
|
}
|
|
24
24
|
|
|
25
25
|
export class DisposableCollection implements Disposable {
|
|
@@ -69,9 +69,6 @@ export class DisposableCollection implements Disposable {
|
|
|
69
69
|
}
|
|
70
70
|
|
|
71
71
|
pushAll(disposables: Disposable[]): Disposable[] {
|
|
72
|
-
return disposables.map(disposable =>
|
|
73
|
-
this.push(disposable)
|
|
74
|
-
);
|
|
72
|
+
return disposables.map((disposable) => this.push(disposable));
|
|
75
73
|
}
|
|
76
|
-
|
|
77
74
|
}
|
package/src/util/event.ts
CHANGED
|
@@ -6,13 +6,12 @@
|
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
8
|
import { Disposable } from "./disposable";
|
|
9
|
-
import { log } from
|
|
9
|
+
import { log } from "./logging";
|
|
10
10
|
|
|
11
11
|
/**
|
|
12
12
|
* Represents a typed event.
|
|
13
13
|
*/
|
|
14
14
|
export interface Event<T> {
|
|
15
|
-
|
|
16
15
|
/**
|
|
17
16
|
*
|
|
18
17
|
* @param listener The listener function will be call when the event happens.
|
|
@@ -24,12 +23,13 @@ export interface Event<T> {
|
|
|
24
23
|
}
|
|
25
24
|
|
|
26
25
|
export namespace Event {
|
|
27
|
-
const _disposable = { dispose() {
|
|
28
|
-
export const None: Event<any> = function () {
|
|
26
|
+
const _disposable = { dispose() {} };
|
|
27
|
+
export const None: Event<any> = function () {
|
|
28
|
+
return _disposable;
|
|
29
|
+
};
|
|
29
30
|
}
|
|
30
31
|
|
|
31
32
|
class CallbackList {
|
|
32
|
-
|
|
33
33
|
private _callbacks: Function[] | undefined;
|
|
34
34
|
private _contexts: any[] | undefined;
|
|
35
35
|
|
|
@@ -66,7 +66,7 @@ class CallbackList {
|
|
|
66
66
|
}
|
|
67
67
|
|
|
68
68
|
if (foundCallbackWithDifferentContext) {
|
|
69
|
-
throw new Error(
|
|
69
|
+
throw new Error("When adding a listener with a context, you should remove it with the same context");
|
|
70
70
|
}
|
|
71
71
|
}
|
|
72
72
|
|
|
@@ -105,14 +105,12 @@ export interface EmitterOptions {
|
|
|
105
105
|
}
|
|
106
106
|
|
|
107
107
|
export class Emitter<T> {
|
|
108
|
-
|
|
109
|
-
private static _noop = function () { };
|
|
108
|
+
private static _noop = function () {};
|
|
110
109
|
|
|
111
110
|
private _event: Event<T>;
|
|
112
111
|
private _callbacks: CallbackList | undefined;
|
|
113
112
|
|
|
114
|
-
constructor(private _options?: EmitterOptions) {
|
|
115
|
-
}
|
|
113
|
+
constructor(private _options?: EmitterOptions) {}
|
|
116
114
|
|
|
117
115
|
/**
|
|
118
116
|
* For the public to allow to subscribe
|
|
@@ -137,7 +135,7 @@ export class Emitter<T> {
|
|
|
137
135
|
if (this._options && this._options.onLastListenerRemove && this._callbacks!.isEmpty()) {
|
|
138
136
|
this._options.onLastListenerRemove(this);
|
|
139
137
|
}
|
|
140
|
-
}
|
|
138
|
+
},
|
|
141
139
|
};
|
|
142
140
|
if (Array.isArray(disposables)) {
|
|
143
141
|
disposables.push(result);
|
|
@@ -6,7 +6,6 @@
|
|
|
6
6
|
|
|
7
7
|
import { repeat } from "./repeat";
|
|
8
8
|
|
|
9
|
-
|
|
10
9
|
interface CacheEntry<T> {
|
|
11
10
|
key: string;
|
|
12
11
|
value: T;
|
|
@@ -16,9 +15,7 @@ interface CacheEntry<T> {
|
|
|
16
15
|
export class GarbageCollectedCache<T> {
|
|
17
16
|
protected readonly store = new Map<string, CacheEntry<T>>();
|
|
18
17
|
|
|
19
|
-
constructor(
|
|
20
|
-
protected readonly defaultMaxAgeSeconds: number,
|
|
21
|
-
protected readonly gcIntervalSeconds: number) {
|
|
18
|
+
constructor(protected readonly defaultMaxAgeSeconds: number, protected readonly gcIntervalSeconds: number) {
|
|
22
19
|
this.regularlyCollectGarbage();
|
|
23
20
|
}
|
|
24
21
|
|
|
@@ -61,6 +58,6 @@ export class GarbageCollectedCache<T> {
|
|
|
61
58
|
}
|
|
62
59
|
|
|
63
60
|
protected calcExpiryDate(maxAgeSeconds?: number): number {
|
|
64
|
-
return Date.now() + (
|
|
61
|
+
return Date.now() + (maxAgeSeconds || this.defaultMaxAgeSeconds) * 1000;
|
|
65
62
|
}
|
|
66
|
-
}
|
|
63
|
+
}
|