@gitpod/gitpod-protocol 0.1.5-wth-test.41 → 0.1.5-yh-vmoptions-fork.3
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 +199 -7
- 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 +12 -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/auth.d.ts.map +1 -1
- 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/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 +61 -28
- package/lib/gitpod-service.d.ts.map +1 -1
- package/lib/gitpod-service.js +43 -34
- 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 +105 -0
- package/lib/ide-protocol.d.ts.map +1 -0
- package/lib/ide-protocol.js +8 -0
- package/lib/ide-protocol.js.map +1 -0
- package/lib/index.d.ts +16 -14
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +2 -0
- package/lib/index.js.map +1 -1
- package/lib/installation-admin-protocol.d.ts +27 -0
- package/lib/installation-admin-protocol.d.ts.map +1 -0
- package/lib/installation-admin-protocol.js +30 -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 -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 +3 -0
- package/lib/messaging/error.d.ts.map +1 -1
- package/lib/messaging/error.js +6 -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.d.ts +1 -17
- package/lib/messaging/node/connection.d.ts.map +1 -1
- package/lib/messaging/node/connection.js +23 -59
- 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/oss-allowlist.d.ts +14 -0
- package/lib/oss-allowlist.d.ts.map +1 -0
- package/lib/oss-allowlist.js +8 -0
- package/lib/oss-allowlist.js.map +1 -0
- 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 +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 +109 -74
- package/lib/protocol.d.ts.map +1 -1
- package/lib/protocol.js +177 -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 +17 -2
- 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/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/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 +1 -0
- package/lib/util/garbage-collected-cache.d.ts.map +1 -1
- package/lib/util/garbage-collected-cache.js +6 -2
- package/lib/util/garbage-collected-cache.js.map +1 -1
- package/lib/util/generate-workspace-id.d.ts +6 -1
- package/lib/util/generate-workspace-id.d.ts.map +1 -1
- package/lib/util/generate-workspace-id.js +461 -440
- package/lib/util/generate-workspace-id.js.map +1 -1
- package/lib/util/generate-workspace-id.spec.js +36 -1
- 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 +0 -1
- package/lib/util/gitpod-host-url.d.ts.map +1 -1
- package/lib/util/gitpod-host-url.js +34 -35
- 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 +68 -0
- package/lib/util/jaeger-client-types.d.ts.map +1 -0
- package/lib/{theia-plugins.js → util/jaeger-client-types.js} +1 -1
- package/lib/util/jaeger-client-types.js.map +1 -0
- 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 +2 -3
- 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/repeat.d.ts +15 -0
- package/lib/util/repeat.d.ts.map +1 -0
- package/lib/util/repeat.js +55 -0
- package/lib/util/repeat.js.map +1 -0
- 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 +52 -6
- package/lib/util/tracing.d.ts.map +1 -1
- package/lib/util/tracing.js +156 -19
- package/lib/util/tracing.js.map +1 -1
- package/lib/util/tracing.spec.d.ts +7 -0
- package/lib/util/tracing.spec.d.ts.map +1 -0
- package/lib/util/tracing.spec.js +121 -0
- package/lib/util/tracing.spec.js.map +1 -0
- 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 +10 -8
- 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 +38 -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 +10 -8
- package/pkg-yarn.lock +6 -6
- package/provenance-bundle.jsonl +2 -0
- package/src/accounting-protocol.ts +63 -51
- package/src/admin-protocol.ts +35 -18
- package/src/analytics.ts +26 -28
- package/src/auth.ts +2 -2
- package/src/context-url.spec.ts +37 -9
- package/src/context-url.ts +94 -36
- 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 +185 -112
- package/src/headless-workspace-log.ts +6 -4
- package/src/ide-frontend-service.ts +2 -2
- package/src/ide-protocol.ts +119 -0
- package/src/index.ts +16 -14
- package/src/installation-admin-protocol.ts +42 -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 +70 -71
- package/src/messaging/error.ts +10 -3
- package/src/messaging/handler.ts +6 -6
- package/src/messaging/node/connection.ts +23 -70
- package/src/messaging/proxy-factory.ts +23 -30
- package/src/oss-allowlist.ts +15 -0
- package/src/payment-protocol.ts +2 -2
- package/src/permission.ts +40 -32
- package/src/plans.ts +236 -189
- package/src/protocol.ts +383 -275
- package/src/snapshot-url.spec.ts +9 -7
- package/src/team-subscription-protocol.ts +57 -23
- package/src/teams-projects-protocol.ts +29 -8
- package/src/typings/globals.ts +4 -4
- 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/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 +9 -6
- package/src/util/generate-workspace-id.spec.ts +34 -7
- package/src/util/generate-workspace-id.ts +464 -440
- 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 +40 -41
- package/src/util/grpc.ts +1 -1
- package/src/util/jaeger-client-types.ts +102 -0
- 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 +6 -7
- package/src/util/queue.spec.ts +27 -25
- package/src/util/repeat.ts +45 -0
- 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 +88 -0
- package/src/util/tracing.ts +200 -31
- package/src/util/workspace-port-authentication.ts +10 -13
- package/src/workspace-cluster.ts +26 -15
- package/src/workspace-instance.ts +69 -20
- package/src/wsready.ts +3 -3
- package/data/builtin-theia-plugins.json +0 -372
- 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/repeater.d.ts +0 -22
- package/lib/util/repeater.d.ts.map +0 -1
- package/lib/util/repeater.js +0 -65
- package/lib/util/repeater.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/messaging/connection-error-handler.ts +0 -62
- package/src/theia-plugins.ts +0 -11
- package/src/util/jaeger-client.d.ts +0 -105
- package/src/util/repeater.ts +0 -49
- package/src/util/safe-promise.ts +0 -26
package/src/util/timeutil.ts
CHANGED
|
@@ -24,28 +24,38 @@ 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 hoursBefore(date: string, hours: number): string {
|
|
51
|
+
const result = new Date(date);
|
|
52
|
+
result.setHours(result.getHours() - hours);
|
|
53
|
+
return result.toISOString();
|
|
54
|
+
}
|
|
55
|
+
|
|
46
56
|
export function hoursLater(date: string, hours: number): string {
|
|
47
|
-
const result = new Date(date)
|
|
48
|
-
result.setHours(result.getHours() + hours)
|
|
57
|
+
const result = new Date(date);
|
|
58
|
+
result.setHours(result.getHours() + hours);
|
|
49
59
|
return result.toISOString();
|
|
50
60
|
}
|
|
51
61
|
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2021 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
|
+
import { suite, test } from "mocha-typescript";
|
|
8
|
+
import * as chai from "chai";
|
|
9
|
+
import { TraceContext } from "./tracing";
|
|
10
|
+
import { MockTracer } from "opentracing";
|
|
11
|
+
|
|
12
|
+
const expect = chai.expect;
|
|
13
|
+
|
|
14
|
+
@suite
|
|
15
|
+
class TestTracing {
|
|
16
|
+
@test public async testTracingContext_addNestedTags() {
|
|
17
|
+
const tracer = new MockTracer();
|
|
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
|
+
},
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
);
|
|
32
|
+
|
|
33
|
+
const mockSpan = tracer.report().spans[0];
|
|
34
|
+
expect(mockSpan.tags()).to.deep.equal({
|
|
35
|
+
"rpc.system": "jsonrpc",
|
|
36
|
+
"rpc.jsonrpc.version": "1.0",
|
|
37
|
+
"rpc.jsonrpc.method": "test",
|
|
38
|
+
"rpc.jsonrpc.parameters.0": "abc",
|
|
39
|
+
"rpc.jsonrpc.parameters.1": "def",
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
@test public async testTracingContext_addNestedTags_null() {
|
|
44
|
+
const tracer = new MockTracer();
|
|
45
|
+
const span = tracer.startSpan("testTracingContext_addNestedTags_null");
|
|
46
|
+
TraceContext.addNestedTags(
|
|
47
|
+
{ span },
|
|
48
|
+
{
|
|
49
|
+
someShape: {
|
|
50
|
+
thisIsNull: null,
|
|
51
|
+
thisIsUndefined: undefined,
|
|
52
|
+
},
|
|
53
|
+
},
|
|
54
|
+
);
|
|
55
|
+
|
|
56
|
+
const mockSpan = tracer.report().spans[0];
|
|
57
|
+
expect(mockSpan.tags()).to.deep.equal({
|
|
58
|
+
"someShape.thisIsNull": null,
|
|
59
|
+
"someShape.thisIsUndefined": undefined,
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
@test public async testTracingContext_addJsonRPCParameters() {
|
|
64
|
+
const tracer = new MockTracer();
|
|
65
|
+
const span = tracer.startSpan("testTracingContext_addJsonRPCParameters");
|
|
66
|
+
const ctx = { span };
|
|
67
|
+
TraceContext.addJsonRPCParameters(ctx, {
|
|
68
|
+
one: "one",
|
|
69
|
+
two: {
|
|
70
|
+
name: "two",
|
|
71
|
+
some: "shape",
|
|
72
|
+
containing: "PII",
|
|
73
|
+
},
|
|
74
|
+
three: "three",
|
|
75
|
+
});
|
|
76
|
+
|
|
77
|
+
const mockSpan = tracer.report().spans[0];
|
|
78
|
+
expect(mockSpan.tags()).to.deep.equal({
|
|
79
|
+
"rpc.jsonrpc.parameters.one": "one",
|
|
80
|
+
"rpc.jsonrpc.parameters.two.containing": "PII",
|
|
81
|
+
"rpc.jsonrpc.parameters.two.name": "two",
|
|
82
|
+
"rpc.jsonrpc.parameters.two.some": "shape",
|
|
83
|
+
"rpc.jsonrpc.parameters.three": "three",
|
|
84
|
+
"rpc.system": "jsonrpc",
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
module.exports = new TestTracing();
|
package/src/util/tracing.ts
CHANGED
|
@@ -4,48 +4,192 @@
|
|
|
4
4
|
* See License-AGPL.txt in the project root for license information.
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
|
|
8
|
-
import
|
|
9
|
-
import {
|
|
10
|
-
import { initGlobalTracer } from
|
|
11
|
-
import { injectable } from
|
|
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";
|
|
12
14
|
|
|
13
15
|
export interface TraceContext {
|
|
14
|
-
span?: opentracing.Span
|
|
16
|
+
span?: opentracing.Span;
|
|
15
17
|
}
|
|
18
|
+
export type TraceContextWithSpan = TraceContext & {
|
|
19
|
+
span: opentracing.Span;
|
|
20
|
+
};
|
|
16
21
|
|
|
17
22
|
export namespace TraceContext {
|
|
18
|
-
export function startSpan(operation: string,
|
|
19
|
-
const options: opentracing.SpanOptions = {
|
|
20
|
-
|
|
23
|
+
export function startSpan(operation: string, parentCtx?: TraceContext): opentracing.Span {
|
|
24
|
+
const options: opentracing.SpanOptions = {};
|
|
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
|
+
}
|
|
21
33
|
}
|
|
34
|
+
|
|
22
35
|
return opentracing.globalTracer().startSpan(operation, options);
|
|
23
36
|
}
|
|
24
37
|
|
|
25
|
-
export function
|
|
26
|
-
const
|
|
27
|
-
|
|
28
|
-
|
|
38
|
+
export function childContext(operation: string, parentCtx: TraceContext): TraceContextWithSpan {
|
|
39
|
+
const span = startSpan(operation, parentCtx);
|
|
40
|
+
return { span };
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export function withSpan(operation: string, callback: (ctx: TraceContext) => void, ctx?: TraceContext): void {
|
|
44
|
+
// if we don't have a parent span, don't create a trace here as those <trace-without-root-spans> are not useful.
|
|
45
|
+
if (!ctx || !ctx.span || !ctx.span.context()) {
|
|
46
|
+
callback({});
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
const span = TraceContext.startSpan(operation, ctx);
|
|
51
|
+
try {
|
|
52
|
+
callback({ span });
|
|
53
|
+
} catch (e) {
|
|
54
|
+
TraceContext.setError({ span }, e);
|
|
55
|
+
throw e;
|
|
56
|
+
} finally {
|
|
57
|
+
span.finish();
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
export function setError(ctx: TraceContext, err: Error) {
|
|
62
|
+
if (!ctx.span) {
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
TraceContext.addNestedTags(ctx, {
|
|
67
|
+
error: {
|
|
68
|
+
message: err.message,
|
|
69
|
+
stacktrace: err.stack,
|
|
70
|
+
},
|
|
71
|
+
});
|
|
72
|
+
ctx.span.setTag("error", true);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
export function setJsonRPCMetadata(ctx: TraceContext, method?: string) {
|
|
76
|
+
if (!ctx.span) {
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
const tags: { [key: string]: any } = {
|
|
81
|
+
rpc: {
|
|
82
|
+
system: "jsonrpc",
|
|
83
|
+
// version,
|
|
84
|
+
},
|
|
85
|
+
};
|
|
86
|
+
if (method) {
|
|
87
|
+
tags.rpc.method = method;
|
|
88
|
+
}
|
|
89
|
+
addNestedTags(ctx, tags);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
export function setJsonRPCError(
|
|
93
|
+
ctx: TraceContext,
|
|
94
|
+
method: string,
|
|
95
|
+
err: ResponseError<any>,
|
|
96
|
+
withStatusCode: boolean = false,
|
|
97
|
+
) {
|
|
98
|
+
if (!ctx.span) {
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
// not use setError bc this is (most likely) a working operation
|
|
102
|
+
|
|
103
|
+
setJsonRPCMetadata(ctx, method);
|
|
104
|
+
// https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/trace/semantic_conventions/rpc.md#json-rpc
|
|
105
|
+
addNestedTags(ctx, {
|
|
106
|
+
rpc: {
|
|
107
|
+
jsonrpc: {
|
|
108
|
+
error_code: err.code,
|
|
109
|
+
error_message: err.message,
|
|
110
|
+
},
|
|
111
|
+
},
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
// the field "status_code" is used by honeycomb to derive insights like success rate, etc. Defaults to "0".
|
|
115
|
+
if (withStatusCode) {
|
|
116
|
+
ctx.span.setTag("status_code", err.code);
|
|
29
117
|
}
|
|
30
|
-
return opentracing.globalTracer().startSpan(operation, options);
|
|
31
118
|
}
|
|
32
119
|
|
|
33
|
-
export function
|
|
120
|
+
export function addJsonRPCParameters(ctx: TraceContext, params: { [key: string]: any }) {
|
|
34
121
|
if (!ctx.span) {
|
|
35
122
|
return;
|
|
36
123
|
}
|
|
37
124
|
|
|
38
|
-
ctx
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
125
|
+
setJsonRPCMetadata(ctx);
|
|
126
|
+
addNestedTags(ctx, {
|
|
127
|
+
rpc: {
|
|
128
|
+
jsonrpc: {
|
|
129
|
+
parameters: params,
|
|
130
|
+
},
|
|
131
|
+
},
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
/**
|
|
136
|
+
* Does what one would expect from `span.addTags`: Calls `span.addTag` for all keys in map, recursively for objects.
|
|
137
|
+
* Example:
|
|
138
|
+
* ```
|
|
139
|
+
* TraceContext.addNestedTags(ctx, {
|
|
140
|
+
* rpc: {
|
|
141
|
+
* system: "jsonrpc",
|
|
142
|
+
* jsonrpc: {
|
|
143
|
+
* version: "1.0",
|
|
144
|
+
* method: "test",
|
|
145
|
+
* parameters: ["abc", "def"],
|
|
146
|
+
* },
|
|
147
|
+
* },
|
|
148
|
+
* });
|
|
149
|
+
* ```
|
|
150
|
+
* gives
|
|
151
|
+
* rpc.system = "jsonrpc"
|
|
152
|
+
* rpc.jsonrpc.version = "1.0"
|
|
153
|
+
* rpc.jsonrpc.method = "test"
|
|
154
|
+
* rpc.jsonrpc.parameters.0 = "abc"
|
|
155
|
+
* rpc.jsonrpc.parameters.1 = "def"
|
|
156
|
+
* @param ctx
|
|
157
|
+
* @param keyValueMap
|
|
158
|
+
* @returns
|
|
159
|
+
*/
|
|
160
|
+
export function addNestedTags(ctx: TraceContext, keyValueMap: { [key: string]: any }, _namespace?: string) {
|
|
161
|
+
if (!ctx.span) {
|
|
162
|
+
return;
|
|
163
|
+
}
|
|
164
|
+
const namespace = _namespace ? `${_namespace}.` : "";
|
|
165
|
+
|
|
166
|
+
try {
|
|
167
|
+
for (const k of Object.keys(keyValueMap)) {
|
|
168
|
+
const v = keyValueMap[k];
|
|
169
|
+
if (v instanceof Object) {
|
|
170
|
+
addNestedTags(ctx, v, `${namespace}${k}`);
|
|
171
|
+
} else {
|
|
172
|
+
ctx.span.setTag(`${namespace}${k}`, v);
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
} catch (err) {
|
|
176
|
+
// general resilience against odd shapes/parameters
|
|
177
|
+
log.error("Tracing.addNestedTags", err, { namespace });
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
export function setOWI(ctx: TraceContext, owi: LogContext) {
|
|
182
|
+
if (!ctx.span) {
|
|
183
|
+
return;
|
|
184
|
+
}
|
|
185
|
+
addNestedTags(ctx, {
|
|
186
|
+
context: owi,
|
|
187
|
+
});
|
|
43
188
|
}
|
|
44
189
|
}
|
|
45
190
|
|
|
46
191
|
@injectable()
|
|
47
192
|
export class TracingManager {
|
|
48
|
-
|
|
49
193
|
public setup(serviceName: string, opts?: CustomTracerOpts) {
|
|
50
194
|
initGlobalTracer(this.getTracerForService(serviceName, opts));
|
|
51
195
|
}
|
|
@@ -54,13 +198,18 @@ export class TracingManager {
|
|
|
54
198
|
const config: TracingConfig = {
|
|
55
199
|
disable: false,
|
|
56
200
|
reporter: {
|
|
57
|
-
logSpans: false
|
|
201
|
+
logSpans: false,
|
|
58
202
|
},
|
|
59
|
-
serviceName
|
|
60
|
-
}
|
|
203
|
+
serviceName,
|
|
204
|
+
};
|
|
61
205
|
const t = initTracerFromEnv(config, {
|
|
62
|
-
logger: console
|
|
206
|
+
logger: console,
|
|
207
|
+
tags: {
|
|
208
|
+
"service.build.commit": process.env.GITPOD_BUILD_GIT_COMMIT,
|
|
209
|
+
"service.build.version": process.env.GITPOD_BUILD_VERSION,
|
|
210
|
+
},
|
|
63
211
|
});
|
|
212
|
+
|
|
64
213
|
if (opts) {
|
|
65
214
|
if (opts.perOpSampling) {
|
|
66
215
|
(t as any)._sampler = new PerOperationSampler((t as any)._sampler, opts.perOpSampling);
|
|
@@ -68,24 +217,22 @@ export class TracingManager {
|
|
|
68
217
|
}
|
|
69
218
|
return t;
|
|
70
219
|
}
|
|
71
|
-
|
|
72
220
|
}
|
|
73
221
|
|
|
74
222
|
export interface CustomTracerOpts {
|
|
75
|
-
perOpSampling?: PerOperationSampling
|
|
223
|
+
perOpSampling?: PerOperationSampling;
|
|
76
224
|
}
|
|
77
225
|
|
|
78
|
-
|
|
79
226
|
// has to conform to https://github.com/jaegertracing/jaeger-client-node/blob/0042b1c0a0796bb655eb93e77ff76ab5e94c2bb6/src/_flow/sampler-thrift.js#L32
|
|
80
227
|
export interface PerOperationSampling {
|
|
81
|
-
[key: string]: boolean
|
|
228
|
+
[key: string]: boolean;
|
|
82
229
|
}
|
|
83
230
|
|
|
84
231
|
export class PerOperationSampler implements Sampler {
|
|
85
232
|
constructor(protected readonly fallback: Sampler, protected readonly strategies: PerOperationSampling) {}
|
|
86
233
|
|
|
87
234
|
name(): string {
|
|
88
|
-
return
|
|
235
|
+
return "PerOperationSampler";
|
|
89
236
|
}
|
|
90
237
|
|
|
91
238
|
toString(): string {
|
|
@@ -125,10 +272,32 @@ export class PerOperationSampler implements Sampler {
|
|
|
125
272
|
return false; // TODO equal should be removed
|
|
126
273
|
}
|
|
127
274
|
|
|
128
|
-
close(callback: ()=>void): void {
|
|
275
|
+
close(callback: () => void): void {
|
|
129
276
|
// all nested samplers are of simple types, so we do not need to Close them
|
|
130
277
|
if (callback) {
|
|
131
278
|
callback();
|
|
132
279
|
}
|
|
133
280
|
}
|
|
134
281
|
}
|
|
282
|
+
|
|
283
|
+
// Augment interfaces with an leading parameter "TraceContext" on every method
|
|
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;
|
|
300
|
+
|
|
301
|
+
export type InterfaceWithTraceContext<T> = {
|
|
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
|
+
};
|
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.
|
|
@@ -35,9 +35,6 @@ export interface WorkspaceCluster {
|
|
|
35
35
|
|
|
36
36
|
// An optional set of constraints that limit who can start workspaces on the cluster
|
|
37
37
|
admissionConstraints?: AdmissionConstraint[];
|
|
38
|
-
|
|
39
|
-
// An optional set of admission preferences that guide cluster selection
|
|
40
|
-
admissionPreferences?: AdmissionPreference[];
|
|
41
38
|
}
|
|
42
39
|
|
|
43
40
|
export type WorkspaceClusterState = "available" | "cordoned" | "draining";
|
|
@@ -50,19 +47,33 @@ export interface TLSConfig {
|
|
|
50
47
|
crt: string;
|
|
51
48
|
}
|
|
52
49
|
export namespace TLSConfig {
|
|
53
|
-
export const loadFromBase64File = (path: string): string =>
|
|
50
|
+
export const loadFromBase64File = (path: string): string =>
|
|
51
|
+
fs.readFileSync(filePathTelepresenceAware(path)).toString("base64");
|
|
54
52
|
}
|
|
55
53
|
export type WorkspaceClusterWoTLS = Omit<WorkspaceCluster, "tls">;
|
|
56
54
|
export type WorkspaceManagerConnectionInfo = Pick<WorkspaceCluster, "name" | "url" | "tls">;
|
|
57
55
|
|
|
58
|
-
export type AdmissionConstraint =
|
|
56
|
+
export type AdmissionConstraint =
|
|
57
|
+
| AdmissionConstraintFeaturePreview
|
|
58
|
+
| AdmissionConstraintHasPermission
|
|
59
|
+
| AdmissionConstraintHasUserLevel
|
|
60
|
+
| AdmissionConstraintHasMoreResources;
|
|
59
61
|
export type AdmissionConstraintFeaturePreview = { type: "has-feature-preview" };
|
|
60
|
-
export type
|
|
61
|
-
export type AdmissionConstraintHasUserLevel = { type: "has-user-level"
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
export
|
|
65
|
-
|
|
62
|
+
export type AdmissionConstraintHasPermission = { type: "has-permission"; permission: PermissionName };
|
|
63
|
+
export type AdmissionConstraintHasUserLevel = { type: "has-user-level"; level: string };
|
|
64
|
+
export type AdmissionConstraintHasMoreResources = { type: "has-more-resources" };
|
|
65
|
+
|
|
66
|
+
export namespace AdmissionConstraint {
|
|
67
|
+
export function is(o: any): o is AdmissionConstraint {
|
|
68
|
+
return !!o && "type" in o;
|
|
69
|
+
}
|
|
70
|
+
export function isHasPermissionConstraint(o: any): o is AdmissionConstraintHasPermission {
|
|
71
|
+
return is(o) && o.type === "has-permission";
|
|
72
|
+
}
|
|
73
|
+
export function hasPermission(ac: AdmissionConstraint, permission: PermissionName): boolean {
|
|
74
|
+
return isHasPermissionConstraint(ac) && ac.permission === permission;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
66
77
|
|
|
67
78
|
export const WorkspaceClusterDB = Symbol("WorkspaceClusterDB");
|
|
68
79
|
export interface WorkspaceClusterDB {
|
|
@@ -93,4 +104,4 @@ export interface WorkspaceClusterDB {
|
|
|
93
104
|
}
|
|
94
105
|
export interface WorkspaceClusterFilter extends Pick<WorkspaceCluster, "state" | "govern" | "url"> {
|
|
95
106
|
minScore: number;
|
|
96
|
-
}
|
|
107
|
+
}
|