@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
|
@@ -7,16 +7,16 @@
|
|
|
7
7
|
import { injectable, inject } from "inversify";
|
|
8
8
|
|
|
9
9
|
export interface KeyMetadata {
|
|
10
|
-
name: string
|
|
11
|
-
version: number
|
|
10
|
+
name: string;
|
|
11
|
+
version: number;
|
|
12
12
|
}
|
|
13
13
|
|
|
14
14
|
export interface Key {
|
|
15
|
-
metadata: KeyMetadata
|
|
16
|
-
material: Buffer
|
|
15
|
+
metadata: KeyMetadata;
|
|
16
|
+
material: Buffer;
|
|
17
17
|
}
|
|
18
18
|
|
|
19
|
-
export const KeyProvider = Symbol(
|
|
19
|
+
export const KeyProvider = Symbol("KeyProvider");
|
|
20
20
|
export interface KeyProvider {
|
|
21
21
|
getPrimaryKey(): Key;
|
|
22
22
|
getKeyFor(metadata: KeyMetadata): Key;
|
|
@@ -24,24 +24,21 @@ export interface KeyProvider {
|
|
|
24
24
|
|
|
25
25
|
export type KeyConfig = KeyMetadata & {
|
|
26
26
|
/** base64 encoded */
|
|
27
|
-
material: string
|
|
28
|
-
primary?: boolean
|
|
29
|
-
}
|
|
27
|
+
material: string;
|
|
28
|
+
primary?: boolean;
|
|
29
|
+
};
|
|
30
30
|
|
|
31
|
-
export const KeyProviderConfig = Symbol(
|
|
31
|
+
export const KeyProviderConfig = Symbol("KeyProviderConfig");
|
|
32
32
|
export interface KeyProviderConfig {
|
|
33
|
-
keys: KeyConfig[]
|
|
33
|
+
keys: KeyConfig[];
|
|
34
34
|
}
|
|
35
35
|
|
|
36
36
|
@injectable()
|
|
37
37
|
export class KeyProviderImpl implements KeyProvider {
|
|
38
|
-
|
|
39
38
|
static loadKeyConfigFromJsonString(configStr: string): KeyConfig[] {
|
|
40
39
|
const keys = (JSON.parse(configStr) || []) as KeyConfig[];
|
|
41
|
-
if (!Array.isArray(keys)
|
|
42
|
-
|
|
43
|
-
|| 1 !== keys.reduce((p, k) => k.primary ? p + 1 : p, 0)) {
|
|
44
|
-
throw new Error('Invalid key config!');
|
|
40
|
+
if (!Array.isArray(keys) || keys.length < 0 || 1 !== keys.reduce((p, k) => (k.primary ? p + 1 : p), 0)) {
|
|
41
|
+
throw new Error("Invalid key config!");
|
|
45
42
|
}
|
|
46
43
|
return keys;
|
|
47
44
|
}
|
|
@@ -49,13 +46,13 @@ export class KeyProviderImpl implements KeyProvider {
|
|
|
49
46
|
constructor(@inject(KeyProviderConfig) protected readonly config: KeyProviderConfig) {}
|
|
50
47
|
|
|
51
48
|
protected get keys() {
|
|
52
|
-
return this.config.keys
|
|
49
|
+
return this.config.keys;
|
|
53
50
|
}
|
|
54
51
|
|
|
55
52
|
getPrimaryKey(): Key {
|
|
56
53
|
const primaryKey = this.keys.find((key) => !!key.primary);
|
|
57
54
|
if (!primaryKey) {
|
|
58
|
-
throw new Error(
|
|
55
|
+
throw new Error("No primary encryption key found!");
|
|
59
56
|
}
|
|
60
57
|
return this.configToKey(primaryKey);
|
|
61
58
|
}
|
|
@@ -72,9 +69,9 @@ export class KeyProviderImpl implements KeyProvider {
|
|
|
72
69
|
return {
|
|
73
70
|
metadata: {
|
|
74
71
|
name: config.name,
|
|
75
|
-
version: config.version
|
|
72
|
+
version: config.version,
|
|
76
73
|
},
|
|
77
|
-
material: new Buffer(config.material,
|
|
74
|
+
material: new Buffer(config.material, "base64"),
|
|
78
75
|
};
|
|
79
76
|
}
|
|
80
77
|
}
|
package/src/env.ts
CHANGED
|
@@ -6,32 +6,10 @@
|
|
|
6
6
|
|
|
7
7
|
import { injectable } from "inversify";
|
|
8
8
|
|
|
9
|
-
const legacyStagenameTranslation: { [key: string]: KubeStage } = {
|
|
10
|
-
"production": "production",
|
|
11
|
-
"staging": "prodcopy",
|
|
12
|
-
"devstaging": "dev",
|
|
13
|
-
"dev": "dev"
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export function translateLegacyStagename(kubeStage: string): KubeStage {
|
|
17
|
-
const stage = legacyStagenameTranslation[kubeStage];
|
|
18
|
-
if (!stage) {
|
|
19
|
-
throw new Error(`Invalid KUBE_STAGE: ${kubeStage}`);
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
return stage;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
9
|
@injectable()
|
|
26
10
|
export abstract class AbstractComponentEnv {
|
|
27
|
-
readonly kubeStage: KubeStage = getEnvVarParsed('KUBE_STAGE', translateLegacyStagename);
|
|
28
|
-
|
|
29
|
-
readonly installationLongname: string = getEnvVar("GITPOD_INSTALLATION_LONGNAME")
|
|
30
|
-
readonly installationShortname: string = getEnvVar("GITPOD_INSTALLATION_SHORTNAME")
|
|
31
11
|
}
|
|
32
12
|
|
|
33
|
-
export type KubeStage = 'production' | 'prodcopy' | 'staging' | 'dev';
|
|
34
|
-
|
|
35
13
|
export function getEnvVar(name: string, defaultValue?: string): string {
|
|
36
14
|
const value = process.env[name] || defaultValue;
|
|
37
15
|
if (!value) {
|
|
@@ -4,19 +4,19 @@
|
|
|
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
|
|
|
10
|
-
import { WorkspaceConfig } from
|
|
11
|
-
import { GitpodFileParser } from
|
|
10
|
+
import { WorkspaceConfig } from "./protocol";
|
|
11
|
+
import { GitpodFileParser } from "./gitpod-file-parser";
|
|
12
12
|
|
|
13
|
-
const expect = chai.expect
|
|
13
|
+
const expect = chai.expect;
|
|
14
14
|
|
|
15
15
|
const DEFAULT_IMAGE = "default-image";
|
|
16
16
|
const DEFAULT_CONFIG = <WorkspaceConfig>{ image: DEFAULT_IMAGE };
|
|
17
17
|
|
|
18
|
-
@suite
|
|
19
|
-
|
|
18
|
+
@suite
|
|
19
|
+
class TestGitpodFileParser {
|
|
20
20
|
protected parser: GitpodFileParser;
|
|
21
21
|
|
|
22
22
|
public before() {
|
|
@@ -24,107 +24,102 @@ const DEFAULT_CONFIG = <WorkspaceConfig>{ image: DEFAULT_IMAGE };
|
|
|
24
24
|
}
|
|
25
25
|
|
|
26
26
|
@test public testOnlyOnePort() {
|
|
27
|
-
const content =
|
|
28
|
-
`ports:\n` +
|
|
29
|
-
` - port: 5555`;
|
|
27
|
+
const content = `ports:\n` + ` - port: 5555`;
|
|
30
28
|
|
|
31
29
|
const result = this.parser.parse(content, {}, DEFAULT_CONFIG);
|
|
32
30
|
expect(result.config).to.deep.equal({
|
|
33
|
-
ports: [
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
31
|
+
ports: [
|
|
32
|
+
{
|
|
33
|
+
port: 5555,
|
|
34
|
+
},
|
|
35
|
+
],
|
|
36
|
+
image: DEFAULT_IMAGE,
|
|
37
37
|
});
|
|
38
38
|
}
|
|
39
39
|
|
|
40
40
|
@test public testPortRange() {
|
|
41
|
-
const content =
|
|
42
|
-
`ports:\n` +
|
|
43
|
-
` - port: 5555\n` +
|
|
44
|
-
` - port: 3000-3999`; // should be filtered out by default
|
|
41
|
+
const content = `ports:\n` + ` - port: 5555\n` + ` - port: 3000-3999`; // should be filtered out by default
|
|
45
42
|
|
|
46
43
|
const result = this.parser.parse(content, {}, DEFAULT_CONFIG);
|
|
47
44
|
expect(result.config).to.deep.equal({
|
|
48
|
-
ports: [
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
45
|
+
ports: [
|
|
46
|
+
{
|
|
47
|
+
port: 5555,
|
|
48
|
+
},
|
|
49
|
+
],
|
|
50
|
+
image: DEFAULT_IMAGE,
|
|
52
51
|
});
|
|
53
52
|
}
|
|
54
53
|
|
|
55
54
|
@test public testPortRangeAccepted() {
|
|
56
|
-
const content =
|
|
57
|
-
`ports:\n` +
|
|
58
|
-
` - port: 5555\n` +
|
|
59
|
-
` - port: 3000-3999`; // should be included if explicitly supported
|
|
55
|
+
const content = `ports:\n` + ` - port: 5555\n` + ` - port: 3000-3999`; // should be included if explicitly supported
|
|
60
56
|
|
|
61
57
|
const result = this.parser.parse(content, { acceptPortRanges: true }, DEFAULT_CONFIG);
|
|
62
58
|
expect(result.config).to.deep.equal({
|
|
63
|
-
ports: [
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
59
|
+
ports: [
|
|
60
|
+
{
|
|
61
|
+
port: 5555,
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
port: "3000-3999",
|
|
65
|
+
},
|
|
66
|
+
],
|
|
67
|
+
image: DEFAULT_IMAGE,
|
|
69
68
|
});
|
|
70
69
|
}
|
|
71
70
|
|
|
72
71
|
@test public testSimpleTask() {
|
|
73
|
-
const content =
|
|
74
|
-
`tasks:\n` +
|
|
75
|
-
` - command: yarn`;
|
|
72
|
+
const content = `tasks:\n` + ` - command: yarn`;
|
|
76
73
|
|
|
77
74
|
const result = this.parser.parse(content, {}, DEFAULT_CONFIG);
|
|
78
75
|
expect(result.config).to.deep.equal({
|
|
79
|
-
tasks: [
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
76
|
+
tasks: [
|
|
77
|
+
{
|
|
78
|
+
command: "yarn",
|
|
79
|
+
},
|
|
80
|
+
],
|
|
81
|
+
image: DEFAULT_IMAGE,
|
|
83
82
|
});
|
|
84
83
|
}
|
|
85
84
|
|
|
86
85
|
@test public testSimpleImage() {
|
|
87
86
|
const imageName = "my-test-org/my-test-image:some-tag";
|
|
88
|
-
const content =
|
|
89
|
-
`image: "${imageName}"\n`;
|
|
87
|
+
const content = `image: "${imageName}"\n`;
|
|
90
88
|
|
|
91
89
|
const result = this.parser.parse(content);
|
|
92
90
|
expect(result.config).to.deep.equal({
|
|
93
|
-
image: imageName
|
|
91
|
+
image: imageName,
|
|
94
92
|
});
|
|
95
93
|
}
|
|
96
94
|
|
|
97
95
|
@test public testComplexImageWithoutContext() {
|
|
98
|
-
const dockerFileName =
|
|
99
|
-
const content =
|
|
100
|
-
`image:\n file: ${dockerFileName}\n`;
|
|
96
|
+
const dockerFileName = "Dockerfile";
|
|
97
|
+
const content = `image:\n file: ${dockerFileName}\n`;
|
|
101
98
|
|
|
102
99
|
const result = this.parser.parse(content);
|
|
103
100
|
expect(result.config).to.deep.equal({
|
|
104
101
|
image: {
|
|
105
|
-
file: dockerFileName
|
|
106
|
-
}
|
|
102
|
+
file: dockerFileName,
|
|
103
|
+
},
|
|
107
104
|
});
|
|
108
105
|
}
|
|
109
106
|
|
|
110
107
|
@test public testComplexImageWithContext() {
|
|
111
|
-
const dockerFileName =
|
|
112
|
-
const dockerContext =
|
|
113
|
-
const content =
|
|
114
|
-
`image:\n file: ${dockerFileName}\n context: ${dockerContext}\n`;
|
|
108
|
+
const dockerFileName = "Dockerfile";
|
|
109
|
+
const dockerContext = "docker";
|
|
110
|
+
const content = `image:\n file: ${dockerFileName}\n context: ${dockerContext}\n`;
|
|
115
111
|
|
|
116
112
|
const result = this.parser.parse(content);
|
|
117
113
|
expect(result.config).to.deep.equal({
|
|
118
114
|
image: {
|
|
119
115
|
file: dockerFileName,
|
|
120
|
-
context: dockerContext
|
|
121
|
-
}
|
|
116
|
+
context: dockerContext,
|
|
117
|
+
},
|
|
122
118
|
});
|
|
123
119
|
}
|
|
124
120
|
|
|
125
121
|
@test public testGitconfig() {
|
|
126
|
-
const content =
|
|
127
|
-
`
|
|
122
|
+
const content = `
|
|
128
123
|
gitConfig:
|
|
129
124
|
core.autocrlf: input
|
|
130
125
|
`;
|
|
@@ -132,20 +127,19 @@ gitConfig:
|
|
|
132
127
|
const result = this.parser.parse(content, {}, DEFAULT_CONFIG);
|
|
133
128
|
expect(result.config).to.deep.equal({
|
|
134
129
|
gitConfig: {
|
|
135
|
-
"core.autocrlf": "input"
|
|
130
|
+
"core.autocrlf": "input",
|
|
136
131
|
},
|
|
137
|
-
image: DEFAULT_IMAGE
|
|
132
|
+
image: DEFAULT_IMAGE,
|
|
138
133
|
});
|
|
139
134
|
}
|
|
140
135
|
|
|
141
136
|
@test public testBrokenConfig() {
|
|
142
|
-
const content =
|
|
143
|
-
`image: 42\n`;
|
|
137
|
+
const content = `image: 42\n`;
|
|
144
138
|
|
|
145
139
|
const result = this.parser.parse(content, {}, DEFAULT_CONFIG);
|
|
146
140
|
expect(result.config).to.deep.equal({
|
|
147
|
-
image: DEFAULT_IMAGE
|
|
141
|
+
image: DEFAULT_IMAGE,
|
|
148
142
|
});
|
|
149
143
|
}
|
|
150
144
|
}
|
|
151
|
-
module.exports = new TestGitpodFileParser()
|
|
145
|
+
module.exports = new TestGitpodFileParser(); // Only to circumvent no usage warning :-/
|
|
@@ -7,40 +7,39 @@
|
|
|
7
7
|
import { injectable } from "inversify";
|
|
8
8
|
import * as yaml from "js-yaml";
|
|
9
9
|
import * as Ajv from "ajv";
|
|
10
|
-
import { log } from
|
|
10
|
+
import { log } from "./util/logging";
|
|
11
11
|
import { WorkspaceConfig, PortRangeConfig } from "./protocol";
|
|
12
12
|
|
|
13
|
-
export type MaybeConfig = WorkspaceConfig | undefined
|
|
13
|
+
export type MaybeConfig = WorkspaceConfig | undefined;
|
|
14
14
|
|
|
15
|
-
const schema = require(
|
|
15
|
+
const schema = require("../data/gitpod-schema.json");
|
|
16
16
|
const validate = new Ajv().compile(schema);
|
|
17
17
|
const defaultParseOptions = {
|
|
18
18
|
acceptPortRanges: false,
|
|
19
19
|
};
|
|
20
20
|
|
|
21
21
|
export interface ParseResult {
|
|
22
|
-
config: WorkspaceConfig
|
|
23
|
-
parsedConfig?: WorkspaceConfig
|
|
24
|
-
validationErrors?: string[]
|
|
22
|
+
config: WorkspaceConfig;
|
|
23
|
+
parsedConfig?: WorkspaceConfig;
|
|
24
|
+
validationErrors?: string[];
|
|
25
25
|
}
|
|
26
26
|
|
|
27
27
|
@injectable()
|
|
28
28
|
export class GitpodFileParser {
|
|
29
|
-
|
|
30
29
|
public parse(content: string, parseOptions = {}, defaultConfig: WorkspaceConfig = {}): ParseResult {
|
|
31
30
|
const options = {
|
|
32
|
-
|
|
33
|
-
|
|
31
|
+
...defaultParseOptions,
|
|
32
|
+
...parseOptions,
|
|
34
33
|
};
|
|
35
34
|
try {
|
|
36
35
|
const parsedConfig = yaml.safeLoad(content) as any;
|
|
37
36
|
validate(parsedConfig);
|
|
38
|
-
const validationErrors = validate.errors ? validate.errors.map(
|
|
37
|
+
const validationErrors = validate.errors ? validate.errors.map((e) => e.message || e.keyword) : undefined;
|
|
39
38
|
if (validationErrors && validationErrors.length > 0) {
|
|
40
39
|
return {
|
|
41
40
|
config: defaultConfig,
|
|
42
41
|
parsedConfig,
|
|
43
|
-
validationErrors
|
|
42
|
+
validationErrors,
|
|
44
43
|
};
|
|
45
44
|
}
|
|
46
45
|
const overrides = {} as any;
|
|
@@ -49,17 +48,17 @@ export class GitpodFileParser {
|
|
|
49
48
|
}
|
|
50
49
|
return {
|
|
51
50
|
config: {
|
|
52
|
-
...
|
|
53
|
-
...
|
|
54
|
-
...
|
|
51
|
+
...defaultConfig,
|
|
52
|
+
...parsedConfig,
|
|
53
|
+
...overrides,
|
|
55
54
|
},
|
|
56
|
-
parsedConfig
|
|
55
|
+
parsedConfig,
|
|
57
56
|
};
|
|
58
57
|
} catch (err) {
|
|
59
|
-
log.error(
|
|
58
|
+
log.error("Unparsable Gitpod configuration", err, { content });
|
|
60
59
|
return {
|
|
61
60
|
config: defaultConfig,
|
|
62
|
-
validationErrors: [
|
|
61
|
+
validationErrors: ["Unparsable Gitpod configuration: " + err.toString()],
|
|
63
62
|
};
|
|
64
63
|
}
|
|
65
64
|
}
|