@gitpod/gitpod-protocol 0.1.5-wth-test.80 → 0.1.5-yh-vmoptions-fork.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (270) hide show
  1. package/data/gitpod-schema.json +181 -4
  2. package/lib/accounting-protocol.d.ts +17 -10
  3. package/lib/accounting-protocol.d.ts.map +1 -1
  4. package/lib/accounting-protocol.js +30 -32
  5. package/lib/accounting-protocol.js.map +1 -1
  6. package/lib/admin-protocol.d.ts +1 -0
  7. package/lib/admin-protocol.d.ts.map +1 -1
  8. package/lib/admin-protocol.js.map +1 -1
  9. package/lib/analytics.d.ts.map +1 -1
  10. package/lib/analytics.js.map +1 -1
  11. package/lib/auth.d.ts.map +1 -1
  12. package/lib/context-url.d.ts.map +1 -1
  13. package/lib/context-url.js +3 -3
  14. package/lib/context-url.js.map +1 -1
  15. package/lib/context-url.spec.d.ts.map +1 -1
  16. package/lib/context-url.spec.js +20 -5
  17. package/lib/context-url.spec.js.map +1 -1
  18. package/lib/email-protocol.d.ts +1 -1
  19. package/lib/email-protocol.d.ts.map +1 -1
  20. package/lib/email-protocol.js.map +1 -1
  21. package/lib/encryption/container-module.d.ts.map +1 -1
  22. package/lib/encryption/container-module.js +1 -1
  23. package/lib/encryption/container-module.js.map +1 -1
  24. package/lib/encryption/encryption-engine.d.ts.map +1 -1
  25. package/lib/encryption/encryption-engine.js +7 -7
  26. package/lib/encryption/encryption-engine.js.map +1 -1
  27. package/lib/encryption/encryption-engine.spec.d.ts.map +1 -1
  28. package/lib/encryption/encryption-engine.spec.js +2 -3
  29. package/lib/encryption/encryption-engine.spec.js.map +1 -1
  30. package/lib/encryption/encryption-service.d.ts.map +1 -1
  31. package/lib/encryption/encryption-service.js +1 -1
  32. package/lib/encryption/encryption-service.js.map +1 -1
  33. package/lib/encryption/key-provider.d.ts.map +1 -1
  34. package/lib/encryption/key-provider.js +7 -9
  35. package/lib/encryption/key-provider.js.map +1 -1
  36. package/lib/env.d.ts +0 -5
  37. package/lib/env.d.ts.map +1 -1
  38. package/lib/env.js +1 -20
  39. package/lib/env.js.map +1 -1
  40. package/lib/gitpod-file-parser.d.ts.map +1 -1
  41. package/lib/gitpod-file-parser.js +6 -6
  42. package/lib/gitpod-file-parser.js.map +1 -1
  43. package/lib/gitpod-file-parser.spec.js +42 -39
  44. package/lib/gitpod-file-parser.spec.js.map +1 -1
  45. package/lib/gitpod-service.d.ts +32 -26
  46. package/lib/gitpod-service.d.ts.map +1 -1
  47. package/lib/gitpod-service.js +39 -32
  48. package/lib/gitpod-service.js.map +1 -1
  49. package/lib/headless-workspace-log.d.ts +1 -0
  50. package/lib/headless-workspace-log.d.ts.map +1 -1
  51. package/lib/headless-workspace-log.js +2 -1
  52. package/lib/headless-workspace-log.js.map +1 -1
  53. package/lib/ide-frontend-service.d.ts +1 -1
  54. package/lib/ide-protocol.d.ts +6 -6
  55. package/lib/ide-protocol.d.ts.map +1 -1
  56. package/lib/index.d.ts +16 -16
  57. package/lib/installation-admin-protocol.d.ts.map +1 -1
  58. package/lib/installation-admin-protocol.js +2 -2
  59. package/lib/installation-admin-protocol.js.map +1 -1
  60. package/lib/license-protocol.d.ts +7 -0
  61. package/lib/license-protocol.d.ts.map +1 -1
  62. package/lib/license-protocol.js.map +1 -1
  63. package/lib/messaging/browser/connection.d.ts +1 -1
  64. package/lib/messaging/browser/connection.d.ts.map +1 -1
  65. package/lib/messaging/browser/connection.js +19 -19
  66. package/lib/messaging/browser/connection.js.map +1 -1
  67. package/lib/messaging/browser/window-connection.d.ts +4 -4
  68. package/lib/messaging/browser/window-connection.d.ts.map +1 -1
  69. package/lib/messaging/browser/window-connection.js +9 -6
  70. package/lib/messaging/browser/window-connection.js.map +1 -1
  71. package/lib/messaging/client-call-metrics.d.ts +2 -2
  72. package/lib/messaging/client-call-metrics.d.ts.map +1 -1
  73. package/lib/messaging/client-call-metrics.js +20 -20
  74. package/lib/messaging/client-call-metrics.js.map +1 -1
  75. package/lib/messaging/error.d.ts +2 -0
  76. package/lib/messaging/error.d.ts.map +1 -1
  77. package/lib/messaging/error.js +4 -0
  78. package/lib/messaging/error.js.map +1 -1
  79. package/lib/messaging/handler.d.ts.map +1 -1
  80. package/lib/messaging/handler.js +1 -1
  81. package/lib/messaging/node/connection.js +8 -8
  82. package/lib/messaging/node/connection.js.map +1 -1
  83. package/lib/messaging/proxy-factory.d.ts +1 -1
  84. package/lib/messaging/proxy-factory.d.ts.map +1 -1
  85. package/lib/messaging/proxy-factory.js +7 -9
  86. package/lib/messaging/proxy-factory.js.map +1 -1
  87. package/lib/payment-protocol.d.ts.map +1 -1
  88. package/lib/payment-protocol.js +1 -1
  89. package/lib/payment-protocol.js.map +1 -1
  90. package/lib/permission.d.ts +2 -2
  91. package/lib/permission.d.ts.map +1 -1
  92. package/lib/permission.js +12 -23
  93. package/lib/permission.js.map +1 -1
  94. package/lib/plans.d.ts +3 -3
  95. package/lib/plans.d.ts.map +1 -1
  96. package/lib/plans.js +206 -171
  97. package/lib/plans.js.map +1 -1
  98. package/lib/protocol.d.ts +83 -36
  99. package/lib/protocol.d.ts.map +1 -1
  100. package/lib/protocol.js +165 -87
  101. package/lib/protocol.js.map +1 -1
  102. package/lib/snapshot-url.spec.js.map +1 -1
  103. package/lib/team-subscription-protocol.d.ts +21 -3
  104. package/lib/team-subscription-protocol.d.ts.map +1 -1
  105. package/lib/team-subscription-protocol.js +16 -5
  106. package/lib/team-subscription-protocol.js.map +1 -1
  107. package/lib/teams-projects-protocol.d.ts +8 -3
  108. package/lib/teams-projects-protocol.d.ts.map +1 -1
  109. package/lib/teams-projects-protocol.js +1 -1
  110. package/lib/teams-projects-protocol.js.map +1 -1
  111. package/lib/typings/globals.d.ts +2 -2
  112. package/lib/typings/globals.d.ts.map +1 -1
  113. package/lib/util/analytics.d.ts.map +1 -1
  114. package/lib/util/analytics.js +6 -6
  115. package/lib/util/analytics.js.map +1 -1
  116. package/lib/util/async-iterator.d.ts.map +1 -1
  117. package/lib/util/async-iterator.js +3 -3
  118. package/lib/util/async-iterator.js.map +1 -1
  119. package/lib/util/cancelable.js.map +1 -1
  120. package/lib/util/date-time.js +6 -6
  121. package/lib/util/date-time.js.map +1 -1
  122. package/lib/util/deferred.js.map +1 -1
  123. package/lib/util/disposable.d.ts.map +1 -1
  124. package/lib/util/disposable.js +2 -2
  125. package/lib/util/disposable.js.map +1 -1
  126. package/lib/util/event.d.ts.map +1 -1
  127. package/lib/util/event.js +5 -3
  128. package/lib/util/event.js.map +1 -1
  129. package/lib/util/garbage-collected-cache.d.ts.map +1 -1
  130. package/lib/util/garbage-collected-cache.js +1 -1
  131. package/lib/util/garbage-collected-cache.js.map +1 -1
  132. package/lib/util/generate-workspace-id.d.ts +5 -0
  133. package/lib/util/generate-workspace-id.d.ts.map +1 -1
  134. package/lib/util/generate-workspace-id.js +446 -442
  135. package/lib/util/generate-workspace-id.js.map +1 -1
  136. package/lib/util/generate-workspace-id.spec.js +18 -7
  137. package/lib/util/generate-workspace-id.spec.js.map +1 -1
  138. package/lib/util/gitpod-cookie.d.ts +1 -1
  139. package/lib/util/gitpod-cookie.d.ts.map +1 -1
  140. package/lib/util/gitpod-cookie.js +0 -3
  141. package/lib/util/gitpod-cookie.js.map +1 -1
  142. package/lib/util/gitpod-host-url.d.ts.map +1 -1
  143. package/lib/util/gitpod-host-url.js +31 -29
  144. package/lib/util/gitpod-host-url.js.map +1 -1
  145. package/lib/util/gitpod-host-url.spec.d.ts.map +1 -1
  146. package/lib/util/gitpod-host-url.spec.js +15 -5
  147. package/lib/util/gitpod-host-url.spec.js.map +1 -1
  148. package/lib/util/grpc.d.ts.map +1 -1
  149. package/lib/util/grpc.js.map +1 -1
  150. package/lib/util/jaeger-client-types.d.ts.map +1 -1
  151. package/lib/util/logging.d.ts +1 -1
  152. package/lib/util/logging.d.ts.map +1 -1
  153. package/lib/util/logging.js +23 -24
  154. package/lib/util/logging.js.map +1 -1
  155. package/lib/util/make-link.js +5 -5
  156. package/lib/util/make-link.js.map +1 -1
  157. package/lib/util/parse-workspace-id.d.ts.map +1 -1
  158. package/lib/util/parse-workspace-id.js +1 -2
  159. package/lib/util/parse-workspace-id.js.map +1 -1
  160. package/lib/util/parse-workspace-id.spec.d.ts.map +1 -1
  161. package/lib/util/parse-workspace-id.spec.js.map +1 -1
  162. package/lib/util/queue.spec.js +9 -6
  163. package/lib/util/queue.spec.js.map +1 -1
  164. package/lib/util/semaphore.d.ts.map +1 -1
  165. package/lib/util/semaphore.js.map +1 -1
  166. package/lib/util/skip-if.d.ts.map +1 -1
  167. package/lib/util/skip-if.js.map +1 -1
  168. package/lib/util/timeutil.d.ts +1 -0
  169. package/lib/util/timeutil.d.ts.map +1 -1
  170. package/lib/util/timeutil.js +9 -3
  171. package/lib/util/timeutil.js.map +1 -1
  172. package/lib/util/timeutil.spec.d.ts.map +1 -1
  173. package/lib/util/timeutil.spec.js.map +1 -1
  174. package/lib/util/tracing.d.ts +6 -6
  175. package/lib/util/tracing.d.ts.map +1 -1
  176. package/lib/util/tracing.js +14 -16
  177. package/lib/util/tracing.js.map +1 -1
  178. package/lib/util/tracing.spec.js +3 -3
  179. package/lib/util/tracing.spec.js.map +1 -1
  180. package/lib/util/workspace-port-authentication.d.ts +7 -7
  181. package/lib/util/workspace-port-authentication.d.ts.map +1 -1
  182. package/lib/util/workspace-port-authentication.js +8 -11
  183. package/lib/util/workspace-port-authentication.js.map +1 -1
  184. package/lib/workspace-cluster.d.ts +1 -1
  185. package/lib/workspace-cluster.d.ts.map +1 -1
  186. package/lib/workspace-cluster.js +2 -4
  187. package/lib/workspace-cluster.js.map +1 -1
  188. package/lib/workspace-instance.d.ts +19 -3
  189. package/lib/workspace-instance.d.ts.map +1 -1
  190. package/lib/wsready.d.ts +1 -1
  191. package/lib/wsready.d.ts.map +1 -1
  192. package/lib/wsready.js +2 -2
  193. package/package.json +6 -6
  194. package/pkg-yarn.lock +5 -5
  195. package/provenance-bundle.jsonl +1 -1
  196. package/src/accounting-protocol.ts +63 -51
  197. package/src/admin-protocol.ts +23 -20
  198. package/src/analytics.ts +21 -21
  199. package/src/auth.ts +2 -2
  200. package/src/context-url.spec.ts +25 -11
  201. package/src/context-url.ts +80 -78
  202. package/src/email-protocol.ts +5 -6
  203. package/src/encryption/container-module.ts +2 -3
  204. package/src/encryption/encryption-engine.spec.ts +9 -8
  205. package/src/encryption/encryption-engine.ts +14 -14
  206. package/src/encryption/encryption-service.ts +4 -5
  207. package/src/encryption/key-provider.ts +16 -19
  208. package/src/env.ts +0 -22
  209. package/src/gitpod-file-parser.spec.ts +55 -61
  210. package/src/gitpod-file-parser.ts +16 -17
  211. package/src/gitpod-service.ts +152 -110
  212. package/src/headless-workspace-log.ts +6 -4
  213. package/src/ide-frontend-service.ts +2 -2
  214. package/src/ide-protocol.ts +8 -8
  215. package/src/index.ts +16 -16
  216. package/src/installation-admin-protocol.ts +8 -8
  217. package/src/license-protocol.ts +12 -6
  218. package/src/messaging/browser/connection.ts +45 -47
  219. package/src/messaging/browser/window-connection.ts +39 -29
  220. package/src/messaging/client-call-metrics.ts +70 -71
  221. package/src/messaging/error.ts +7 -3
  222. package/src/messaging/handler.ts +6 -6
  223. package/src/messaging/node/connection.ts +8 -8
  224. package/src/messaging/proxy-factory.ts +23 -30
  225. package/src/oss-allowlist.ts +3 -3
  226. package/src/payment-protocol.ts +2 -2
  227. package/src/permission.ts +20 -31
  228. package/src/plans.ts +236 -189
  229. package/src/protocol.ts +346 -239
  230. package/src/snapshot-url.spec.ts +9 -7
  231. package/src/team-subscription-protocol.ts +57 -23
  232. package/src/teams-projects-protocol.ts +14 -8
  233. package/src/typings/globals.ts +4 -4
  234. package/src/util/analytics.ts +46 -42
  235. package/src/util/async-iterator.ts +4 -5
  236. package/src/util/cancelable.ts +3 -3
  237. package/src/util/date-time.ts +8 -8
  238. package/src/util/deferred.ts +6 -6
  239. package/src/util/disposable.ts +3 -6
  240. package/src/util/event.ts +9 -11
  241. package/src/util/garbage-collected-cache.ts +3 -6
  242. package/src/util/generate-workspace-id.spec.ts +26 -16
  243. package/src/util/generate-workspace-id.ts +460 -454
  244. package/src/util/gitpod-cookie.ts +8 -9
  245. package/src/util/gitpod-host-url.spec.ts +40 -13
  246. package/src/util/gitpod-host-url.ts +37 -34
  247. package/src/util/grpc.ts +1 -1
  248. package/src/util/jaeger-client-types.ts +2 -2
  249. package/src/util/logging.ts +49 -40
  250. package/src/util/make-link.ts +6 -7
  251. package/src/util/parse-workspace-id.spec.ts +17 -8
  252. package/src/util/parse-workspace-id.ts +5 -6
  253. package/src/util/queue.spec.ts +27 -25
  254. package/src/util/repeat.ts +1 -1
  255. package/src/util/semaphore.ts +4 -6
  256. package/src/util/skip-if.ts +9 -6
  257. package/src/util/timeutil.spec.ts +14 -15
  258. package/src/util/timeutil.ts +21 -11
  259. package/src/util/tracing.spec.ts +28 -23
  260. package/src/util/tracing.ts +54 -51
  261. package/src/util/workspace-port-authentication.ts +10 -13
  262. package/src/workspace-cluster.ts +15 -12
  263. package/src/workspace-instance.ts +53 -24
  264. package/src/wsready.ts +3 -3
  265. package/data/builtin-theia-plugins.json +0 -372
  266. package/lib/theia-plugins.d.ts +0 -11
  267. package/lib/theia-plugins.d.ts.map +0 -1
  268. package/lib/theia-plugins.js +0 -8
  269. package/lib/theia-plugins.js.map +0 -1
  270. package/src/theia-plugins.ts +0 -11
@@ -4,16 +4,18 @@
4
4
  * See License-AGPL.txt in the project root for license information.
5
5
  */
6
6
 
7
- import { suite, test } from "mocha-typescript"
8
- import * as chai from "chai"
7
+ import { suite, test } from "mocha-typescript";
8
+ import * as chai from "chai";
9
9
  import { SnapshotUrl } from ".";
10
10
 
11
- const expect = chai.expect
12
-
13
- @suite class TestSnapshotUrlParser {
11
+ const expect = chai.expect;
14
12
 
13
+ @suite
14
+ class TestSnapshotUrlParser {
15
15
  @test public testPositive() {
16
- const actual = SnapshotUrl.parse("workspaces/c362d434-6faa-4ce0-9ad4-91b4a87c4abe/3f0556f7-4afa-11e9-98d5-52f8983b9279.tar@gitpod-prodcopy-user-e1e28f18-0354-4a5d-b6b4-8879a2ff73fd");
16
+ const actual = SnapshotUrl.parse(
17
+ "workspaces/c362d434-6faa-4ce0-9ad4-91b4a87c4abe/3f0556f7-4afa-11e9-98d5-52f8983b9279.tar@gitpod-prodcopy-user-e1e28f18-0354-4a5d-b6b4-8879a2ff73fd",
18
+ );
17
19
 
18
20
  expect(actual).to.deep.equal(<SnapshotUrl>{
19
21
  bucketId: "gitpod-prodcopy-user-e1e28f18-0354-4a5d-b6b4-8879a2ff73fd",
@@ -22,4 +24,4 @@ const expect = chai.expect
22
24
  });
23
25
  }
24
26
  }
25
- module.exports = new TestSnapshotUrlParser() // Only to circumvent no usage warning :-/
27
+ module.exports = new TestSnapshotUrlParser(); // Only to circumvent no usage warning :-/
@@ -4,7 +4,7 @@
4
4
  * See License-AGPL.txt in the project root for license information.
5
5
  */
6
6
 
7
- import { v4 as uuidv4 } from 'uuid';
7
+ import { v4 as uuidv4 } from "uuid";
8
8
  import { Subscription } from "./accounting-protocol";
9
9
 
10
10
  export interface TeamSubscription {
@@ -18,17 +18,43 @@ export interface TeamSubscription {
18
18
  paymentReference: string;
19
19
  cancellationDate?: string;
20
20
  deleted?: boolean;
21
+ /** If this flag is set slots are not eligibile for clusters with "more-resources" - even if their plan might be */
22
+ excludeFromMoreResources: boolean;
21
23
  }
22
24
 
23
25
  export namespace TeamSubscription {
24
- export const create = (ts: Omit<TeamSubscription, 'id'>): TeamSubscription => {
26
+ export const create = (ts: Omit<TeamSubscription, "id">): TeamSubscription => {
25
27
  const withId = ts as TeamSubscription;
26
28
  withId.id = uuidv4();
27
29
  return withId;
28
- }
30
+ };
29
31
  export const isActive = (ts: TeamSubscription, date: string): boolean => {
30
32
  return ts.startDate <= date && (ts.endDate === undefined || date < ts.endDate);
31
- }
33
+ };
34
+ }
35
+
36
+ export interface TeamSubscription2 {
37
+ id: string;
38
+ teamId: string;
39
+ planId: string;
40
+ startDate: string;
41
+ endDate?: string;
42
+ quantity: number;
43
+ /** The Chargebee subscription id */
44
+ paymentReference: string;
45
+ cancellationDate?: string;
46
+ excludeFromMoreResources: boolean;
47
+ }
48
+
49
+ export namespace TeamSubscription2 {
50
+ export const create = (ts2: Omit<TeamSubscription2, "id">): TeamSubscription2 => {
51
+ const withId = ts2 as TeamSubscription2;
52
+ withId.id = uuidv4();
53
+ return withId;
54
+ };
55
+ export const isActive = (ts2: TeamSubscription2, date: string): boolean => {
56
+ return ts2.startDate <= date && (ts2.endDate === undefined || date < ts2.endDate);
57
+ };
32
58
  }
33
59
 
34
60
  /**
@@ -42,49 +68,57 @@ export interface TeamSubscriptionSlot {
42
68
  subscriptionId?: string;
43
69
  cancellationDate?: string;
44
70
  }
45
- export type TeamSubscriptionSlotDeactivated = TeamSubscriptionSlot & { assigneeId: string, assigneeIdentifier: AssigneeIdentifier };
46
- export type TeamSubscriptionSlotAssigned = TeamSubscriptionSlot & TeamSubscriptionSlotDeactivated & { subscriptionId: string };
71
+ export type TeamSubscriptionSlotDeactivated = TeamSubscriptionSlot & {
72
+ assigneeId: string;
73
+ assigneeIdentifier: AssigneeIdentifier;
74
+ };
75
+ export type TeamSubscriptionSlotAssigned = TeamSubscriptionSlot &
76
+ TeamSubscriptionSlotDeactivated & { subscriptionId: string };
47
77
 
48
- export type TeamSubscriptionSlotState = 'unassigned' | 'assigned' | 'deactivated' | 'cancelled';
78
+ export type TeamSubscriptionSlotState = "unassigned" | "assigned" | "deactivated" | "cancelled";
49
79
 
50
80
  export namespace TeamSubscriptionSlot {
51
- export const create = (ts: Omit<TeamSubscriptionSlot, 'id'>): TeamSubscriptionSlot => {
81
+ export const create = (ts: Omit<TeamSubscriptionSlot, "id">): TeamSubscriptionSlot => {
52
82
  const withId = ts as TeamSubscriptionSlot;
53
83
  withId.id = uuidv4();
54
84
  return withId;
55
- }
56
- export const assign = (slot: TeamSubscriptionSlot, assigneeId: string, subscriptionId: string, assigneeIdentifier: AssigneeIdentifier) => {
85
+ };
86
+ export const assign = (
87
+ slot: TeamSubscriptionSlot,
88
+ assigneeId: string,
89
+ subscriptionId: string,
90
+ assigneeIdentifier: AssigneeIdentifier,
91
+ ) => {
57
92
  slot.assigneeId = assigneeId;
58
93
  slot.subscriptionId = subscriptionId;
59
94
  slot.assigneeIdentifier = assigneeIdentifier;
60
- }
95
+ };
61
96
  export const deactivate = (slot: TeamSubscriptionSlot, cancellationDate: string) => {
62
97
  slot.subscriptionId = undefined;
63
98
  slot.cancellationDate = cancellationDate;
64
- }
99
+ };
65
100
  export const reactivate = (slot: TeamSubscriptionSlot, subscriptionId?: string) => {
66
101
  slot.subscriptionId = subscriptionId;
67
102
  slot.cancellationDate = undefined;
68
- }
103
+ };
69
104
  export const status = (slot: TeamSubscriptionSlot, now: string): TeamSubscriptionSlotState => {
70
105
  if (slot.cancellationDate) {
71
106
  if (slot.cancellationDate < now) {
72
- return 'cancelled';
107
+ return "cancelled";
73
108
  } else {
74
- return 'deactivated';
109
+ return "deactivated";
75
110
  }
76
111
  } else {
77
112
  if (slot.subscriptionId) {
78
- return 'assigned';
113
+ return "assigned";
79
114
  } else {
80
- return 'unassigned';
115
+ return "unassigned";
81
116
  }
82
117
  }
83
-
84
- }
118
+ };
85
119
  export const isActive = (slot: TeamSubscriptionSlot): boolean => {
86
120
  return !slot.cancellationDate;
87
- }
121
+ };
88
122
  }
89
123
 
90
124
  /**
@@ -107,7 +141,7 @@ export interface TeamSubscriptionSlotResolved {
107
141
  export type AssigneeIdentifier = AssigneeIdentityIdentifier;
108
142
  export interface AssigneeIdentityIdentifier {
109
143
  identity: {
110
- authHost: string,
111
- authName: string
112
- }
144
+ authHost: string;
145
+ authName: string;
146
+ };
113
147
  }
@@ -5,15 +5,16 @@
5
5
  */
6
6
 
7
7
  import { PrebuiltWorkspaceState } from "./protocol";
8
- import { v4 as uuidv4 } from 'uuid';
8
+ import { v4 as uuidv4 } from "uuid";
9
9
  import { DeepPartial } from "./util/deep-partial";
10
10
 
11
11
  export interface ProjectConfig {
12
- '.gitpod.yml': string;
12
+ ".gitpod.yml": string;
13
13
  }
14
14
 
15
15
  export interface ProjectSettings {
16
16
  useIncrementalPrebuilds?: boolean;
17
+ usePersistentVolumeClaim?: boolean;
17
18
  }
18
19
 
19
20
  export interface Project {
@@ -33,13 +34,13 @@ export interface Project {
33
34
  }
34
35
 
35
36
  export namespace Project {
36
- export const create = (project: Omit<Project, 'id' | 'creationTime'>): Project => {
37
+ export const create = (project: Omit<Project, "id" | "creationTime">): Project => {
37
38
  return {
38
39
  ...project,
39
40
  id: uuidv4(),
40
- creationTime: new Date().toISOString()
41
+ creationTime: new Date().toISOString(),
41
42
  };
42
- }
43
+ };
43
44
 
44
45
  export interface Overview {
45
46
  branches: BranchDetails[];
@@ -67,7 +68,12 @@ export namespace Project {
67
68
  }
68
69
  }
69
70
 
70
- export type PartialProject = DeepPartial<Project> & Pick<Project, 'id'>;
71
+ export type PartialProject = DeepPartial<Project> & Pick<Project, "id">;
72
+
73
+ export interface ProjectUsage {
74
+ lastWebhookReceived: string;
75
+ lastWorkspaceStart: string;
76
+ }
71
77
 
72
78
  export interface PrebuildWithStatus {
73
79
  info: PrebuildInfo;
@@ -103,7 +109,7 @@ export interface PrebuildInfo {
103
109
  }
104
110
  export namespace PrebuildInfo {
105
111
  export function is(data?: any): data is PrebuildInfo {
106
- return typeof data === "object" && ["id", "buildWorkspaceId", "projectId", "branch"].every(p => p in data);
112
+ return typeof data === "object" && ["id", "buildWorkspaceId", "projectId", "branch"].every((p) => p in data);
107
113
  }
108
114
  }
109
115
 
@@ -144,4 +150,4 @@ export interface TeamMembershipInvite {
144
150
 
145
151
  /** This is a flag that triggers the HARD DELETION of this entity */
146
152
  deleted?: boolean;
147
- }
153
+ }
@@ -6,7 +6,7 @@
6
6
 
7
7
  interface Window {
8
8
  gitpod: {
9
- service: import('../gitpod-service').GitpodService
10
- ideService?: import('../ide-frontend-service').IDEFrontendService
11
- }
12
- }
9
+ service: import("../gitpod-service").GitpodService;
10
+ ideService?: import("../ide-frontend-service").IDEFrontendService;
11
+ };
12
+ }
@@ -6,8 +6,7 @@
6
6
 
7
7
  import Analytics = require("analytics-node");
8
8
  import { IAnalyticsWriter, IdentifyMessage, TrackMessage, PageMessage } from "../analytics";
9
- import { log } from './logging';
10
-
9
+ import { log } from "./logging";
11
10
 
12
11
  export function newAnalyticsWriterFromEnv(): IAnalyticsWriter {
13
12
  switch (process.env.GITPOD_ANALYTICS_WRITER) {
@@ -21,26 +20,28 @@ export function newAnalyticsWriterFromEnv(): IAnalyticsWriter {
21
20
  }
22
21
 
23
22
  class SegmentAnalyticsWriter implements IAnalyticsWriter {
24
-
25
23
  protected readonly analytics: Analytics;
26
24
 
27
25
  constructor(writeKey: string) {
28
26
  this.analytics = new Analytics(writeKey);
29
27
  }
30
28
 
31
- identify(msg: IdentifyMessage) {
29
+ identify(msg: IdentifyMessage) {
32
30
  try {
33
- this.analytics.identify({
34
- ...msg,
35
- integrations: {
36
- "All": true,
37
- "Mixpanel": !!msg.userId
38
- }
39
- }, (err: Error) => {
40
- if (err) {
41
- log.warn("analytics.identify failed", err);
42
- }
43
- });
31
+ this.analytics.identify(
32
+ {
33
+ ...msg,
34
+ integrations: {
35
+ All: true,
36
+ Mixpanel: !!msg.userId,
37
+ },
38
+ },
39
+ (err: Error) => {
40
+ if (err) {
41
+ log.warn("analytics.identify failed", err);
42
+ }
43
+ },
44
+ );
44
45
  } catch (err) {
45
46
  log.warn("analytics.identify failed", err);
46
47
  }
@@ -48,44 +49,48 @@ class SegmentAnalyticsWriter implements IAnalyticsWriter {
48
49
 
49
50
  track(msg: TrackMessage) {
50
51
  try {
51
- this.analytics.track({
52
- ...msg,
53
- integrations: {
54
- "All": true,
55
- "Mixpanel": !!msg.userId
56
- }
57
- }, (err: Error) => {
58
- if (err) {
59
- log.warn("analytics.track failed", err);
60
- }
61
- });
52
+ this.analytics.track(
53
+ {
54
+ ...msg,
55
+ integrations: {
56
+ All: true,
57
+ Mixpanel: !!msg.userId,
58
+ },
59
+ },
60
+ (err: Error) => {
61
+ if (err) {
62
+ log.warn("analytics.track failed", err);
63
+ }
64
+ },
65
+ );
62
66
  } catch (err) {
63
67
  log.warn("analytics.track failed", err);
64
68
  }
65
69
  }
66
70
 
67
71
  page(msg: PageMessage) {
68
- try{
69
- this.analytics.page({
70
- ...msg,
71
- integrations: {
72
- "All": true,
73
- "Mixpanel": !!msg.userId
74
- }
75
- }, (err: Error) => {
76
- if (err) {
77
- log.warn("analytics.page failed", err);
78
- }
79
- });
72
+ try {
73
+ this.analytics.page(
74
+ {
75
+ ...msg,
76
+ integrations: {
77
+ All: true,
78
+ Mixpanel: !!msg.userId,
79
+ },
80
+ },
81
+ (err: Error) => {
82
+ if (err) {
83
+ log.warn("analytics.page failed", err);
84
+ }
85
+ },
86
+ );
80
87
  } catch (err) {
81
88
  log.warn("analytics.page failed", err);
82
89
  }
83
90
  }
84
-
85
91
  }
86
92
 
87
93
  class LogAnalyticsWriter implements IAnalyticsWriter {
88
-
89
94
  identify(msg: IdentifyMessage): void {
90
95
  log.debug("analytics identify", msg);
91
96
  }
@@ -95,11 +100,10 @@ class LogAnalyticsWriter implements IAnalyticsWriter {
95
100
  page(msg: PageMessage): void {
96
101
  log.debug("analytics page", msg);
97
102
  }
98
-
99
103
  }
100
104
 
101
105
  class NoAnalyticsWriter implements IAnalyticsWriter {
102
106
  identify(msg: IdentifyMessage): void {}
103
107
  track(msg: TrackMessage): void {}
104
108
  page(msg: PageMessage): void {}
105
- }
109
+ }
@@ -5,8 +5,8 @@
5
5
  */
6
6
 
7
7
  // Use asyncIterators with es2015
8
- if (typeof (Symbol as any).asyncIterator === 'undefined') {
9
- (Symbol as any).asyncIterator = Symbol.asyncIterator || Symbol('asyncIterator');
8
+ if (typeof (Symbol as any).asyncIterator === "undefined") {
9
+ (Symbol as any).asyncIterator = Symbol.asyncIterator || Symbol("asyncIterator");
10
10
  }
11
11
 
12
12
  export async function find<T>(it: AsyncIterableIterator<T>, predicate: (value: T) => boolean): Promise<T | undefined> {
@@ -31,12 +31,11 @@ export interface AsyncCachingIterator<T> extends AsyncIterableIterator<T> {
31
31
  resetCursor(): void;
32
32
  }
33
33
  export class AsyncCachingIteratorImpl<T> implements AsyncIterableIterator<T>, AsyncCachingIterator<T> {
34
-
35
34
  protected cache: T[] = [];
36
35
  protected cursor = 0;
37
36
  protected cacheRead = false;
38
37
 
39
- constructor(protected readonly iterable: AsyncIterableIterator<T>) { }
38
+ constructor(protected readonly iterable: AsyncIterableIterator<T>) {}
40
39
 
41
40
  public resetCursor() {
42
41
  this.cursor = 0;
@@ -47,7 +46,7 @@ export class AsyncCachingIteratorImpl<T> implements AsyncIterableIterator<T>, As
47
46
  if (!this.cacheRead && this.cursor < this.cache.length) {
48
47
  return {
49
48
  done: false,
50
- value: this.cache[this.cursor++]
49
+ value: this.cache[this.cursor++],
51
50
  };
52
51
  }
53
52
  this.cacheRead = true;
@@ -9,10 +9,10 @@ import { Disposable } from "./disposable";
9
9
  export class Cancelable<T> implements Disposable {
10
10
  protected canceled: boolean;
11
11
 
12
- constructor(protected readonly activity: (cancel: boolean) => Promise<T> | undefined) { }
12
+ constructor(protected readonly activity: (cancel: boolean) => Promise<T> | undefined) {}
13
13
 
14
14
  public async run(): Promise<T | undefined> {
15
- for(let r = await this.activity(this.canceled); ; r = await this.activity(this.canceled)) {
15
+ for (let r = await this.activity(this.canceled); ; r = await this.activity(this.canceled)) {
16
16
  if (this.canceled) {
17
17
  return;
18
18
  } else if (r !== undefined) {
@@ -28,4 +28,4 @@ export class Cancelable<T> implements Disposable {
28
28
  dispose(): void {
29
29
  this.cancel();
30
30
  }
31
- }
31
+ }
@@ -5,26 +5,26 @@
5
5
  */
6
6
 
7
7
  export function formatDate(date?: string) {
8
- return date ? new Date(date).toLocaleString() : '';
8
+ return date ? new Date(date).toLocaleString() : "";
9
9
  }
10
10
 
11
11
  export function formatHours(hours?: number) {
12
12
  if (hours === undefined) {
13
- return '';
13
+ return "";
14
14
  }
15
15
  const h = Math.floor(Math.abs(hours));
16
- const rm = (Math.abs(hours) - h) * 60.;
16
+ const rm = (Math.abs(hours) - h) * 60;
17
17
  const m = Math.floor(rm);
18
- const rs = (rm - m) * 60.;
18
+ const rs = (rm - m) * 60;
19
19
  const s = Math.floor(rs);
20
- const result = h + ':' + pad2(m) + ':' + pad2(s);
20
+ const result = h + ":" + pad2(m) + ":" + pad2(s);
21
21
  if (hours < 0) {
22
- return `-${result}`
22
+ return `-${result}`;
23
23
  } else {
24
- return `${result}`
24
+ return `${result}`;
25
25
  }
26
26
  }
27
27
 
28
28
  function pad2(n: number) {
29
- return n < 10 ? '0' + n : '' + n;
29
+ return n < 10 ? "0" + n : "" + n;
30
30
  }
@@ -19,12 +19,12 @@ export class Deferred<T> {
19
19
  promise = new Promise<T>((resolve, reject) => {
20
20
  this.resolve = (o) => {
21
21
  this.isResolved = true;
22
- resolve(o as any)
23
- clearTimeout(this.timer)
22
+ resolve(o as any);
23
+ clearTimeout(this.timer);
24
24
  };
25
25
  this.reject = (e) => {
26
- reject(e)
27
- clearTimeout(this.timer)
28
- }
26
+ reject(e);
27
+ clearTimeout(this.timer);
28
+ };
29
29
  });
30
- }
30
+ }
@@ -16,10 +16,10 @@ export interface Disposable {
16
16
  export namespace Disposable {
17
17
  export function create(func: () => void): Disposable {
18
18
  return {
19
- dispose: func
19
+ dispose: func,
20
20
  };
21
21
  }
22
- export const NULL = create(() => { });
22
+ export const NULL = create(() => {});
23
23
  }
24
24
 
25
25
  export class DisposableCollection implements Disposable {
@@ -69,9 +69,6 @@ export class DisposableCollection implements Disposable {
69
69
  }
70
70
 
71
71
  pushAll(disposables: Disposable[]): Disposable[] {
72
- return disposables.map(disposable =>
73
- this.push(disposable)
74
- );
72
+ return disposables.map((disposable) => this.push(disposable));
75
73
  }
76
-
77
74
  }
package/src/util/event.ts CHANGED
@@ -6,13 +6,12 @@
6
6
  */
7
7
 
8
8
  import { Disposable } from "./disposable";
9
- import { log } from './logging';
9
+ import { log } from "./logging";
10
10
 
11
11
  /**
12
12
  * Represents a typed event.
13
13
  */
14
14
  export interface Event<T> {
15
-
16
15
  /**
17
16
  *
18
17
  * @param listener The listener function will be call when the event happens.
@@ -24,12 +23,13 @@ export interface Event<T> {
24
23
  }
25
24
 
26
25
  export namespace Event {
27
- const _disposable = { dispose() { } };
28
- export const None: Event<any> = function () { return _disposable; };
26
+ const _disposable = { dispose() {} };
27
+ export const None: Event<any> = function () {
28
+ return _disposable;
29
+ };
29
30
  }
30
31
 
31
32
  class CallbackList {
32
-
33
33
  private _callbacks: Function[] | undefined;
34
34
  private _contexts: any[] | undefined;
35
35
 
@@ -66,7 +66,7 @@ class CallbackList {
66
66
  }
67
67
 
68
68
  if (foundCallbackWithDifferentContext) {
69
- throw new Error('When adding a listener with a context, you should remove it with the same context');
69
+ throw new Error("When adding a listener with a context, you should remove it with the same context");
70
70
  }
71
71
  }
72
72
 
@@ -105,14 +105,12 @@ export interface EmitterOptions {
105
105
  }
106
106
 
107
107
  export class Emitter<T> {
108
-
109
- private static _noop = function () { };
108
+ private static _noop = function () {};
110
109
 
111
110
  private _event: Event<T>;
112
111
  private _callbacks: CallbackList | undefined;
113
112
 
114
- constructor(private _options?: EmitterOptions) {
115
- }
113
+ constructor(private _options?: EmitterOptions) {}
116
114
 
117
115
  /**
118
116
  * For the public to allow to subscribe
@@ -137,7 +135,7 @@ export class Emitter<T> {
137
135
  if (this._options && this._options.onLastListenerRemove && this._callbacks!.isEmpty()) {
138
136
  this._options.onLastListenerRemove(this);
139
137
  }
140
- }
138
+ },
141
139
  };
142
140
  if (Array.isArray(disposables)) {
143
141
  disposables.push(result);
@@ -6,7 +6,6 @@
6
6
 
7
7
  import { repeat } from "./repeat";
8
8
 
9
-
10
9
  interface CacheEntry<T> {
11
10
  key: string;
12
11
  value: T;
@@ -16,9 +15,7 @@ interface CacheEntry<T> {
16
15
  export class GarbageCollectedCache<T> {
17
16
  protected readonly store = new Map<string, CacheEntry<T>>();
18
17
 
19
- constructor(
20
- protected readonly defaultMaxAgeSeconds: number,
21
- protected readonly gcIntervalSeconds: number) {
18
+ constructor(protected readonly defaultMaxAgeSeconds: number, protected readonly gcIntervalSeconds: number) {
22
19
  this.regularlyCollectGarbage();
23
20
  }
24
21
 
@@ -61,6 +58,6 @@ export class GarbageCollectedCache<T> {
61
58
  }
62
59
 
63
60
  protected calcExpiryDate(maxAgeSeconds?: number): number {
64
- return Date.now() + ((maxAgeSeconds || this.defaultMaxAgeSeconds) * 1000);
61
+ return Date.now() + (maxAgeSeconds || this.defaultMaxAgeSeconds) * 1000;
65
62
  }
66
- }
63
+ }