@gitpod/gitpod-protocol 0.1.5-wth-argo.0 → 0.1.5-wth-test.41

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.
Files changed (253) hide show
  1. package/data/builtin-theia-plugins.json +9 -9
  2. package/data/gitpod-schema.json +8 -22
  3. package/lib/accounting-protocol.d.ts +155 -0
  4. package/lib/accounting-protocol.d.ts.map +1 -0
  5. package/lib/accounting-protocol.js +109 -0
  6. package/lib/accounting-protocol.js.map +1 -0
  7. package/lib/admin-protocol.d.ts +20 -4
  8. package/lib/admin-protocol.d.ts.map +1 -1
  9. package/lib/admin-protocol.js +15 -0
  10. package/lib/admin-protocol.js.map +1 -1
  11. package/lib/analytics.d.ts +45 -0
  12. package/lib/analytics.d.ts.map +1 -0
  13. package/lib/{util/without.js → analytics.js} +4 -2
  14. package/lib/analytics.js.map +1 -0
  15. package/lib/context-url.d.ts +18 -0
  16. package/lib/context-url.d.ts.map +1 -0
  17. package/lib/context-url.js +49 -0
  18. package/lib/context-url.js.map +1 -0
  19. package/lib/{util/context-url.spec.d.ts → context-url.spec.d.ts} +3 -1
  20. package/lib/context-url.spec.d.ts.map +1 -0
  21. package/lib/context-url.spec.js +73 -0
  22. package/lib/context-url.spec.js.map +1 -0
  23. package/lib/email-protocol.d.ts +1 -2
  24. package/lib/email-protocol.d.ts.map +1 -1
  25. package/lib/email-protocol.js +4 -4
  26. package/lib/email-protocol.js.map +1 -1
  27. package/lib/encryption/container-module.js +5 -4
  28. package/lib/encryption/container-module.js.map +1 -1
  29. package/lib/encryption/encryption-engine.js +19 -20
  30. package/lib/encryption/encryption-engine.js.map +1 -1
  31. package/lib/encryption/encryption-engine.spec.js +29 -36
  32. package/lib/encryption/encryption-engine.spec.js.map +1 -1
  33. package/lib/encryption/encryption-service.js +29 -43
  34. package/lib/encryption/encryption-service.js.map +1 -1
  35. package/lib/encryption/key-provider.js +25 -30
  36. package/lib/encryption/key-provider.js.map +1 -1
  37. package/lib/env.d.ts +1 -2
  38. package/lib/env.d.ts.map +1 -1
  39. package/lib/env.js +20 -21
  40. package/lib/env.js.map +1 -1
  41. package/lib/gitpod-file-parser.js +25 -41
  42. package/lib/gitpod-file-parser.js.map +1 -1
  43. package/lib/gitpod-file-parser.spec.js +116 -116
  44. package/lib/gitpod-file-parser.spec.js.map +1 -1
  45. package/lib/gitpod-service.d.ts +132 -18
  46. package/lib/gitpod-service.d.ts.map +1 -1
  47. package/lib/gitpod-service.js +168 -256
  48. package/lib/gitpod-service.js.map +1 -1
  49. package/lib/headless-workspace-log.d.ts +8 -11
  50. package/lib/headless-workspace-log.d.ts.map +1 -1
  51. package/lib/headless-workspace-log.js +4 -7
  52. package/lib/headless-workspace-log.js.map +1 -1
  53. package/lib/ide-frontend-service.d.ts +4 -0
  54. package/lib/ide-frontend-service.d.ts.map +1 -1
  55. package/lib/index.d.ts +4 -0
  56. package/lib/index.d.ts.map +1 -1
  57. package/lib/index.js +5 -1
  58. package/lib/index.js.map +1 -1
  59. package/lib/messaging/browser/connection.d.ts +5 -3
  60. package/lib/messaging/browser/connection.d.ts.map +1 -1
  61. package/lib/messaging/browser/connection.js +183 -33
  62. package/lib/messaging/browser/connection.js.map +1 -1
  63. package/lib/messaging/browser/window-connection.js +35 -55
  64. package/lib/messaging/browser/window-connection.js.map +1 -1
  65. package/lib/messaging/client-call-metrics.d.ts +35 -0
  66. package/lib/messaging/client-call-metrics.d.ts.map +1 -0
  67. package/lib/messaging/client-call-metrics.js +83 -0
  68. package/lib/messaging/client-call-metrics.js.map +1 -0
  69. package/lib/messaging/connection-error-handler.js +11 -23
  70. package/lib/messaging/connection-error-handler.js.map +1 -1
  71. package/lib/messaging/error.d.ts +3 -1
  72. package/lib/messaging/error.d.ts.map +1 -1
  73. package/lib/messaging/error.js +6 -2
  74. package/lib/messaging/error.js.map +1 -1
  75. package/lib/messaging/handler.d.ts +10 -0
  76. package/lib/messaging/handler.d.ts.map +1 -1
  77. package/lib/messaging/node/connection.js +22 -22
  78. package/lib/messaging/node/connection.js.map +1 -1
  79. package/lib/messaging/proxy-factory.d.ts +2 -0
  80. package/lib/messaging/proxy-factory.d.ts.map +1 -1
  81. package/lib/messaging/proxy-factory.js +74 -159
  82. package/lib/messaging/proxy-factory.js.map +1 -1
  83. package/lib/payment-protocol.d.ts +18 -0
  84. package/lib/payment-protocol.d.ts.map +1 -0
  85. package/lib/payment-protocol.js +13 -0
  86. package/lib/payment-protocol.js.map +1 -0
  87. package/lib/permission.d.ts +2 -1
  88. package/lib/permission.d.ts.map +1 -1
  89. package/lib/permission.js +14 -13
  90. package/lib/permission.js.map +1 -1
  91. package/lib/plans.d.ts +210 -0
  92. package/lib/plans.d.ts.map +1 -0
  93. package/lib/plans.js +570 -0
  94. package/lib/plans.js.map +1 -0
  95. package/lib/protocol.d.ts +94 -16
  96. package/lib/protocol.d.ts.map +1 -1
  97. package/lib/protocol.js +104 -130
  98. package/lib/protocol.js.map +1 -1
  99. package/lib/snapshot-url.d.ts +14 -0
  100. package/lib/snapshot-url.d.ts.map +1 -0
  101. package/lib/snapshot-url.js +26 -0
  102. package/lib/snapshot-url.js.map +1 -0
  103. package/{src/util/without.ts → lib/snapshot-url.spec.d.ts} +2 -3
  104. package/lib/snapshot-url.spec.d.ts.map +1 -0
  105. package/lib/snapshot-url.spec.js +41 -0
  106. package/lib/snapshot-url.spec.js.map +1 -0
  107. package/lib/team-subscription-protocol.d.ts +73 -0
  108. package/lib/team-subscription-protocol.d.ts.map +1 -0
  109. package/lib/team-subscription-protocol.js +63 -0
  110. package/lib/team-subscription-protocol.js.map +1 -0
  111. package/lib/teams-projects-protocol.d.ts +103 -0
  112. package/lib/teams-projects-protocol.d.ts.map +1 -0
  113. package/lib/teams-projects-protocol.js +23 -0
  114. package/lib/teams-projects-protocol.js.map +1 -0
  115. package/lib/util/analytics.d.ts +8 -0
  116. package/lib/util/analytics.d.ts.map +1 -0
  117. package/lib/util/analytics.js +79 -0
  118. package/lib/util/analytics.js.map +1 -0
  119. package/lib/util/async-iterator.js +55 -133
  120. package/lib/util/async-iterator.js.map +1 -1
  121. package/lib/util/cancelable.js +17 -59
  122. package/lib/util/cancelable.js.map +1 -1
  123. package/lib/util/date-time.js +8 -8
  124. package/lib/util/date-time.js.map +1 -1
  125. package/lib/util/deferred.js +10 -12
  126. package/lib/util/deferred.js.map +1 -1
  127. package/lib/util/disposable.js +26 -39
  128. package/lib/util/disposable.js.map +1 -1
  129. package/lib/util/event.js +58 -74
  130. package/lib/util/event.js.map +1 -1
  131. package/lib/util/garbage-collected-cache.js +22 -46
  132. package/lib/util/garbage-collected-cache.js.map +1 -1
  133. package/lib/util/generate-workspace-id.d.ts.map +1 -1
  134. package/lib/util/generate-workspace-id.js +13 -67
  135. package/lib/util/generate-workspace-id.js.map +1 -1
  136. package/lib/util/generate-workspace-id.spec.js +34 -79
  137. package/lib/util/generate-workspace-id.spec.js.map +1 -1
  138. package/lib/util/gitpod-cookie.d.ts +20 -0
  139. package/lib/util/gitpod-cookie.d.ts.map +1 -0
  140. package/lib/util/gitpod-cookie.js +44 -0
  141. package/lib/util/gitpod-cookie.js.map +1 -0
  142. package/lib/util/gitpod-host-url.d.ts +1 -1
  143. package/lib/util/gitpod-host-url.d.ts.map +1 -1
  144. package/lib/util/gitpod-host-url.js +98 -98
  145. package/lib/util/gitpod-host-url.js.map +1 -1
  146. package/lib/util/gitpod-host-url.spec.d.ts +7 -1
  147. package/lib/util/gitpod-host-url.spec.d.ts.map +1 -1
  148. package/lib/util/gitpod-host-url.spec.js +103 -31
  149. package/lib/util/gitpod-host-url.spec.js.map +1 -1
  150. package/lib/util/grpc.d.ts +15 -0
  151. package/lib/util/grpc.d.ts.map +1 -0
  152. package/lib/util/grpc.js +18 -0
  153. package/lib/util/grpc.js.map +1 -0
  154. package/lib/util/logging.d.ts +49 -33
  155. package/lib/util/logging.d.ts.map +1 -1
  156. package/lib/util/logging.js +107 -110
  157. package/lib/util/logging.js.map +1 -1
  158. package/lib/util/make-link.js +2 -2
  159. package/lib/util/make-link.js.map +1 -1
  160. package/lib/util/parse-workspace-id.d.ts +10 -0
  161. package/lib/util/parse-workspace-id.d.ts.map +1 -1
  162. package/lib/util/parse-workspace-id.js +32 -7
  163. package/lib/util/parse-workspace-id.js.map +1 -1
  164. package/lib/util/parse-workspace-id.spec.d.ts +4 -0
  165. package/lib/util/parse-workspace-id.spec.d.ts.map +1 -1
  166. package/lib/util/parse-workspace-id.spec.js +123 -84
  167. package/lib/util/parse-workspace-id.spec.js.map +1 -1
  168. package/lib/util/queue.js +16 -55
  169. package/lib/util/queue.js.map +1 -1
  170. package/lib/util/queue.spec.js +144 -288
  171. package/lib/util/queue.spec.js.map +1 -1
  172. package/lib/util/repeater.js +35 -88
  173. package/lib/util/repeater.js.map +1 -1
  174. package/lib/util/safe-promise.js +9 -12
  175. package/lib/util/safe-promise.js.map +1 -1
  176. package/lib/util/semaphore.js +15 -46
  177. package/lib/util/semaphore.js.map +1 -1
  178. package/lib/util/skip-if.js +6 -6
  179. package/lib/util/skip-if.js.map +1 -1
  180. package/lib/util/timeutil.js +28 -16
  181. package/lib/util/timeutil.js.map +1 -1
  182. package/lib/util/timeutil.spec.js +21 -24
  183. package/lib/util/timeutil.spec.js.map +1 -1
  184. package/lib/util/tracing.js +43 -47
  185. package/lib/util/tracing.js.map +1 -1
  186. package/lib/util/workspace-port-authentication.js +3 -2
  187. package/lib/util/workspace-port-authentication.js.map +1 -1
  188. package/lib/workspace-cluster.d.ts +74 -0
  189. package/lib/workspace-cluster.d.ts.map +1 -0
  190. package/lib/workspace-cluster.js +16 -0
  191. package/lib/workspace-cluster.js.map +1 -0
  192. package/lib/workspace-instance.d.ts +7 -2
  193. package/lib/workspace-instance.d.ts.map +1 -1
  194. package/lib/wsready.d.ts +1 -1
  195. package/lib/wsready.js +2 -2
  196. package/package.json +28 -16
  197. package/pkg-yarn.lock +17 -9
  198. package/src/accounting-protocol.ts +229 -0
  199. package/src/admin-protocol.ts +39 -5
  200. package/src/analytics.ts +54 -0
  201. package/src/context-url.spec.ts +39 -0
  202. package/src/context-url.ts +51 -0
  203. package/src/email-protocol.ts +2 -3
  204. package/src/env.ts +10 -10
  205. package/src/gitpod-service.ts +198 -33
  206. package/src/headless-workspace-log.ts +7 -11
  207. package/src/ide-frontend-service.ts +4 -0
  208. package/src/index.ts +5 -1
  209. package/src/messaging/browser/connection.ts +195 -14
  210. package/src/messaging/client-call-metrics.ts +97 -0
  211. package/src/messaging/error.ts +8 -2
  212. package/src/messaging/handler.ts +12 -0
  213. package/src/messaging/node/connection.ts +2 -2
  214. package/src/messaging/proxy-factory.ts +14 -6
  215. package/src/payment-protocol.ts +20 -0
  216. package/src/permission.ts +2 -1
  217. package/src/plans.ts +632 -0
  218. package/src/protocol.ts +153 -43
  219. package/src/snapshot-url.spec.ts +25 -0
  220. package/src/snapshot-url.ts +27 -0
  221. package/src/team-subscription-protocol.ts +113 -0
  222. package/src/teams-projects-protocol.ts +132 -0
  223. package/src/util/analytics.ts +87 -0
  224. package/src/util/deferred.ts +1 -1
  225. package/src/util/garbage-collected-cache.ts +2 -2
  226. package/src/util/generate-workspace-id.spec.ts +3 -3
  227. package/src/util/generate-workspace-id.ts +2 -0
  228. package/src/util/gitpod-cookie.ts +39 -0
  229. package/src/util/gitpod-host-url.spec.ts +25 -1
  230. package/src/util/gitpod-host-url.ts +23 -10
  231. package/src/util/grpc.ts +15 -0
  232. package/src/util/logging.ts +102 -38
  233. package/src/util/parse-workspace-id.spec.ts +21 -1
  234. package/src/util/parse-workspace-id.ts +32 -6
  235. package/src/util/queue.spec.ts +1 -1
  236. package/src/util/semaphore.ts +2 -2
  237. package/src/util/skip-if.ts +1 -1
  238. package/src/util/timeutil.ts +4 -4
  239. package/src/workspace-cluster.ts +96 -0
  240. package/src/workspace-instance.ts +31 -13
  241. package/src/wsready.ts +2 -2
  242. package/lib/util/context-url.d.ts +0 -13
  243. package/lib/util/context-url.d.ts.map +0 -1
  244. package/lib/util/context-url.js +0 -26
  245. package/lib/util/context-url.js.map +0 -1
  246. package/lib/util/context-url.spec.d.ts.map +0 -1
  247. package/lib/util/context-url.spec.js +0 -52
  248. package/lib/util/context-url.spec.js.map +0 -1
  249. package/lib/util/without.d.ts +0 -7
  250. package/lib/util/without.d.ts.map +0 -1
  251. package/lib/util/without.js.map +0 -1
  252. package/src/util/context-url.spec.ts +0 -25
  253. package/src/util/context-url.ts +0 -23
@@ -27,7 +27,7 @@ export function skipIf(doSkip: (suite: TestSuiteContext) => boolean): MochaTypeS
27
27
  }
28
28
  })
29
29
  };
30
-
30
+
31
31
  // Mark as "trait": mimics the behavior of https://github.com/testdeck/testdeck/blob/9d2dd6a458c2c86c945f6f2999b8278b7528a7a7/index.ts#L433
32
32
  (trait as any)["__mts_isTrait"] = true;
33
33
  return trait;
@@ -6,12 +6,12 @@
6
6
 
7
7
  /**
8
8
  * Returns the <code>day</code>th of the next month from <code>formDate</code>.
9
- * If the next month does not have a <code>day</code>th, the last day of that
9
+ * If the next month does not have a <code>day</code>th, the last day of that
10
10
  * month is taken.
11
11
  * The time is copied from <code>fromDate</code>.
12
- *
13
- * @param fromDate
14
- * @param day
12
+ *
13
+ * @param fromDate
14
+ * @param day
15
15
  */
16
16
  export function oneMonthLater(fromDate: string, day?: number): string {
17
17
  const later = new Date(fromDate);
@@ -0,0 +1,96 @@
1
+ /**
2
+ * Copyright (c) 2020 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 * as fs from 'fs';
8
+ import { filePathTelepresenceAware } from './env';
9
+ import { DeepPartial } from "./util/deep-partial";
10
+ import { PermissionName } from './permission';
11
+
12
+ export interface WorkspaceCluster {
13
+ // Name of the workspace cluster.
14
+ // This is the string set in each
15
+ // Must be identical to the installationShortname of the cluster it represents!
16
+ name: string;
17
+
18
+ // URL of the cluster's ws-manager API
19
+ url: string;
20
+
21
+ // TLS contains the keys and certificates necessary to use mTLS between server and clients
22
+ tls?: TLSConfig;
23
+
24
+ // Current state of the cluster
25
+ state: WorkspaceClusterState;
26
+
27
+ // Maximum value score can reach for this cluster
28
+ maxScore: number;
29
+
30
+ // Score used for cluster selection when starting workspace instances
31
+ score: number;
32
+
33
+ // True if this bridge should control this cluster
34
+ govern: boolean;
35
+
36
+ // An optional set of constraints that limit who can start workspaces on the cluster
37
+ admissionConstraints?: AdmissionConstraint[];
38
+
39
+ // An optional set of admission preferences that guide cluster selection
40
+ admissionPreferences?: AdmissionPreference[];
41
+ }
42
+
43
+ export type WorkspaceClusterState = "available" | "cordoned" | "draining";
44
+ export interface TLSConfig {
45
+ // the CA shared between client and server (base64 encoded)
46
+ ca: string;
47
+ // the private key (base64 encoded)
48
+ key: string;
49
+ // the certificate signed with the shared CA (base64 encoded)
50
+ crt: string;
51
+ }
52
+ export namespace TLSConfig {
53
+ export const loadFromBase64File = (path: string): string => fs.readFileSync(filePathTelepresenceAware(path)).toString("base64");
54
+ }
55
+ export type WorkspaceClusterWoTLS = Omit<WorkspaceCluster, "tls">;
56
+ export type WorkspaceManagerConnectionInfo = Pick<WorkspaceCluster, "name" | "url" | "tls">;
57
+
58
+ export type AdmissionConstraint = AdmissionConstraintFeaturePreview | AdmissionConstraintHasRole | AdmissionConstraintHasUserLevel;
59
+ export type AdmissionConstraintFeaturePreview = { type: "has-feature-preview" };
60
+ export type AdmissionConstraintHasRole = { type: "has-permission", permission: PermissionName };
61
+ export type AdmissionConstraintHasUserLevel = { type: "has-user-level", level: string };
62
+
63
+ export type AdmissionPreference = AdmissionPreferenceUserLevel;
64
+ export type AdmissionPreferenceUserLevel = { type: 'user-level', level: string };
65
+
66
+
67
+ export const WorkspaceClusterDB = Symbol("WorkspaceClusterDB");
68
+ export interface WorkspaceClusterDB {
69
+ /**
70
+ * Stores the given WorkspaceCluster to the cluster-local DB in a consistent manner.
71
+ * If there already is an entry with the same name it's merged and updated with the given state.
72
+ * @param cluster
73
+ */
74
+ save(cluster: WorkspaceCluster): Promise<void>;
75
+
76
+ /**
77
+ * Deletes the cluster identified by this name, if any.
78
+ * @param name
79
+ */
80
+ deleteByName(name: string): Promise<void>;
81
+
82
+ /**
83
+ * Finds a WorkspaceCluster with the given name. If there is none, `undefined` is returned.
84
+ * @param name
85
+ */
86
+ findByName(name: string): Promise<WorkspaceCluster | undefined>;
87
+
88
+ /**
89
+ * Lists all WorkspaceClusterWoTls for which the given predicate is true (does not return TLS for size/speed concerns)
90
+ * @param predicate
91
+ */
92
+ findFiltered(predicate: DeepPartial<WorkspaceClusterFilter>): Promise<WorkspaceClusterWoTLS[]>;
93
+ }
94
+ export interface WorkspaceClusterFilter extends Pick<WorkspaceCluster, "state" | "govern" | "url"> {
95
+ minScore: number;
96
+ }
@@ -23,16 +23,22 @@ export interface WorkspaceInstance {
23
23
  // The time an instance has switched phase to 'Running'
24
24
  startedTime?: string;
25
25
 
26
+ // The time an instance has switched phase to 'Stopping' */
27
+ stoppingTime?: string;
28
+
26
29
  // The time an instance has switched phase to 'Stopped' */
27
30
  stoppedTime?: string;
28
31
 
29
32
  // ideUrl is the URL at which the workspace is available on the internet
33
+ // Note: this is nitially empty, filled during starting process!
30
34
  ideUrl: string;
31
35
 
32
36
  // region is the name of the workspace cluster this instance runs in
37
+ // Note: this is nitially empty, filled during starting process!
33
38
  region: string;
34
39
 
35
40
  // workspaceImage is the name of the Docker image this instance runs
41
+ // Note: this is nitially empty, filled during starting process!
36
42
  workspaceImage: string;
37
43
 
38
44
  // status is the latest status of the instance that we're aware of
@@ -70,6 +76,12 @@ export interface WorkspaceInstanceStatus {
70
76
  // nodeName is the name of the node the instance was scheduled onto
71
77
  nodeName?: string;
72
78
 
79
+ // podName is the name of the pod of this instance
80
+ podName?: string;
81
+
82
+ // nodeIp is the IP of the node the workspace is running on
83
+ nodeIp?: string;
84
+
73
85
  // ownerToken is the token one needs to access the workspace. Its presence is checked by ws-proxy.
74
86
  ownerToken?: string;
75
87
  }
@@ -77,7 +89,7 @@ export interface WorkspaceInstanceStatus {
77
89
  // WorkspaceInstancePhase describes a high-level state of a workspace instance
78
90
  export type WorkspaceInstancePhase =
79
91
  // unknown indicates an issue within the system in that it cannot determine the actual phase of
80
- // a workspace. This phase is usually accompanied by an error.
92
+ // a workspace. This phase is usually accompanied by an error.
81
93
  "unknown" |
82
94
 
83
95
  // Preparing means that we haven't actually started the workspace instance just yet, but rather
@@ -85,21 +97,21 @@ export type WorkspaceInstancePhase =
85
97
  "preparing" |
86
98
 
87
99
  // Pending means the workspace does not yet consume resources in the cluster, but rather is looking for
88
- // some space within the cluster. If for example the cluster needs to scale up to accomodate the
89
- // workspace, the workspace will be in Pending state until that happened.
100
+ // some space within the cluster. If for example the cluster needs to scale up to accomodate the
101
+ // workspace, the workspace will be in Pending state until that happened.
90
102
  "pending" |
91
103
 
92
104
  // Creating means the workspace is currently being created. Thati includes downloading the images required
93
- // to run the workspace over the network. The time spent in this phase varies widely and depends on the current
94
- // network speed, image size and cache states.
105
+ // to run the workspace over the network. The time spent in this phase varies widely and depends on the current
106
+ // network speed, image size and cache states.
95
107
  "creating" |
96
108
 
97
109
  // Initializing is the phase in which the workspace is executing the appropriate workspace initializer (e.g. Git
98
- // clone or backup download). After this phase one can expect the workspace to either be Running or Failed.
110
+ // clone or backup download). After this phase one can expect the workspace to either be Running or Failed.
99
111
  "initializing" |
100
112
 
101
113
  // Running means the workspace is able to actively perform work, either by serving a user through Theia,
102
- // or as a headless workspace.
114
+ // or as a headless workspace.
103
115
  "running" |
104
116
 
105
117
  // Interrupted is an exceptional state where the container should be running but is temporarily unavailable.
@@ -122,9 +134,6 @@ export interface WorkspaceInstanceConditions {
122
134
  // PullingImages marks if the workspace is currently pulling its images. This condition can only be set during PhaseCreating
123
135
  pullingImages?: boolean
124
136
 
125
- // ServiceExists denotes if the workspace theia-/ports- services exist. This condition will be true if either of the two services exist.
126
- serviceExists?: boolean
127
-
128
137
  // deployed marks that a workspace instance was sent/deployed at a workspace manager
129
138
  deployed?: boolean;
130
139
 
@@ -133,6 +142,12 @@ export interface WorkspaceInstanceConditions {
133
142
 
134
143
  // ISO8601 timestamp when the first user activity was registered in the frontend. Only set if the workspace is running.
135
144
  firstUserActivity?: string;
145
+
146
+ // headless_task_failed indicates that a headless workspace task failed
147
+ headlessTaskFailed?: string;
148
+
149
+ // stopped_by_request is true if the workspace was stopped using a StopWorkspace call
150
+ stoppedByRequest?: boolean;
136
151
  }
137
152
 
138
153
  // AdmissionLevel describes who can access a workspace instance and its ports.
@@ -146,9 +161,6 @@ export interface WorkspaceInstancePort {
146
161
  // The outward-facing port number
147
162
  port: number;
148
163
 
149
- // An optional inward-facing port number. If not present we'll use port.
150
- targetPort?: number;
151
-
152
164
  // The visiblity of this port. Optional for backwards compatibility.
153
165
  visibility?: PortVisibility;
154
166
 
@@ -194,4 +206,10 @@ export interface WorkspaceInstanceConfiguration {
194
206
 
195
207
  // ideImage is the ref of the IDE image this instance uses.
196
208
  ideImage: string;
209
+
210
+ // desktopIdeImage is the ref of the desktop IDE image this instance uses.
211
+ desktopIdeImage?: string
212
+
213
+ // supervisorImage is the ref of the supervisor image this instance uses.
214
+ supervisorImage?: string;
197
215
  }
package/src/wsready.ts CHANGED
@@ -1,10 +1,10 @@
1
1
  /**
2
- * Copyright (c) 2020 Gitpod GmbH. All rights reserved.
2
+ * Copyright (c) 2021 Gitpod GmbH. All rights reserved.
3
3
  * Licensed under the GNU Affero General Public License (AGPL).
4
4
  * See License-AGPL.txt in the project root for license information.
5
5
  */
6
6
 
7
- // generated using github.com/32leaves/bel on 2020-06-11 14:47:30.351829728 +0000 UTC m=+0.002956090
7
+ // generated using github.com/32leaves/bel on 2021-11-04 12:16:53.917570766 +0000 UTC m=+0.006002884
8
8
  // DO NOT MODIFY
9
9
 
10
10
  export enum WorkspaceInitSource {
@@ -1,13 +0,0 @@
1
- /**
2
- * Copyright (c) 2020 TypeFox 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
- * The field "contextUrl" might contain prefixes like:
8
- * - envvar1=value1/...
9
- * - prebuild/...
10
- * This is the analogon to the (Prefix)ContextParser structure in "server".
11
- */
12
- export declare function contextUrlToUrl(contextUrl: string | undefined): URL | undefined;
13
- //# sourceMappingURL=context-url.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"context-url.d.ts","sourceRoot":"","sources":["../../src/util/context-url.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH;;;;;GAKG;AACH,wBAAgB,eAAe,CAAC,UAAU,EAAE,MAAM,GAAG,SAAS,GAAG,GAAG,GAAG,SAAS,CAU/E"}
@@ -1,26 +0,0 @@
1
- "use strict";
2
- /**
3
- * Copyright (c) 2020 TypeFox GmbH. All rights reserved.
4
- * Licensed under the GNU Affero General Public License (AGPL).
5
- * See License-AGPL.txt in the project root for license information.
6
- */
7
- Object.defineProperty(exports, "__esModule", { value: true });
8
- exports.contextUrlToUrl = void 0;
9
- /**
10
- * The field "contextUrl" might contain prefixes like:
11
- * - envvar1=value1/...
12
- * - prebuild/...
13
- * This is the analogon to the (Prefix)ContextParser structure in "server".
14
- */
15
- function contextUrlToUrl(contextUrl) {
16
- if (contextUrl === undefined) {
17
- return undefined;
18
- }
19
- if (contextUrl.startsWith("http")) {
20
- return new URL(contextUrl);
21
- }
22
- var finding = contextUrl.search("/http");
23
- return new URL(contextUrl.substr(finding + 1));
24
- }
25
- exports.contextUrlToUrl = contextUrlToUrl;
26
- //# sourceMappingURL=context-url.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"context-url.js","sourceRoot":"","sources":["../../src/util/context-url.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;;AAEH;;;;;GAKG;AACH,SAAgB,eAAe,CAAC,UAA8B;IAC5D,IAAI,UAAU,KAAK,SAAS,EAAE;QAC5B,OAAO,SAAS,CAAC;KAClB;IAED,IAAI,UAAU,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE;QACjC,OAAO,IAAI,GAAG,CAAC,UAAU,CAAC,CAAC;KAC5B;IACD,IAAM,OAAO,GAAG,UAAU,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC3C,OAAO,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC;AACjD,CAAC;AAVD,0CAUC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"context-url.spec.d.ts","sourceRoot":"","sources":["../../src/util/context-url.spec.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAOH,qBACa,cAAc;IAEV,0BAA0B;IAK1B,4BAA4B;CAI5C"}
@@ -1,52 +0,0 @@
1
- "use strict";
2
- /**
3
- * Copyright (c) 2020 TypeFox GmbH. All rights reserved.
4
- * Licensed under the GNU Affero General Public License (AGPL).
5
- * See License-AGPL.txt in the project root for license information.
6
- */
7
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
8
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
9
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
10
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
11
- return c > 3 && r && Object.defineProperty(target, key, r), r;
12
- };
13
- var __metadata = (this && this.__metadata) || function (k, v) {
14
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- exports.ContextUrlTest = void 0;
18
- var chai = require("chai");
19
- var mocha_typescript_1 = require("mocha-typescript");
20
- var context_url_1 = require("./context-url");
21
- var expect = chai.expect;
22
- var ContextUrlTest = /** @class */ (function () {
23
- function ContextUrlTest() {
24
- }
25
- ContextUrlTest.prototype.parseContextUrl_withEnvVar = function () {
26
- var actual = context_url_1.contextUrlToUrl("passedin=test%20value/https://github.com/gitpod-io/gitpod-test-repo");
27
- expect(actual === null || actual === void 0 ? void 0 : actual.pathname).to.equal("/gitpod-io/gitpod-test-repo");
28
- };
29
- ContextUrlTest.prototype.parseContextUrl_withPrebuild = function () {
30
- var actual = context_url_1.contextUrlToUrl("prebuild/https://github.com/gitpod-io/gitpod-test-repo");
31
- expect(actual === null || actual === void 0 ? void 0 : actual.host).to.equal("github.com");
32
- };
33
- __decorate([
34
- mocha_typescript_1.test,
35
- __metadata("design:type", Function),
36
- __metadata("design:paramtypes", []),
37
- __metadata("design:returntype", void 0)
38
- ], ContextUrlTest.prototype, "parseContextUrl_withEnvVar", null);
39
- __decorate([
40
- mocha_typescript_1.test,
41
- __metadata("design:type", Function),
42
- __metadata("design:paramtypes", []),
43
- __metadata("design:returntype", void 0)
44
- ], ContextUrlTest.prototype, "parseContextUrl_withPrebuild", null);
45
- ContextUrlTest = __decorate([
46
- mocha_typescript_1.suite
47
- ], ContextUrlTest);
48
- return ContextUrlTest;
49
- }());
50
- exports.ContextUrlTest = ContextUrlTest;
51
- module.exports = new ContextUrlTest();
52
- //# sourceMappingURL=context-url.spec.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"context-url.spec.js","sourceRoot":"","sources":["../../src/util/context-url.spec.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;;;;;;;;;;;AAEH,2BAA6B;AAC7B,qDAA+C;AAC/C,6CAAgD;AAChD,IAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;AAG3B;IAAA;IAWA,CAAC;IATgB,mDAA0B,GAAjC;QACF,IAAM,MAAM,GAAG,6BAAe,CAAC,qEAAqE,CAAC,CAAC;QACtG,MAAM,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,QAAQ,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAC;IACrE,CAAC;IAEY,qDAA4B,GAAnC;QACF,IAAM,MAAM,GAAG,6BAAe,CAAC,wDAAwD,CAAC,CAAC;QACzF,MAAM,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,IAAI,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IAChD,CAAC;IARK;QAAL,uBAAI;;;;oEAGJ;IAEK;QAAL,uBAAI;;;;sEAGJ;IAVQ,cAAc;QAD1B,wBAAK;OACO,cAAc,CAW1B;IAAD,qBAAC;CAAA,AAXD,IAWC;AAXY,wCAAc;AAY3B,MAAM,CAAC,OAAO,GAAG,IAAI,cAAc,EAAE,CAAA"}
@@ -1,7 +0,0 @@
1
- /**
2
- * Copyright (c) 2020 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
- export declare type Without<T, K> = Pick<T, Exclude<keyof T, K>>;
7
- //# sourceMappingURL=without.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"without.d.ts","sourceRoot":"","sources":["../../src/util/without.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,oBAAY,OAAO,CAAC,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"without.js","sourceRoot":"","sources":["../../src/util/without.ts"],"names":[],"mappings":";AAAA;;;;GAIG"}
@@ -1,25 +0,0 @@
1
- /**
2
- * Copyright (c) 2020 TypeFox 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 * as chai from 'chai';
8
- import { suite, test } from 'mocha-typescript';
9
- import { contextUrlToUrl } from './context-url';
10
- const expect = chai.expect;
11
-
12
- @suite
13
- export class ContextUrlTest {
14
-
15
- @test public parseContextUrl_withEnvVar() {
16
- const actual = contextUrlToUrl("passedin=test%20value/https://github.com/gitpod-io/gitpod-test-repo");
17
- expect(actual?.pathname).to.equal("/gitpod-io/gitpod-test-repo");
18
- }
19
-
20
- @test public parseContextUrl_withPrebuild() {
21
- const actual = contextUrlToUrl("prebuild/https://github.com/gitpod-io/gitpod-test-repo");
22
- expect(actual?.host).to.equal("github.com");
23
- }
24
- }
25
- module.exports = new ContextUrlTest()
@@ -1,23 +0,0 @@
1
- /**
2
- * Copyright (c) 2020 TypeFox 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
- /**
8
- * The field "contextUrl" might contain prefixes like:
9
- * - envvar1=value1/...
10
- * - prebuild/...
11
- * This is the analogon to the (Prefix)ContextParser structure in "server".
12
- */
13
- export function contextUrlToUrl(contextUrl: string | undefined): URL | undefined {
14
- if (contextUrl === undefined) {
15
- return undefined;
16
- }
17
-
18
- if (contextUrl.startsWith("http")) {
19
- return new URL(contextUrl);
20
- }
21
- const finding = contextUrl.search("/http");
22
- return new URL(contextUrl.substr(finding + 1));
23
- }