@gitpod/gitpod-protocol 0.1.5-vn-integrate-gitpod-yml-tasks-into-jetbrainsa.5 → 0.1.5-vn-6525.77

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 (267) hide show
  1. package/data/gitpod-schema.json +28 -2
  2. package/lib/accounting-protocol.d.ts +10 -10
  3. package/lib/accounting-protocol.d.ts.map +1 -1
  4. package/lib/accounting-protocol.js +22 -31
  5. package/lib/accounting-protocol.js.map +1 -1
  6. package/lib/admin-protocol.d.ts +4 -2
  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 +4 -5
  10. package/lib/analytics.d.ts.map +1 -1
  11. package/lib/analytics.js.map +1 -1
  12. package/lib/auth.d.ts.map +1 -1
  13. package/lib/context-url.d.ts.map +1 -1
  14. package/lib/context-url.js +3 -3
  15. package/lib/context-url.js.map +1 -1
  16. package/lib/context-url.spec.d.ts.map +1 -1
  17. package/lib/context-url.spec.js +20 -5
  18. package/lib/context-url.spec.js.map +1 -1
  19. package/lib/email-protocol.d.ts +1 -1
  20. package/lib/email-protocol.d.ts.map +1 -1
  21. package/lib/email-protocol.js.map +1 -1
  22. package/lib/encryption/container-module.d.ts.map +1 -1
  23. package/lib/encryption/container-module.js +1 -1
  24. package/lib/encryption/container-module.js.map +1 -1
  25. package/lib/encryption/encryption-engine.d.ts.map +1 -1
  26. package/lib/encryption/encryption-engine.js +7 -7
  27. package/lib/encryption/encryption-engine.js.map +1 -1
  28. package/lib/encryption/encryption-engine.spec.d.ts.map +1 -1
  29. package/lib/encryption/encryption-engine.spec.js +2 -3
  30. package/lib/encryption/encryption-engine.spec.js.map +1 -1
  31. package/lib/encryption/encryption-service.d.ts.map +1 -1
  32. package/lib/encryption/encryption-service.js +1 -1
  33. package/lib/encryption/encryption-service.js.map +1 -1
  34. package/lib/encryption/key-provider.d.ts.map +1 -1
  35. package/lib/encryption/key-provider.js +7 -9
  36. package/lib/encryption/key-provider.js.map +1 -1
  37. package/lib/env.d.ts +1 -1
  38. package/lib/env.d.ts.map +1 -1
  39. package/lib/env.js +5 -5
  40. package/lib/env.js.map +1 -1
  41. package/lib/gitpod-file-parser.d.ts.map +1 -1
  42. package/lib/gitpod-file-parser.js +6 -6
  43. package/lib/gitpod-file-parser.js.map +1 -1
  44. package/lib/gitpod-file-parser.spec.js +42 -39
  45. package/lib/gitpod-file-parser.spec.js.map +1 -1
  46. package/lib/gitpod-service.d.ts +23 -26
  47. package/lib/gitpod-service.d.ts.map +1 -1
  48. package/lib/gitpod-service.js +32 -26
  49. package/lib/gitpod-service.js.map +1 -1
  50. package/lib/headless-workspace-log.d.ts +1 -0
  51. package/lib/headless-workspace-log.d.ts.map +1 -1
  52. package/lib/headless-workspace-log.js +2 -1
  53. package/lib/headless-workspace-log.js.map +1 -1
  54. package/lib/ide-frontend-service.d.ts +1 -1
  55. package/lib/ide-protocol.d.ts +6 -6
  56. package/lib/ide-protocol.d.ts.map +1 -1
  57. package/lib/index.d.ts +16 -16
  58. package/lib/installation-admin-protocol.d.ts +1 -1
  59. package/lib/installation-admin-protocol.d.ts.map +1 -1
  60. package/lib/installation-admin-protocol.js +2 -2
  61. package/lib/installation-admin-protocol.js.map +1 -1
  62. package/lib/license-protocol.d.ts.map +1 -1
  63. package/lib/license-protocol.js.map +1 -1
  64. package/lib/messaging/browser/connection.d.ts +1 -1
  65. package/lib/messaging/browser/connection.d.ts.map +1 -1
  66. package/lib/messaging/browser/connection.js +19 -19
  67. package/lib/messaging/browser/connection.js.map +1 -1
  68. package/lib/messaging/browser/window-connection.d.ts +4 -4
  69. package/lib/messaging/browser/window-connection.d.ts.map +1 -1
  70. package/lib/messaging/browser/window-connection.js +9 -6
  71. package/lib/messaging/browser/window-connection.js.map +1 -1
  72. package/lib/messaging/client-call-metrics.d.ts +2 -2
  73. package/lib/messaging/client-call-metrics.d.ts.map +1 -1
  74. package/lib/messaging/client-call-metrics.js +20 -20
  75. package/lib/messaging/client-call-metrics.js.map +1 -1
  76. package/lib/messaging/error.d.ts.map +1 -1
  77. package/lib/messaging/error.js.map +1 -1
  78. package/lib/messaging/handler.d.ts.map +1 -1
  79. package/lib/messaging/handler.js +1 -1
  80. package/lib/messaging/node/connection.js +8 -8
  81. package/lib/messaging/node/connection.js.map +1 -1
  82. package/lib/messaging/proxy-factory.d.ts +1 -1
  83. package/lib/messaging/proxy-factory.d.ts.map +1 -1
  84. package/lib/messaging/proxy-factory.js +7 -9
  85. package/lib/messaging/proxy-factory.js.map +1 -1
  86. package/lib/payment-protocol.d.ts.map +1 -1
  87. package/lib/payment-protocol.js +1 -1
  88. package/lib/payment-protocol.js.map +1 -1
  89. package/lib/permission.d.ts +2 -2
  90. package/lib/permission.d.ts.map +1 -1
  91. package/lib/permission.js +12 -23
  92. package/lib/permission.js.map +1 -1
  93. package/lib/plans.d.ts +3 -3
  94. package/lib/plans.d.ts.map +1 -1
  95. package/lib/plans.js +206 -171
  96. package/lib/plans.js.map +1 -1
  97. package/lib/protocol.d.ts +53 -37
  98. package/lib/protocol.d.ts.map +1 -1
  99. package/lib/protocol.js +85 -86
  100. package/lib/protocol.js.map +1 -1
  101. package/lib/snapshot-url.spec.js.map +1 -1
  102. package/lib/team-subscription-protocol.d.ts +5 -3
  103. package/lib/team-subscription-protocol.d.ts.map +1 -1
  104. package/lib/team-subscription-protocol.js +4 -4
  105. package/lib/team-subscription-protocol.js.map +1 -1
  106. package/lib/teams-projects-protocol.d.ts +3 -3
  107. package/lib/teams-projects-protocol.d.ts.map +1 -1
  108. package/lib/teams-projects-protocol.js +1 -1
  109. package/lib/teams-projects-protocol.js.map +1 -1
  110. package/lib/typings/globals.d.ts +2 -2
  111. package/lib/typings/globals.d.ts.map +1 -1
  112. package/lib/util/analytics.d.ts.map +1 -1
  113. package/lib/util/analytics.js +12 -3
  114. package/lib/util/analytics.js.map +1 -1
  115. package/lib/util/async-iterator.d.ts.map +1 -1
  116. package/lib/util/async-iterator.js +3 -3
  117. package/lib/util/async-iterator.js.map +1 -1
  118. package/lib/util/cancelable.js.map +1 -1
  119. package/lib/util/date-time.js +6 -6
  120. package/lib/util/date-time.js.map +1 -1
  121. package/lib/util/deferred.js.map +1 -1
  122. package/lib/util/disposable.d.ts.map +1 -1
  123. package/lib/util/disposable.js +2 -2
  124. package/lib/util/disposable.js.map +1 -1
  125. package/lib/util/event.d.ts.map +1 -1
  126. package/lib/util/event.js +5 -3
  127. package/lib/util/event.js.map +1 -1
  128. package/lib/util/garbage-collected-cache.d.ts.map +1 -1
  129. package/lib/util/garbage-collected-cache.js +1 -1
  130. package/lib/util/garbage-collected-cache.js.map +1 -1
  131. package/lib/util/generate-workspace-id.d.ts.map +1 -1
  132. package/lib/util/generate-workspace-id.js +435 -435
  133. package/lib/util/generate-workspace-id.js.map +1 -1
  134. package/lib/util/generate-workspace-id.spec.js +10 -6
  135. package/lib/util/generate-workspace-id.spec.js.map +1 -1
  136. package/lib/util/gitpod-cookie.d.ts +1 -1
  137. package/lib/util/gitpod-cookie.d.ts.map +1 -1
  138. package/lib/util/gitpod-cookie.js +0 -3
  139. package/lib/util/gitpod-cookie.js.map +1 -1
  140. package/lib/util/gitpod-host-url.d.ts.map +1 -1
  141. package/lib/util/gitpod-host-url.js +31 -29
  142. package/lib/util/gitpod-host-url.js.map +1 -1
  143. package/lib/util/gitpod-host-url.spec.d.ts.map +1 -1
  144. package/lib/util/gitpod-host-url.spec.js +15 -5
  145. package/lib/util/gitpod-host-url.spec.js.map +1 -1
  146. package/lib/util/grpc.d.ts.map +1 -1
  147. package/lib/util/grpc.js.map +1 -1
  148. package/lib/util/jaeger-client-types.d.ts.map +1 -1
  149. package/lib/util/logging.d.ts +1 -1
  150. package/lib/util/logging.d.ts.map +1 -1
  151. package/lib/util/logging.js +22 -23
  152. package/lib/util/logging.js.map +1 -1
  153. package/lib/util/make-link.js +5 -5
  154. package/lib/util/make-link.js.map +1 -1
  155. package/lib/util/parse-workspace-id.d.ts.map +1 -1
  156. package/lib/util/parse-workspace-id.js +1 -2
  157. package/lib/util/parse-workspace-id.js.map +1 -1
  158. package/lib/util/parse-workspace-id.spec.d.ts.map +1 -1
  159. package/lib/util/parse-workspace-id.spec.js.map +1 -1
  160. package/lib/util/queue.spec.js +9 -6
  161. package/lib/util/queue.spec.js.map +1 -1
  162. package/lib/util/semaphore.d.ts.map +1 -1
  163. package/lib/util/semaphore.js.map +1 -1
  164. package/lib/util/skip-if.d.ts.map +1 -1
  165. package/lib/util/skip-if.js.map +1 -1
  166. package/lib/util/timeutil.d.ts.map +1 -1
  167. package/lib/util/timeutil.js +2 -2
  168. package/lib/util/timeutil.js.map +1 -1
  169. package/lib/util/timeutil.spec.d.ts.map +1 -1
  170. package/lib/util/timeutil.spec.js.map +1 -1
  171. package/lib/util/tracing.d.ts +6 -6
  172. package/lib/util/tracing.d.ts.map +1 -1
  173. package/lib/util/tracing.js +6 -6
  174. package/lib/util/tracing.js.map +1 -1
  175. package/lib/util/tracing.spec.js +3 -3
  176. package/lib/util/tracing.spec.js.map +1 -1
  177. package/lib/util/workspace-port-authentication.d.ts +7 -7
  178. package/lib/util/workspace-port-authentication.d.ts.map +1 -1
  179. package/lib/util/workspace-port-authentication.js +8 -11
  180. package/lib/util/workspace-port-authentication.js.map +1 -1
  181. package/lib/workspace-cluster.d.ts +1 -1
  182. package/lib/workspace-cluster.d.ts.map +1 -1
  183. package/lib/workspace-cluster.js +2 -4
  184. package/lib/workspace-cluster.js.map +1 -1
  185. package/lib/workspace-instance.d.ts +2 -2
  186. package/lib/workspace-instance.d.ts.map +1 -1
  187. package/lib/wsready.d.ts +1 -1
  188. package/lib/wsready.d.ts.map +1 -1
  189. package/lib/wsready.js +2 -2
  190. package/package.json +2 -2
  191. package/pkg-yarn.lock +2 -2
  192. package/provenance-bundle.jsonl +1 -1
  193. package/src/accounting-protocol.ts +53 -51
  194. package/src/admin-protocol.ts +25 -21
  195. package/src/analytics.ts +26 -28
  196. package/src/auth.ts +2 -2
  197. package/src/context-url.spec.ts +25 -11
  198. package/src/context-url.ts +80 -78
  199. package/src/email-protocol.ts +5 -6
  200. package/src/encryption/container-module.ts +2 -3
  201. package/src/encryption/encryption-engine.spec.ts +9 -8
  202. package/src/encryption/encryption-engine.ts +14 -14
  203. package/src/encryption/encryption-service.ts +4 -5
  204. package/src/encryption/key-provider.ts +16 -19
  205. package/src/env.ts +9 -9
  206. package/src/gitpod-file-parser.spec.ts +55 -61
  207. package/src/gitpod-file-parser.ts +16 -17
  208. package/src/gitpod-service.ts +130 -104
  209. package/src/headless-workspace-log.ts +6 -4
  210. package/src/ide-frontend-service.ts +2 -2
  211. package/src/ide-protocol.ts +8 -8
  212. package/src/index.ts +16 -16
  213. package/src/installation-admin-protocol.ts +9 -9
  214. package/src/license-protocol.ts +5 -6
  215. package/src/messaging/browser/connection.ts +45 -47
  216. package/src/messaging/browser/window-connection.ts +39 -29
  217. package/src/messaging/client-call-metrics.ts +70 -71
  218. package/src/messaging/error.ts +1 -3
  219. package/src/messaging/handler.ts +6 -6
  220. package/src/messaging/node/connection.ts +8 -8
  221. package/src/messaging/proxy-factory.ts +23 -30
  222. package/src/oss-allowlist.ts +3 -3
  223. package/src/payment-protocol.ts +2 -2
  224. package/src/permission.ts +20 -31
  225. package/src/plans.ts +236 -189
  226. package/src/protocol.ts +239 -239
  227. package/src/snapshot-url.spec.ts +9 -7
  228. package/src/team-subscription-protocol.ts +33 -23
  229. package/src/teams-projects-protocol.ts +8 -8
  230. package/src/typings/globals.ts +4 -4
  231. package/src/util/analytics.ts +46 -24
  232. package/src/util/async-iterator.ts +4 -5
  233. package/src/util/cancelable.ts +3 -3
  234. package/src/util/date-time.ts +8 -8
  235. package/src/util/deferred.ts +6 -6
  236. package/src/util/disposable.ts +3 -6
  237. package/src/util/event.ts +9 -11
  238. package/src/util/garbage-collected-cache.ts +3 -6
  239. package/src/util/generate-workspace-id.spec.ts +18 -15
  240. package/src/util/generate-workspace-id.ts +453 -453
  241. package/src/util/gitpod-cookie.ts +8 -9
  242. package/src/util/gitpod-host-url.spec.ts +40 -13
  243. package/src/util/gitpod-host-url.ts +37 -34
  244. package/src/util/grpc.ts +1 -1
  245. package/src/util/jaeger-client-types.ts +2 -2
  246. package/src/util/logging.ts +49 -39
  247. package/src/util/make-link.ts +6 -7
  248. package/src/util/parse-workspace-id.spec.ts +17 -8
  249. package/src/util/parse-workspace-id.ts +5 -6
  250. package/src/util/queue.spec.ts +27 -25
  251. package/src/util/repeat.ts +1 -1
  252. package/src/util/semaphore.ts +4 -6
  253. package/src/util/skip-if.ts +9 -6
  254. package/src/util/timeutil.spec.ts +14 -15
  255. package/src/util/timeutil.ts +15 -11
  256. package/src/util/tracing.spec.ts +28 -23
  257. package/src/util/tracing.ts +46 -41
  258. package/src/util/workspace-port-authentication.ts +10 -13
  259. package/src/workspace-cluster.ts +15 -12
  260. package/src/workspace-instance.ts +27 -23
  261. package/src/wsready.ts +3 -3
  262. package/data/builtin-theia-plugins.json +0 -372
  263. package/lib/theia-plugins.d.ts +0 -11
  264. package/lib/theia-plugins.d.ts.map +0 -1
  265. package/lib/theia-plugins.js +0 -8
  266. package/lib/theia-plugins.js.map +0 -1
  267. package/src/theia-plugins.ts +0 -11
@@ -6,8 +6,7 @@
6
6
 
7
7
  import { User, Workspace, NamedWorkspaceFeatureFlag } from "./protocol";
8
8
  import { FindPrebuildsParams } from "./gitpod-service";
9
- import { PrebuildWithStatus } from "./teams-projects-protocol"
10
- import { Project, Team } from "./teams-projects-protocol";
9
+ import { Project, Team, PrebuildWithStatus, TeamMemberInfo, TeamMemberRole } from "./teams-projects-protocol";
11
10
  import { WorkspaceInstance, WorkspaceInstancePhase } from "./workspace-instance";
12
11
  import { RoleOrPermission } from "./permission";
13
12
  import { AccountStatement } from "./accounting-protocol";
@@ -21,7 +20,10 @@ export interface AdminServer {
21
20
  adminModifyRoleOrPermission(req: AdminModifyRoleOrPermissionRequest): Promise<User>;
22
21
  adminModifyPermanentWorkspaceFeatureFlag(req: AdminModifyPermanentWorkspaceFeatureFlagRequest): Promise<User>;
23
22
 
23
+ adminGetTeamMembers(teamId: string): Promise<TeamMemberInfo[]>;
24
+ adminGetTeams(req: AdminGetListRequest<Team>): Promise<AdminGetListResult<Team>>;
24
25
  adminGetTeamById(id: string): Promise<Team | undefined>;
26
+ adminSetTeamMemberRole(teamId: string, userId: string, role: TeamMemberRole): Promise<void>;
25
27
 
26
28
  adminGetWorkspaces(req: AdminGetWorkspacesRequest): Promise<AdminGetListResult<WorkspaceAndInstance>>;
27
29
  adminGetWorkspace(id: string): Promise<WorkspaceAndInstance>;
@@ -40,45 +42,47 @@ export interface AdminServer {
40
42
  adminAddStudentEmailDomain(userId: string, domain: string): Promise<void>;
41
43
  adminGrantExtraHours(userId: string, extraHours: number): Promise<void>;
42
44
 
43
- adminGetSettings(): Promise<InstallationAdminSettings>
44
- adminUpdateSettings(settings: InstallationAdminSettings): Promise<void>
45
+ adminGetSettings(): Promise<InstallationAdminSettings>;
46
+ adminUpdateSettings(settings: InstallationAdminSettings): Promise<void>;
45
47
  }
46
48
 
47
49
  export interface AdminGetListRequest<T> {
48
- offset: number
49
- limit: number
50
- orderBy: keyof T
51
- orderDir: "asc" | "desc"
50
+ offset: number;
51
+ limit: number;
52
+ orderBy: keyof T;
53
+ orderDir: "asc" | "desc";
52
54
  searchTerm?: string;
53
55
  }
54
56
 
55
57
  export interface AdminGetListResult<T> {
56
- total: number
57
- rows: T[]
58
+ total: number;
59
+ rows: T[];
58
60
  }
59
61
 
60
62
  export interface AdminBlockUserRequest {
61
- id: string
62
- blocked: boolean
63
+ id: string;
64
+ blocked: boolean;
63
65
  }
64
66
 
65
67
  export interface AdminModifyRoleOrPermissionRequest {
66
68
  id: string;
67
69
  rpp: {
68
- r: RoleOrPermission
69
- add: boolean
70
- }[]
70
+ r: RoleOrPermission;
71
+ add: boolean;
72
+ }[];
71
73
  }
72
74
 
73
75
  export interface AdminModifyPermanentWorkspaceFeatureFlagRequest {
74
76
  id: string;
75
77
  changes: {
76
- featureFlag: NamedWorkspaceFeatureFlag
77
- add: boolean
78
- }[]
78
+ featureFlag: NamedWorkspaceFeatureFlag;
79
+ add: boolean;
80
+ }[];
79
81
  }
80
82
 
81
- export interface WorkspaceAndInstance extends Omit<Workspace, "id" | "creationTime">, Omit<WorkspaceInstance, "id" | "creationTime"> {
83
+ export interface WorkspaceAndInstance
84
+ extends Omit<Workspace, "id" | "creationTime">,
85
+ Omit<WorkspaceInstance, "id" | "creationTime"> {
82
86
  workspaceId: string;
83
87
  workspaceCreationTime: string;
84
88
  instanceId: string;
@@ -91,7 +95,7 @@ export namespace WorkspaceAndInstance {
91
95
  return {
92
96
  id: wai.workspaceId,
93
97
  creationTime: wai.workspaceCreationTime,
94
- ...wai
98
+ ...wai,
95
99
  };
96
100
  }
97
101
 
@@ -102,7 +106,7 @@ export namespace WorkspaceAndInstance {
102
106
  return {
103
107
  id: wai.instanceId,
104
108
  creationTime: wai.instanceCreationTime,
105
- ...wai
109
+ ...wai,
106
110
  };
107
111
  }
108
112
  }
package/src/analytics.ts CHANGED
@@ -4,51 +4,49 @@
4
4
  * See License-AGPL.txt in the project root for license information.
5
5
  */
6
6
 
7
-
8
7
  export const IAnalyticsWriter = Symbol("IAnalyticsWriter");
9
8
 
10
9
  type Identity =
11
- | { userId: string | number }
10
+ | { userId: string | number; anonymousId?: string | number }
12
11
  | { userId?: string | number; anonymousId: string | number };
13
12
 
14
13
  interface Message {
15
14
  messageId?: string;
16
15
  }
17
16
 
18
- export type IdentifyMessage = Message & Identity & {
19
- traits?: any;
20
- timestamp?: Date;
21
- context?: any;
22
- };
23
-
24
- export type TrackMessage = Message & Identity & {
25
- event: string;
26
- properties?: any;
27
- timestamp?: Date;
28
- context?: any;
29
- };
30
-
31
- export type PageMessage = Message & Identity & {
32
- properties?: any;
33
- timestamp?: Date;
34
- context?: any;
35
- };
36
-
37
- export type RemoteTrackMessage = Omit<TrackMessage, "timestamp" | "userId" | "anonymousId"> & {
38
- anonymousId?: string | number;
39
- };
17
+ export type IdentifyMessage = Message &
18
+ Identity & {
19
+ traits?: any;
20
+ timestamp?: Date;
21
+ context?: any;
22
+ };
23
+
24
+ export type TrackMessage = Message &
25
+ Identity & {
26
+ event: string;
27
+ properties?: any;
28
+ timestamp?: Date;
29
+ context?: any;
30
+ };
31
+
32
+ export type PageMessage = Message &
33
+ Identity & {
34
+ properties?: any;
35
+ timestamp?: Date;
36
+ context?: any;
37
+ };
38
+
39
+ export type RemoteTrackMessage = Omit<TrackMessage, "timestamp" | "userId">;
40
40
  export type RemotePageMessage = Omit<PageMessage, "timestamp" | "userId"> & {
41
- anonymousId?: string | number;
41
+ includePII?: boolean;
42
42
  };
43
43
 
44
- export type RemoteIdentifyMessage = Omit<IdentifyMessage, "timestamp" | "userId" | "anonymousId">;
44
+ export type RemoteIdentifyMessage = Omit<IdentifyMessage, "timestamp" | "userId">;
45
45
 
46
46
  export interface IAnalyticsWriter {
47
-
48
47
  identify(msg: IdentifyMessage): void;
49
48
 
50
49
  track(msg: TrackMessage): void;
51
50
 
52
51
  page(msg: PageMessage): void;
53
-
54
52
  }
package/src/auth.ts CHANGED
@@ -11,14 +11,14 @@ export interface SelectAccountPayload {
11
11
  authHost: string;
12
12
  authName: string;
13
13
  authProviderType: string;
14
- },
14
+ };
15
15
  otherUser: {
16
16
  name: string;
17
17
  avatarUrl: string;
18
18
  authHost: string;
19
19
  authName: string;
20
20
  authProviderType: string;
21
- }
21
+ };
22
22
  }
23
23
  export namespace SelectAccountPayload {
24
24
  export function is(data: any): data is SelectAccountPayload {
@@ -4,43 +4,57 @@
4
4
  * See License-AGPL.txt in the project root for license information.
5
5
  */
6
6
 
7
- import * as chai from 'chai';
8
- import { suite, test } from 'mocha-typescript';
9
- import { Workspace } from '.';
10
- import { ContextURL } from './context-url';
7
+ import * as chai from "chai";
8
+ import { suite, test } from "mocha-typescript";
9
+ import { Workspace } from ".";
10
+ import { ContextURL } from "./context-url";
11
11
  const expect = chai.expect;
12
12
 
13
13
  type WsContextUrl = Pick<Workspace, "context" | "contextURL">;
14
14
 
15
15
  @suite
16
16
  export class ContextUrlTest {
17
-
18
17
  @test public parseContextUrl_withEnvVar() {
19
- const actual = ContextURL.getNormalizedURL({ contextURL: "passedin=test%20value/https://github.com/gitpod-io/gitpod-test-repo", context: {} } as WsContextUrl);
18
+ const actual = ContextURL.getNormalizedURL({
19
+ contextURL: "passedin=test%20value/https://github.com/gitpod-io/gitpod-test-repo",
20
+ context: {},
21
+ } as WsContextUrl);
20
22
  expect(actual?.host).to.equal("github.com");
21
23
  expect(actual?.pathname).to.equal("/gitpod-io/gitpod-test-repo");
22
24
  }
23
25
 
24
26
  @test public parseContextUrl_withEnvVar_withoutSchema() {
25
- const actual = ContextURL.getNormalizedURL({ contextURL: "passedin=test%20value/github.com/gitpod-io/gitpod-test-repo", context: {} } as WsContextUrl);
27
+ const actual = ContextURL.getNormalizedURL({
28
+ contextURL: "passedin=test%20value/github.com/gitpod-io/gitpod-test-repo",
29
+ context: {},
30
+ } as WsContextUrl);
26
31
  expect(actual?.host).to.equal("github.com");
27
32
  expect(actual?.pathname).to.equal("/gitpod-io/gitpod-test-repo");
28
33
  }
29
34
 
30
35
  @test public parseContextUrl_withEnvVar_sshUrl() {
31
- const actual = ContextURL.getNormalizedURL({ contextURL: "passedin=test%20value/git@github.com:gitpod-io/gitpod-test-repo.git", context: {} } as WsContextUrl);
36
+ const actual = ContextURL.getNormalizedURL({
37
+ contextURL: "passedin=test%20value/git@github.com:gitpod-io/gitpod-test-repo.git",
38
+ context: {},
39
+ } as WsContextUrl);
32
40
  expect(actual?.host).to.equal("github.com");
33
41
  expect(actual?.pathname).to.equal("/gitpod-io/gitpod-test-repo.git");
34
42
  }
35
43
 
36
44
  @test public parseContextUrl_withPrebuild() {
37
- const actual = ContextURL.getNormalizedURL({ contextURL: "prebuild/https://github.com/gitpod-io/gitpod-test-repo", context: {} } as WsContextUrl);
45
+ const actual = ContextURL.getNormalizedURL({
46
+ contextURL: "prebuild/https://github.com/gitpod-io/gitpod-test-repo",
47
+ context: {},
48
+ } as WsContextUrl);
38
49
  expect(actual?.host).to.equal("github.com");
39
50
  expect(actual?.pathname).to.equal("/gitpod-io/gitpod-test-repo");
40
51
  }
41
52
 
42
53
  @test public parseContextUrl_withPrebuild_withoutSchema() {
43
- const actual = ContextURL.getNormalizedURL({ contextURL: "prebuild/github.com/gitpod-io/gitpod-test-repo", context: {} } as WsContextUrl);
54
+ const actual = ContextURL.getNormalizedURL({
55
+ contextURL: "prebuild/github.com/gitpod-io/gitpod-test-repo",
56
+ context: {},
57
+ } as WsContextUrl);
44
58
  expect(actual?.host).to.equal("github.com");
45
59
  expect(actual?.pathname).to.equal("/gitpod-io/gitpod-test-repo");
46
60
  }
@@ -50,4 +64,4 @@ export class ContextUrlTest {
50
64
  expect(actual).to.be.undefined;
51
65
  }
52
66
  }
53
- module.exports = new ContextUrlTest()
67
+ module.exports = new ContextUrlTest();
@@ -15,93 +15,95 @@ import { Workspace } from ".";
15
15
  * TODO(gpl) See if we can get this into `server` code to remove the burden from clients
16
16
  */
17
17
  export namespace ContextURL {
18
- export const INCREMENTAL_PREBUILD_PREFIX = "incremental-prebuild";
19
- export const PREBUILD_PREFIX = "prebuild";
20
- export const IMAGEBUILD_PREFIX = "imagebuild";
21
- export const SNAPSHOT_PREFIX = "snapshot";
22
- export const REFERRER_PREFIX = 'referrer:';
18
+ export const INCREMENTAL_PREBUILD_PREFIX = "incremental-prebuild";
19
+ export const PREBUILD_PREFIX = "prebuild";
20
+ export const IMAGEBUILD_PREFIX = "imagebuild";
21
+ export const SNAPSHOT_PREFIX = "snapshot";
22
+ export const REFERRER_PREFIX = "referrer:";
23
23
 
24
- /**
25
- * This function will (try to) return the HTTP(S) URL of the context the user originally created this workspace on.
26
- * Especially it will not contain any modifiers or be of different scheme than HTTP(S).
27
- *
28
- * Use this function if you need to provided a _working_ URL to the original context.
29
- * @param ws
30
- * @returns
31
- */
32
- export function getNormalizedURL(ws: Pick<Workspace, "context" | "contextURL"> | undefined): URL | undefined {
33
- const normalized = normalize(ws);
34
- if (!normalized) {
35
- return undefined;
36
- }
24
+ /**
25
+ * This function will (try to) return the HTTP(S) URL of the context the user originally created this workspace on.
26
+ * Especially it will not contain any modifiers or be of different scheme than HTTP(S).
27
+ *
28
+ * Use this function if you need to provided a _working_ URL to the original context.
29
+ * @param ws
30
+ * @returns
31
+ */
32
+ export function getNormalizedURL(ws: Pick<Workspace, "context" | "contextURL"> | undefined): URL | undefined {
33
+ const normalized = normalize(ws);
34
+ if (!normalized) {
35
+ return undefined;
36
+ }
37
37
 
38
- try {
39
- return new URL(normalized);
40
- } catch (err) {
41
- console.error(`unable to parse URL from normalized contextURL: '${normalized}'`, err);
38
+ try {
39
+ return new URL(normalized);
40
+ } catch (err) {
41
+ console.error(`unable to parse URL from normalized contextURL: '${normalized}'`, err);
42
+ }
43
+ return undefined;
42
44
  }
43
- return undefined;
44
- }
45
45
 
46
- function normalize(ws: Pick<Workspace, "context" | "contextURL"> | undefined): string | undefined {
47
- if (!ws) {
48
- return undefined;
49
- }
50
- if (ws.context.normalizedContextURL) {
51
- return ws.context.normalizedContextURL;
52
- }
46
+ function normalize(ws: Pick<Workspace, "context" | "contextURL"> | undefined): string | undefined {
47
+ if (!ws) {
48
+ return undefined;
49
+ }
50
+ if (ws.context.normalizedContextURL) {
51
+ return ws.context.normalizedContextURL;
52
+ }
53
53
 
54
- // fallback: we do not yet set normalizedContextURL on all workspaces, yet, let alone older existing workspaces
55
- let fallback: string | undefined = undefined;
56
- try {
57
- fallback = removePrefixes(ws.contextURL);
58
- } catch (err) {
59
- console.error(`unable to remove prefixes from contextURL: '${ws.contextURL}'`, err);
54
+ // fallback: we do not yet set normalizedContextURL on all workspaces, yet, let alone older existing workspaces
55
+ let fallback: string | undefined = undefined;
56
+ try {
57
+ fallback = removePrefixes(ws.contextURL);
58
+ } catch (err) {
59
+ console.error(`unable to remove prefixes from contextURL: '${ws.contextURL}'`, err);
60
+ }
61
+ return fallback;
60
62
  }
61
- return fallback;
62
- }
63
63
 
64
- /**
65
- * The field "contextUrl" might contain prefixes like:
66
- * - envvar1=value1/...
67
- * - prebuild/...
68
- * This is the analogon to the (Prefix)ContextParser structure in "server".
69
- */
70
- function removePrefixes(contextUrl: string | undefined): string | undefined {
71
- if (contextUrl === undefined) {
72
- return undefined;
73
- }
64
+ /**
65
+ * The field "contextUrl" might contain prefixes like:
66
+ * - envvar1=value1/...
67
+ * - prebuild/...
68
+ * This is the analogon to the (Prefix)ContextParser structure in "server".
69
+ */
70
+ function removePrefixes(contextUrl: string | undefined): string | undefined {
71
+ if (contextUrl === undefined) {
72
+ return undefined;
73
+ }
74
74
 
75
- const segments = contextUrl.split("/");
76
- if (segments.length === 1) {
77
- return segments[0]; // this might be something, we just try
78
- }
75
+ const segments = contextUrl.split("/");
76
+ if (segments.length === 1) {
77
+ return segments[0]; // this might be something, we just try
78
+ }
79
79
 
80
- const segmentsToURL = (offset: number): string => {
81
- let rest = segments.slice(offset).join("/");
82
- if (/^git@[^:\/]+:/.test(rest)) {
83
- rest = rest.replace(/^git@([^:\/]+):/, 'https://$1/');
84
- }
85
- if (!rest.startsWith("http")) {
86
- rest = 'https://' + rest;
87
- }
88
- return rest;
89
- };
80
+ const segmentsToURL = (offset: number): string => {
81
+ let rest = segments.slice(offset).join("/");
82
+ if (/^git@[^:\/]+:/.test(rest)) {
83
+ rest = rest.replace(/^git@([^:\/]+):/, "https://$1/");
84
+ }
85
+ if (!rest.startsWith("http")) {
86
+ rest = "https://" + rest;
87
+ }
88
+ return rest;
89
+ };
90
90
 
91
- const firstSegment = segments[0];
92
- if (firstSegment === PREBUILD_PREFIX ||
93
- firstSegment === INCREMENTAL_PREBUILD_PREFIX ||
94
- firstSegment === IMAGEBUILD_PREFIX ||
95
- firstSegment === SNAPSHOT_PREFIX ||
96
- firstSegment.startsWith(REFERRER_PREFIX)) {
97
- return segmentsToURL(1);
98
- }
91
+ const firstSegment = segments[0];
92
+ if (
93
+ firstSegment === PREBUILD_PREFIX ||
94
+ firstSegment === INCREMENTAL_PREBUILD_PREFIX ||
95
+ firstSegment === IMAGEBUILD_PREFIX ||
96
+ firstSegment === SNAPSHOT_PREFIX ||
97
+ firstSegment.startsWith(REFERRER_PREFIX)
98
+ ) {
99
+ return segmentsToURL(1);
100
+ }
99
101
 
100
- // check for env vars
101
- if (firstSegment.indexOf("=") !== -1) {
102
- return segmentsToURL(1);
103
- }
102
+ // check for env vars
103
+ if (firstSegment.indexOf("=") !== -1) {
104
+ return segmentsToURL(1);
105
+ }
104
106
 
105
- return segmentsToURL(0);
106
- }
107
- }
107
+ return segmentsToURL(0);
108
+ }
109
+ }
@@ -4,10 +4,9 @@
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
 
9
- export type EMailState = "scheduledInternal"
10
- | "scheduledSendgrid";
9
+ export type EMailState = "scheduledInternal" | "scheduledSendgrid";
11
10
 
12
11
  export interface EMailStatus {
13
12
  /** The time the email entry was inserted into the DB */
@@ -58,9 +57,9 @@ export type EMail = {
58
57
  } & EMailStatus;
59
58
 
60
59
  export namespace EMail {
61
- export const create = (ts: Omit<EMail, 'uid'>): EMail => {
60
+ export const create = (ts: Omit<EMail, "uid">): EMail => {
62
61
  const withId = ts as EMail;
63
62
  withId.uid = uuidv4();
64
63
  return withId;
65
- }
66
- }
64
+ };
65
+ }
@@ -19,10 +19,9 @@ import { EncryptionService, EncryptionServiceImpl } from "./encryption-service";
19
19
  * };
20
20
  * }).inSingletonScope();
21
21
  */
22
- export const encryptionModule: interfaces.ContainerModuleCallBack = bind => {
23
-
22
+ export const encryptionModule: interfaces.ContainerModuleCallBack = (bind) => {
24
23
  bind(KeyProvider).to(KeyProviderImpl).inSingletonScope();
25
24
 
26
25
  bind(EncryptionEngine).to(EncryptionEngineImpl).inSingletonScope();
27
26
  bind(EncryptionService).to(EncryptionServiceImpl).inSingletonScope();
28
- };
27
+ };
@@ -5,25 +5,26 @@
5
5
  */
6
6
 
7
7
  import { suite, test } from "mocha-typescript";
8
- import * as chai from 'chai';
9
- import * as path from 'path';
8
+ import * as chai from "chai";
9
+ import * as path from "path";
10
10
  import * as fs from "fs";
11
11
 
12
12
  import { EncryptionEngineImpl } from "./encryption-engine";
13
13
 
14
14
  const expect = chai.expect;
15
15
 
16
- @suite class TestEncryptionEngineImpl {
16
+ @suite
17
+ class TestEncryptionEngineImpl {
17
18
  // Created with openssl rand -rand /dev/urandom -out key -base64 32
18
- protected get testkey () {
19
- const keyFilePath = path.resolve(__dirname, '../../test/fixtures/encryption/testkey');
19
+ protected get testkey() {
20
+ const keyFilePath = path.resolve(__dirname, "../../test/fixtures/encryption/testkey");
20
21
  const keyBuffer = fs.readFileSync(keyFilePath);
21
22
  return keyBuffer.toString().trim();
22
- };
23
+ }
23
24
 
24
25
  @test basicSymmetry() {
25
26
  const plaintext = "12345678901234567890";
26
- const key = new Buffer(this.testkey, 'base64');
27
+ const key = new Buffer(this.testkey, "base64");
27
28
 
28
29
  const cut = new EncryptionEngineImpl();
29
30
  const encryptedData = cut.encrypt(plaintext, key);
@@ -33,4 +34,4 @@ const expect = chai.expect;
33
34
  expect(decryptedPlaintext).equals(plaintext);
34
35
  }
35
36
  }
36
- export const t = new TestEncryptionEngineImpl();
37
+ export const t = new TestEncryptionEngineImpl();
@@ -4,20 +4,20 @@
4
4
  * See License-AGPL.txt in the project root for license information.
5
5
  */
6
6
 
7
- import * as crypto from 'crypto';
8
- import { injectable } from 'inversify';
7
+ import * as crypto from "crypto";
8
+ import { injectable } from "inversify";
9
9
 
10
10
  export interface KeyParams {
11
- iv: string
11
+ iv: string;
12
12
  }
13
13
 
14
14
  export interface EncryptedData {
15
15
  /** utf8 encoded string */
16
- data: string,
17
- keyParams: KeyParams
16
+ data: string;
17
+ keyParams: KeyParams;
18
18
  }
19
19
 
20
- export const EncryptionEngine = Symbol('EncryptionEngine');
20
+ export const EncryptionEngine = Symbol("EncryptionEngine");
21
21
  export interface EncryptionEngine {
22
22
  /**
23
23
  * @param data utf8 encoded string
@@ -32,21 +32,21 @@ export interface EncryptionEngine {
32
32
  * - no salt, as we pass in a real key (no salting needed to turn a password into a key)
33
33
  * The implementation closely follows the exampes in https://nodejs.org/api/crypto.html.
34
34
  */
35
- @injectable()
35
+ @injectable()
36
36
  export class EncryptionEngineImpl {
37
- readonly algorithm = 'aes-256-cbc';
38
- readonly enc = 'base64';
37
+ readonly algorithm = "aes-256-cbc";
38
+ readonly enc = "base64";
39
39
 
40
40
  encrypt(data: string, key: Buffer): EncryptedData {
41
41
  const iv = crypto.randomBytes(16);
42
42
  const cipher = crypto.createCipheriv(this.algorithm, key, iv);
43
- const encrypted = cipher.update(new Buffer(data, 'utf8'));
43
+ const encrypted = cipher.update(new Buffer(data, "utf8"));
44
44
  const finalEncrypted = Buffer.concat([encrypted, cipher.final()]);
45
45
  return {
46
46
  data: finalEncrypted.toString(this.enc),
47
47
  keyParams: {
48
- iv: iv.toString(this.enc)
49
- }
48
+ iv: iv.toString(this.enc),
49
+ },
50
50
  };
51
51
  }
52
52
 
@@ -54,6 +54,6 @@ export class EncryptionEngineImpl {
54
54
  const decipher = crypto.createDecipheriv(this.algorithm, key, new Buffer(encryptedData.keyParams.iv, this.enc));
55
55
  let decrypted = decipher.update(new Buffer(encryptedData.data, this.enc));
56
56
  const finalDecrypted = Buffer.concat([decrypted, decipher.final()]);
57
- return finalDecrypted.toString('utf8');
57
+ return finalDecrypted.toString("utf8");
58
58
  }
59
- }
59
+ }
@@ -9,12 +9,11 @@ import { injectable, inject } from "inversify";
9
9
  import { EncryptedData, EncryptionEngine } from "./encryption-engine";
10
10
  import { KeyProvider, KeyMetadata } from "./key-provider";
11
11
 
12
-
13
12
  export interface Encrypted<_T> extends EncryptedData {
14
- keyMetadata: KeyMetadata
13
+ keyMetadata: KeyMetadata;
15
14
  }
16
15
 
17
- export const EncryptionService = Symbol('EncryptionService');
16
+ export const EncryptionService = Symbol("EncryptionService");
18
17
  export interface EncryptionService {
19
18
  encrypt<T>(data: T): Encrypted<T>;
20
19
  decrypt<T>(encrypted: Encrypted<T>): T;
@@ -32,7 +31,7 @@ export class EncryptionServiceImpl implements EncryptionService {
32
31
  const encryptedData = this.engine.encrypt(dataStr, key.material);
33
32
  return {
34
33
  ...encryptedData,
35
- keyMetadata: key.metadata
34
+ keyMetadata: key.metadata,
36
35
  };
37
36
  }
38
37
 
@@ -49,4 +48,4 @@ export class EncryptionServiceImpl implements EncryptionService {
49
48
  protected deserialize<T>(data: string): T {
50
49
  return JSON.parse(data) as T;
51
50
  }
52
- }
51
+ }