@gitpod/gitpod-protocol 0.1.5-wth-test.41 → 0.1.5-yh-vmoptions-fork.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (311) hide show
  1. package/data/gitpod-schema.json +199 -7
  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 +12 -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 +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 +18 -5
  14. package/lib/context-url.d.ts.map +1 -1
  15. package/lib/context-url.js +59 -6
  16. package/lib/context-url.js.map +1 -1
  17. package/lib/context-url.spec.d.ts +2 -0
  18. package/lib/context-url.spec.d.ts.map +1 -1
  19. package/lib/context-url.spec.js +40 -4
  20. package/lib/context-url.spec.js.map +1 -1
  21. package/lib/email-protocol.d.ts +1 -1
  22. package/lib/email-protocol.d.ts.map +1 -1
  23. package/lib/email-protocol.js.map +1 -1
  24. package/lib/encryption/container-module.d.ts.map +1 -1
  25. package/lib/encryption/container-module.js +1 -1
  26. package/lib/encryption/container-module.js.map +1 -1
  27. package/lib/encryption/encryption-engine.d.ts.map +1 -1
  28. package/lib/encryption/encryption-engine.js +7 -7
  29. package/lib/encryption/encryption-engine.js.map +1 -1
  30. package/lib/encryption/encryption-engine.spec.d.ts.map +1 -1
  31. package/lib/encryption/encryption-engine.spec.js +2 -3
  32. package/lib/encryption/encryption-engine.spec.js.map +1 -1
  33. package/lib/encryption/encryption-service.d.ts.map +1 -1
  34. package/lib/encryption/encryption-service.js +1 -1
  35. package/lib/encryption/encryption-service.js.map +1 -1
  36. package/lib/encryption/key-provider.d.ts.map +1 -1
  37. package/lib/encryption/key-provider.js +7 -9
  38. package/lib/encryption/key-provider.js.map +1 -1
  39. package/lib/env.d.ts +0 -5
  40. package/lib/env.d.ts.map +1 -1
  41. package/lib/env.js +1 -20
  42. package/lib/env.js.map +1 -1
  43. package/lib/gitpod-file-parser.d.ts.map +1 -1
  44. package/lib/gitpod-file-parser.js +6 -6
  45. package/lib/gitpod-file-parser.js.map +1 -1
  46. package/lib/gitpod-file-parser.spec.js +42 -39
  47. package/lib/gitpod-file-parser.spec.js.map +1 -1
  48. package/lib/gitpod-service.d.ts +61 -28
  49. package/lib/gitpod-service.d.ts.map +1 -1
  50. package/lib/gitpod-service.js +43 -34
  51. package/lib/gitpod-service.js.map +1 -1
  52. package/lib/headless-workspace-log.d.ts +1 -0
  53. package/lib/headless-workspace-log.d.ts.map +1 -1
  54. package/lib/headless-workspace-log.js +2 -1
  55. package/lib/headless-workspace-log.js.map +1 -1
  56. package/lib/ide-frontend-service.d.ts +1 -1
  57. package/lib/ide-protocol.d.ts +105 -0
  58. package/lib/ide-protocol.d.ts.map +1 -0
  59. package/lib/ide-protocol.js +8 -0
  60. package/lib/ide-protocol.js.map +1 -0
  61. package/lib/index.d.ts +16 -14
  62. package/lib/index.d.ts.map +1 -1
  63. package/lib/index.js +2 -0
  64. package/lib/index.js.map +1 -1
  65. package/lib/installation-admin-protocol.d.ts +27 -0
  66. package/lib/installation-admin-protocol.d.ts.map +1 -0
  67. package/lib/installation-admin-protocol.js +30 -0
  68. package/lib/installation-admin-protocol.js.map +1 -0
  69. package/lib/license-protocol.d.ts +7 -0
  70. package/lib/license-protocol.d.ts.map +1 -1
  71. package/lib/license-protocol.js.map +1 -1
  72. package/lib/messaging/browser/connection.d.ts +1 -1
  73. package/lib/messaging/browser/connection.d.ts.map +1 -1
  74. package/lib/messaging/browser/connection.js +19 -19
  75. package/lib/messaging/browser/connection.js.map +1 -1
  76. package/lib/messaging/browser/window-connection.d.ts +4 -4
  77. package/lib/messaging/browser/window-connection.d.ts.map +1 -1
  78. package/lib/messaging/browser/window-connection.js +9 -6
  79. package/lib/messaging/browser/window-connection.js.map +1 -1
  80. package/lib/messaging/client-call-metrics.d.ts +2 -2
  81. package/lib/messaging/client-call-metrics.d.ts.map +1 -1
  82. package/lib/messaging/client-call-metrics.js +20 -20
  83. package/lib/messaging/client-call-metrics.js.map +1 -1
  84. package/lib/messaging/error.d.ts +3 -0
  85. package/lib/messaging/error.d.ts.map +1 -1
  86. package/lib/messaging/error.js +6 -0
  87. package/lib/messaging/error.js.map +1 -1
  88. package/lib/messaging/handler.d.ts.map +1 -1
  89. package/lib/messaging/handler.js +1 -1
  90. package/lib/messaging/node/connection.d.ts +1 -17
  91. package/lib/messaging/node/connection.d.ts.map +1 -1
  92. package/lib/messaging/node/connection.js +23 -59
  93. package/lib/messaging/node/connection.js.map +1 -1
  94. package/lib/messaging/proxy-factory.d.ts +1 -1
  95. package/lib/messaging/proxy-factory.d.ts.map +1 -1
  96. package/lib/messaging/proxy-factory.js +7 -9
  97. package/lib/messaging/proxy-factory.js.map +1 -1
  98. package/lib/oss-allowlist.d.ts +14 -0
  99. package/lib/oss-allowlist.d.ts.map +1 -0
  100. package/lib/oss-allowlist.js +8 -0
  101. package/lib/oss-allowlist.js.map +1 -0
  102. package/lib/payment-protocol.d.ts.map +1 -1
  103. package/lib/payment-protocol.js +1 -1
  104. package/lib/payment-protocol.js.map +1 -1
  105. package/lib/permission.d.ts +9 -3
  106. package/lib/permission.d.ts.map +1 -1
  107. package/lib/permission.js +34 -25
  108. package/lib/permission.js.map +1 -1
  109. package/lib/plans.d.ts +3 -3
  110. package/lib/plans.d.ts.map +1 -1
  111. package/lib/plans.js +206 -171
  112. package/lib/plans.js.map +1 -1
  113. package/lib/protocol.d.ts +109 -74
  114. package/lib/protocol.d.ts.map +1 -1
  115. package/lib/protocol.js +177 -87
  116. package/lib/protocol.js.map +1 -1
  117. package/lib/snapshot-url.spec.js.map +1 -1
  118. package/lib/team-subscription-protocol.d.ts +21 -3
  119. package/lib/team-subscription-protocol.d.ts.map +1 -1
  120. package/lib/team-subscription-protocol.js +16 -5
  121. package/lib/team-subscription-protocol.js.map +1 -1
  122. package/lib/teams-projects-protocol.d.ts +17 -2
  123. package/lib/teams-projects-protocol.d.ts.map +1 -1
  124. package/lib/teams-projects-protocol.js +8 -1
  125. package/lib/teams-projects-protocol.js.map +1 -1
  126. package/lib/typings/globals.d.ts +2 -2
  127. package/lib/typings/globals.d.ts.map +1 -1
  128. package/lib/util/analytics.d.ts.map +1 -1
  129. package/lib/util/analytics.js +12 -3
  130. package/lib/util/analytics.js.map +1 -1
  131. package/lib/util/async-iterator.d.ts.map +1 -1
  132. package/lib/util/async-iterator.js +3 -3
  133. package/lib/util/async-iterator.js.map +1 -1
  134. package/lib/util/cancelable.js.map +1 -1
  135. package/lib/util/date-time.js +6 -6
  136. package/lib/util/date-time.js.map +1 -1
  137. package/lib/util/deferred.js.map +1 -1
  138. package/lib/util/disposable.d.ts.map +1 -1
  139. package/lib/util/disposable.js +2 -2
  140. package/lib/util/disposable.js.map +1 -1
  141. package/lib/util/event.d.ts.map +1 -1
  142. package/lib/util/event.js +5 -3
  143. package/lib/util/event.js.map +1 -1
  144. package/lib/util/garbage-collected-cache.d.ts +1 -0
  145. package/lib/util/garbage-collected-cache.d.ts.map +1 -1
  146. package/lib/util/garbage-collected-cache.js +6 -2
  147. package/lib/util/garbage-collected-cache.js.map +1 -1
  148. package/lib/util/generate-workspace-id.d.ts +6 -1
  149. package/lib/util/generate-workspace-id.d.ts.map +1 -1
  150. package/lib/util/generate-workspace-id.js +461 -440
  151. package/lib/util/generate-workspace-id.js.map +1 -1
  152. package/lib/util/generate-workspace-id.spec.js +36 -1
  153. package/lib/util/generate-workspace-id.spec.js.map +1 -1
  154. package/lib/util/gitpod-cookie.d.ts +1 -1
  155. package/lib/util/gitpod-cookie.d.ts.map +1 -1
  156. package/lib/util/gitpod-cookie.js +0 -3
  157. package/lib/util/gitpod-cookie.js.map +1 -1
  158. package/lib/util/gitpod-host-url.d.ts +0 -1
  159. package/lib/util/gitpod-host-url.d.ts.map +1 -1
  160. package/lib/util/gitpod-host-url.js +34 -35
  161. package/lib/util/gitpod-host-url.js.map +1 -1
  162. package/lib/util/gitpod-host-url.spec.d.ts.map +1 -1
  163. package/lib/util/gitpod-host-url.spec.js +15 -5
  164. package/lib/util/gitpod-host-url.spec.js.map +1 -1
  165. package/lib/util/grpc.d.ts.map +1 -1
  166. package/lib/util/grpc.js.map +1 -1
  167. package/lib/util/jaeger-client-types.d.ts +68 -0
  168. package/lib/util/jaeger-client-types.d.ts.map +1 -0
  169. package/lib/{theia-plugins.js → util/jaeger-client-types.js} +1 -1
  170. package/lib/util/jaeger-client-types.js.map +1 -0
  171. package/lib/util/logging.d.ts +1 -1
  172. package/lib/util/logging.d.ts.map +1 -1
  173. package/lib/util/logging.js +23 -24
  174. package/lib/util/logging.js.map +1 -1
  175. package/lib/util/make-link.js +5 -5
  176. package/lib/util/make-link.js.map +1 -1
  177. package/lib/util/parse-workspace-id.d.ts.map +1 -1
  178. package/lib/util/parse-workspace-id.js +2 -3
  179. package/lib/util/parse-workspace-id.js.map +1 -1
  180. package/lib/util/parse-workspace-id.spec.d.ts.map +1 -1
  181. package/lib/util/parse-workspace-id.spec.js.map +1 -1
  182. package/lib/util/queue.spec.js +9 -6
  183. package/lib/util/queue.spec.js.map +1 -1
  184. package/lib/util/repeat.d.ts +15 -0
  185. package/lib/util/repeat.d.ts.map +1 -0
  186. package/lib/util/repeat.js +55 -0
  187. package/lib/util/repeat.js.map +1 -0
  188. package/lib/util/semaphore.d.ts.map +1 -1
  189. package/lib/util/semaphore.js.map +1 -1
  190. package/lib/util/skip-if.d.ts.map +1 -1
  191. package/lib/util/skip-if.js.map +1 -1
  192. package/lib/util/timeutil.d.ts +1 -0
  193. package/lib/util/timeutil.d.ts.map +1 -1
  194. package/lib/util/timeutil.js +9 -3
  195. package/lib/util/timeutil.js.map +1 -1
  196. package/lib/util/timeutil.spec.d.ts.map +1 -1
  197. package/lib/util/timeutil.spec.js.map +1 -1
  198. package/lib/util/tracing.d.ts +52 -6
  199. package/lib/util/tracing.d.ts.map +1 -1
  200. package/lib/util/tracing.js +156 -19
  201. package/lib/util/tracing.js.map +1 -1
  202. package/lib/util/tracing.spec.d.ts +7 -0
  203. package/lib/util/tracing.spec.d.ts.map +1 -0
  204. package/lib/util/tracing.spec.js +121 -0
  205. package/lib/util/tracing.spec.js.map +1 -0
  206. package/lib/util/workspace-port-authentication.d.ts +7 -7
  207. package/lib/util/workspace-port-authentication.d.ts.map +1 -1
  208. package/lib/util/workspace-port-authentication.js +8 -11
  209. package/lib/util/workspace-port-authentication.js.map +1 -1
  210. package/lib/workspace-cluster.d.ts +10 -8
  211. package/lib/workspace-cluster.d.ts.map +1 -1
  212. package/lib/workspace-cluster.js +16 -1
  213. package/lib/workspace-cluster.js.map +1 -1
  214. package/lib/workspace-instance.d.ts +38 -3
  215. package/lib/workspace-instance.d.ts.map +1 -1
  216. package/lib/wsready.d.ts +1 -1
  217. package/lib/wsready.d.ts.map +1 -1
  218. package/lib/wsready.js +2 -2
  219. package/package.json +10 -8
  220. package/pkg-yarn.lock +6 -6
  221. package/provenance-bundle.jsonl +2 -0
  222. package/src/accounting-protocol.ts +63 -51
  223. package/src/admin-protocol.ts +35 -18
  224. package/src/analytics.ts +26 -28
  225. package/src/auth.ts +2 -2
  226. package/src/context-url.spec.ts +37 -9
  227. package/src/context-url.ts +94 -36
  228. package/src/email-protocol.ts +5 -6
  229. package/src/encryption/container-module.ts +2 -3
  230. package/src/encryption/encryption-engine.spec.ts +9 -8
  231. package/src/encryption/encryption-engine.ts +14 -14
  232. package/src/encryption/encryption-service.ts +4 -5
  233. package/src/encryption/key-provider.ts +16 -19
  234. package/src/env.ts +0 -22
  235. package/src/gitpod-file-parser.spec.ts +55 -61
  236. package/src/gitpod-file-parser.ts +16 -17
  237. package/src/gitpod-service.ts +185 -112
  238. package/src/headless-workspace-log.ts +6 -4
  239. package/src/ide-frontend-service.ts +2 -2
  240. package/src/ide-protocol.ts +119 -0
  241. package/src/index.ts +16 -14
  242. package/src/installation-admin-protocol.ts +42 -0
  243. package/src/license-protocol.ts +12 -6
  244. package/src/messaging/browser/connection.ts +45 -47
  245. package/src/messaging/browser/window-connection.ts +39 -29
  246. package/src/messaging/client-call-metrics.ts +70 -71
  247. package/src/messaging/error.ts +10 -3
  248. package/src/messaging/handler.ts +6 -6
  249. package/src/messaging/node/connection.ts +23 -70
  250. package/src/messaging/proxy-factory.ts +23 -30
  251. package/src/oss-allowlist.ts +15 -0
  252. package/src/payment-protocol.ts +2 -2
  253. package/src/permission.ts +40 -32
  254. package/src/plans.ts +236 -189
  255. package/src/protocol.ts +383 -275
  256. package/src/snapshot-url.spec.ts +9 -7
  257. package/src/team-subscription-protocol.ts +57 -23
  258. package/src/teams-projects-protocol.ts +29 -8
  259. package/src/typings/globals.ts +4 -4
  260. package/src/util/analytics.ts +46 -24
  261. package/src/util/async-iterator.ts +4 -5
  262. package/src/util/cancelable.ts +3 -3
  263. package/src/util/date-time.ts +8 -8
  264. package/src/util/deferred.ts +6 -6
  265. package/src/util/disposable.ts +3 -6
  266. package/src/util/event.ts +9 -11
  267. package/src/util/garbage-collected-cache.ts +9 -6
  268. package/src/util/generate-workspace-id.spec.ts +34 -7
  269. package/src/util/generate-workspace-id.ts +464 -440
  270. package/src/util/gitpod-cookie.ts +8 -9
  271. package/src/util/gitpod-host-url.spec.ts +40 -13
  272. package/src/util/gitpod-host-url.ts +40 -41
  273. package/src/util/grpc.ts +1 -1
  274. package/src/util/jaeger-client-types.ts +102 -0
  275. package/src/util/logging.ts +49 -40
  276. package/src/util/make-link.ts +6 -7
  277. package/src/util/parse-workspace-id.spec.ts +17 -8
  278. package/src/util/parse-workspace-id.ts +6 -7
  279. package/src/util/queue.spec.ts +27 -25
  280. package/src/util/repeat.ts +45 -0
  281. package/src/util/semaphore.ts +4 -6
  282. package/src/util/skip-if.ts +9 -6
  283. package/src/util/timeutil.spec.ts +14 -15
  284. package/src/util/timeutil.ts +21 -11
  285. package/src/util/tracing.spec.ts +88 -0
  286. package/src/util/tracing.ts +200 -31
  287. package/src/util/workspace-port-authentication.ts +10 -13
  288. package/src/workspace-cluster.ts +26 -15
  289. package/src/workspace-instance.ts +69 -20
  290. package/src/wsready.ts +3 -3
  291. package/data/builtin-theia-plugins.json +0 -372
  292. package/lib/messaging/connection-error-handler.d.ts +0 -27
  293. package/lib/messaging/connection-error-handler.d.ts.map +0 -1
  294. package/lib/messaging/connection-error-handler.js +0 -34
  295. package/lib/messaging/connection-error-handler.js.map +0 -1
  296. package/lib/theia-plugins.d.ts +0 -11
  297. package/lib/theia-plugins.d.ts.map +0 -1
  298. package/lib/theia-plugins.js.map +0 -1
  299. package/lib/util/repeater.d.ts +0 -22
  300. package/lib/util/repeater.d.ts.map +0 -1
  301. package/lib/util/repeater.js +0 -65
  302. package/lib/util/repeater.js.map +0 -1
  303. package/lib/util/safe-promise.d.ts +0 -11
  304. package/lib/util/safe-promise.d.ts.map +0 -1
  305. package/lib/util/safe-promise.js +0 -31
  306. package/lib/util/safe-promise.js.map +0 -1
  307. package/src/messaging/connection-error-handler.ts +0 -62
  308. package/src/theia-plugins.ts +0 -11
  309. package/src/util/jaeger-client.d.ts +0 -105
  310. package/src/util/repeater.ts +0 -49
  311. package/src/util/safe-promise.ts +0 -26
@@ -24,28 +24,38 @@ export function oneMonthLater(fromDate: string, day?: number): string {
24
24
  }
25
25
  return later.toISOString();
26
26
  }
27
- export const yearsLater = (fromDate: string, years: number): string => liftDate1(fromDate, (d) => {
28
- d.setUTCFullYear(d.getUTCFullYear() + years);
29
- return d.toISOString();
30
- });
27
+ export const yearsLater = (fromDate: string, years: number): string =>
28
+ liftDate1(fromDate, (d) => {
29
+ d.setUTCFullYear(d.getUTCFullYear() + years);
30
+ return d.toISOString();
31
+ });
31
32
 
32
33
  // tslint:disable-next-line:no-shadowed-variable
33
- export const addMillis = (d1: string, millis: number) => liftDate1(d1, (d1) => new Date(d1.getTime() + millis).toISOString());
34
- export const durationInHours = (d1: string, d2: string) => liftDate(d1, d2, (d1, d2) => millisecondsToHours(d1.getTime() - d2.getTime()));
34
+ export const addMillis = (d1: string, millis: number) =>
35
+ liftDate1(d1, (d1) => new Date(d1.getTime() + millis).toISOString());
36
+ export const durationInHours = (d1: string, d2: string) =>
37
+ liftDate(d1, d2, (d1, d2) => millisecondsToHours(d1.getTime() - d2.getTime()));
35
38
  export const durationInMillis = (d1: string, d2: string) => liftDate(d1, d2, (d1, d2) => d1.getTime() - d2.getTime());
36
39
  // tslint:disable-next-line:no-shadowed-variable
37
- export const isDateGreaterOrEqual = (d1: string, d2: string): boolean => liftDate(d1, d2, (d1, d2) => d1.getTime() >= d2.getTime());
40
+ export const isDateGreaterOrEqual = (d1: string, d2: string): boolean =>
41
+ liftDate(d1, d2, (d1, d2) => d1.getTime() >= d2.getTime());
38
42
  export const isDateSmallerOrEqual = (d1: string, d2: string | undefined) => !d2 || d1 <= d2;
39
43
  export const isDateSmaller = (d1: string, d2: string | undefined) => !d2 || d1 < d2;
40
- export const oldest = (d1: string, d2: string): string => d1 > d2 ? d1 : d2;
41
- export const earliest = (d1: string, d2: string): string => d1 < d2 ? d1 : d2;
44
+ export const oldest = (d1: string, d2: string): string => (d1 > d2 ? d1 : d2);
45
+ export const earliest = (d1: string, d2: string): string => (d1 < d2 ? d1 : d2);
42
46
  export const orderAsc = (d1: string, d2: string): number => liftDate(d1, d2, (d1, d2) => d1.getTime() - d2.getTime());
43
47
  export const liftDate1 = <T>(d1: string, f: (d1: Date) => T): T => f(new Date(d1));
44
48
  export const liftDate = <T>(d1: string, d2: string, f: (d1: Date, d2: Date) => T): T => f(new Date(d1), new Date(d2));
45
49
 
50
+ export function hoursBefore(date: string, hours: number): string {
51
+ const result = new Date(date);
52
+ result.setHours(result.getHours() - hours);
53
+ return result.toISOString();
54
+ }
55
+
46
56
  export function hoursLater(date: string, hours: number): string {
47
- const result = new Date(date)
48
- result.setHours(result.getHours() + hours)
57
+ const result = new Date(date);
58
+ result.setHours(result.getHours() + hours);
49
59
  return result.toISOString();
50
60
  }
51
61
 
@@ -0,0 +1,88 @@
1
+ /**
2
+ * Copyright (c) 2021 Gitpod GmbH. All rights reserved.
3
+ * Licensed under the GNU Affero General Public License (AGPL).
4
+ * See License-AGPL.txt in the project root for license information.
5
+ */
6
+
7
+ import { suite, test } from "mocha-typescript";
8
+ import * as chai from "chai";
9
+ import { TraceContext } from "./tracing";
10
+ import { MockTracer } from "opentracing";
11
+
12
+ const expect = chai.expect;
13
+
14
+ @suite
15
+ class TestTracing {
16
+ @test public async testTracingContext_addNestedTags() {
17
+ const tracer = new MockTracer();
18
+ const span = tracer.startSpan("testTracingContext_addNestedTags");
19
+ TraceContext.addNestedTags(
20
+ { span },
21
+ {
22
+ rpc: {
23
+ system: "jsonrpc",
24
+ jsonrpc: {
25
+ version: "1.0",
26
+ method: "test",
27
+ parameters: ["abc", "def"],
28
+ },
29
+ },
30
+ },
31
+ );
32
+
33
+ const mockSpan = tracer.report().spans[0];
34
+ expect(mockSpan.tags()).to.deep.equal({
35
+ "rpc.system": "jsonrpc",
36
+ "rpc.jsonrpc.version": "1.0",
37
+ "rpc.jsonrpc.method": "test",
38
+ "rpc.jsonrpc.parameters.0": "abc",
39
+ "rpc.jsonrpc.parameters.1": "def",
40
+ });
41
+ }
42
+
43
+ @test public async testTracingContext_addNestedTags_null() {
44
+ const tracer = new MockTracer();
45
+ const span = tracer.startSpan("testTracingContext_addNestedTags_null");
46
+ TraceContext.addNestedTags(
47
+ { span },
48
+ {
49
+ someShape: {
50
+ thisIsNull: null,
51
+ thisIsUndefined: undefined,
52
+ },
53
+ },
54
+ );
55
+
56
+ const mockSpan = tracer.report().spans[0];
57
+ expect(mockSpan.tags()).to.deep.equal({
58
+ "someShape.thisIsNull": null,
59
+ "someShape.thisIsUndefined": undefined,
60
+ });
61
+ }
62
+
63
+ @test public async testTracingContext_addJsonRPCParameters() {
64
+ const tracer = new MockTracer();
65
+ const span = tracer.startSpan("testTracingContext_addJsonRPCParameters");
66
+ const ctx = { span };
67
+ TraceContext.addJsonRPCParameters(ctx, {
68
+ one: "one",
69
+ two: {
70
+ name: "two",
71
+ some: "shape",
72
+ containing: "PII",
73
+ },
74
+ three: "three",
75
+ });
76
+
77
+ const mockSpan = tracer.report().spans[0];
78
+ expect(mockSpan.tags()).to.deep.equal({
79
+ "rpc.jsonrpc.parameters.one": "one",
80
+ "rpc.jsonrpc.parameters.two.containing": "PII",
81
+ "rpc.jsonrpc.parameters.two.name": "two",
82
+ "rpc.jsonrpc.parameters.two.some": "shape",
83
+ "rpc.jsonrpc.parameters.three": "three",
84
+ "rpc.system": "jsonrpc",
85
+ });
86
+ }
87
+ }
88
+ module.exports = new TestTracing();
@@ -4,48 +4,192 @@
4
4
  * See License-AGPL.txt in the project root for license information.
5
5
  */
6
6
 
7
-
8
- import * as opentracing from 'opentracing';
9
- import { TracingConfig, initTracerFromEnv, Sampler, SamplingDecision } from 'jaeger-client';
10
- import { initGlobalTracer } from 'opentracing';
11
- import { injectable } from 'inversify';
7
+ import * as opentracing from "opentracing";
8
+ import { TracingConfig, initTracerFromEnv } from "jaeger-client";
9
+ import { Sampler, SamplingDecision } from "./jaeger-client-types";
10
+ import { initGlobalTracer } from "opentracing";
11
+ import { injectable } from "inversify";
12
+ import { ResponseError } from "vscode-jsonrpc";
13
+ import { log, LogContext } from "./logging";
12
14
 
13
15
  export interface TraceContext {
14
- span?: opentracing.Span
16
+ span?: opentracing.Span;
15
17
  }
18
+ export type TraceContextWithSpan = TraceContext & {
19
+ span: opentracing.Span;
20
+ };
16
21
 
17
22
  export namespace TraceContext {
18
- export function startSpan(operation: string, ctx: TraceContext): opentracing.Span {
19
- const options: opentracing.SpanOptions = {
20
- childOf: ctx.span
23
+ export function startSpan(operation: string, parentCtx?: TraceContext): opentracing.Span {
24
+ const options: opentracing.SpanOptions = {};
25
+
26
+ // references should contain span id.
27
+ // cf. https://github.com/jaegertracing/jaeger-client-node/issues/432
28
+ if (!!parentCtx?.span) {
29
+ const ctx = parentCtx?.span?.context();
30
+ if (ctx && !!ctx.toTraceId() && !!ctx.toSpanId()) {
31
+ options.references = [opentracing.followsFrom(ctx)];
32
+ }
21
33
  }
34
+
22
35
  return opentracing.globalTracer().startSpan(operation, options);
23
36
  }
24
37
 
25
- export function startAsyncSpan(operation: string, ctx: TraceContext): opentracing.Span {
26
- const options: opentracing.SpanOptions = {};
27
- if (!!ctx.span) {
28
- options.references = [opentracing.followsFrom(ctx.span.context())];
38
+ export function childContext(operation: string, parentCtx: TraceContext): TraceContextWithSpan {
39
+ const span = startSpan(operation, parentCtx);
40
+ return { span };
41
+ }
42
+
43
+ export function withSpan(operation: string, callback: (ctx: TraceContext) => void, ctx?: TraceContext): void {
44
+ // if we don't have a parent span, don't create a trace here as those <trace-without-root-spans> are not useful.
45
+ if (!ctx || !ctx.span || !ctx.span.context()) {
46
+ callback({});
47
+ return;
48
+ }
49
+
50
+ const span = TraceContext.startSpan(operation, ctx);
51
+ try {
52
+ callback({ span });
53
+ } catch (e) {
54
+ TraceContext.setError({ span }, e);
55
+ throw e;
56
+ } finally {
57
+ span.finish();
58
+ }
59
+ }
60
+
61
+ export function setError(ctx: TraceContext, err: Error) {
62
+ if (!ctx.span) {
63
+ return;
64
+ }
65
+
66
+ TraceContext.addNestedTags(ctx, {
67
+ error: {
68
+ message: err.message,
69
+ stacktrace: err.stack,
70
+ },
71
+ });
72
+ ctx.span.setTag("error", true);
73
+ }
74
+
75
+ export function setJsonRPCMetadata(ctx: TraceContext, method?: string) {
76
+ if (!ctx.span) {
77
+ return;
78
+ }
79
+
80
+ const tags: { [key: string]: any } = {
81
+ rpc: {
82
+ system: "jsonrpc",
83
+ // version,
84
+ },
85
+ };
86
+ if (method) {
87
+ tags.rpc.method = method;
88
+ }
89
+ addNestedTags(ctx, tags);
90
+ }
91
+
92
+ export function setJsonRPCError(
93
+ ctx: TraceContext,
94
+ method: string,
95
+ err: ResponseError<any>,
96
+ withStatusCode: boolean = false,
97
+ ) {
98
+ if (!ctx.span) {
99
+ return;
100
+ }
101
+ // not use setError bc this is (most likely) a working operation
102
+
103
+ setJsonRPCMetadata(ctx, method);
104
+ // https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/trace/semantic_conventions/rpc.md#json-rpc
105
+ addNestedTags(ctx, {
106
+ rpc: {
107
+ jsonrpc: {
108
+ error_code: err.code,
109
+ error_message: err.message,
110
+ },
111
+ },
112
+ });
113
+
114
+ // the field "status_code" is used by honeycomb to derive insights like success rate, etc. Defaults to "0".
115
+ if (withStatusCode) {
116
+ ctx.span.setTag("status_code", err.code);
29
117
  }
30
- return opentracing.globalTracer().startSpan(operation, options);
31
118
  }
32
119
 
33
- export function logError(ctx: TraceContext, err: Error) {
120
+ export function addJsonRPCParameters(ctx: TraceContext, params: { [key: string]: any }) {
34
121
  if (!ctx.span) {
35
122
  return;
36
123
  }
37
124
 
38
- ctx.span.log({
39
- "error": err.message,
40
- "stacktrace": err.stack
41
- })
42
- ctx.span.setTag("error", true)
125
+ setJsonRPCMetadata(ctx);
126
+ addNestedTags(ctx, {
127
+ rpc: {
128
+ jsonrpc: {
129
+ parameters: params,
130
+ },
131
+ },
132
+ });
133
+ }
134
+
135
+ /**
136
+ * Does what one would expect from `span.addTags`: Calls `span.addTag` for all keys in map, recursively for objects.
137
+ * Example:
138
+ * ```
139
+ * TraceContext.addNestedTags(ctx, {
140
+ * rpc: {
141
+ * system: "jsonrpc",
142
+ * jsonrpc: {
143
+ * version: "1.0",
144
+ * method: "test",
145
+ * parameters: ["abc", "def"],
146
+ * },
147
+ * },
148
+ * });
149
+ * ```
150
+ * gives
151
+ * rpc.system = "jsonrpc"
152
+ * rpc.jsonrpc.version = "1.0"
153
+ * rpc.jsonrpc.method = "test"
154
+ * rpc.jsonrpc.parameters.0 = "abc"
155
+ * rpc.jsonrpc.parameters.1 = "def"
156
+ * @param ctx
157
+ * @param keyValueMap
158
+ * @returns
159
+ */
160
+ export function addNestedTags(ctx: TraceContext, keyValueMap: { [key: string]: any }, _namespace?: string) {
161
+ if (!ctx.span) {
162
+ return;
163
+ }
164
+ const namespace = _namespace ? `${_namespace}.` : "";
165
+
166
+ try {
167
+ for (const k of Object.keys(keyValueMap)) {
168
+ const v = keyValueMap[k];
169
+ if (v instanceof Object) {
170
+ addNestedTags(ctx, v, `${namespace}${k}`);
171
+ } else {
172
+ ctx.span.setTag(`${namespace}${k}`, v);
173
+ }
174
+ }
175
+ } catch (err) {
176
+ // general resilience against odd shapes/parameters
177
+ log.error("Tracing.addNestedTags", err, { namespace });
178
+ }
179
+ }
180
+
181
+ export function setOWI(ctx: TraceContext, owi: LogContext) {
182
+ if (!ctx.span) {
183
+ return;
184
+ }
185
+ addNestedTags(ctx, {
186
+ context: owi,
187
+ });
43
188
  }
44
189
  }
45
190
 
46
191
  @injectable()
47
192
  export class TracingManager {
48
-
49
193
  public setup(serviceName: string, opts?: CustomTracerOpts) {
50
194
  initGlobalTracer(this.getTracerForService(serviceName, opts));
51
195
  }
@@ -54,13 +198,18 @@ export class TracingManager {
54
198
  const config: TracingConfig = {
55
199
  disable: false,
56
200
  reporter: {
57
- logSpans: false
201
+ logSpans: false,
58
202
  },
59
- serviceName
60
- }
203
+ serviceName,
204
+ };
61
205
  const t = initTracerFromEnv(config, {
62
- logger: console
206
+ logger: console,
207
+ tags: {
208
+ "service.build.commit": process.env.GITPOD_BUILD_GIT_COMMIT,
209
+ "service.build.version": process.env.GITPOD_BUILD_VERSION,
210
+ },
63
211
  });
212
+
64
213
  if (opts) {
65
214
  if (opts.perOpSampling) {
66
215
  (t as any)._sampler = new PerOperationSampler((t as any)._sampler, opts.perOpSampling);
@@ -68,24 +217,22 @@ export class TracingManager {
68
217
  }
69
218
  return t;
70
219
  }
71
-
72
220
  }
73
221
 
74
222
  export interface CustomTracerOpts {
75
- perOpSampling?: PerOperationSampling
223
+ perOpSampling?: PerOperationSampling;
76
224
  }
77
225
 
78
-
79
226
  // has to conform to https://github.com/jaegertracing/jaeger-client-node/blob/0042b1c0a0796bb655eb93e77ff76ab5e94c2bb6/src/_flow/sampler-thrift.js#L32
80
227
  export interface PerOperationSampling {
81
- [key: string]: boolean
228
+ [key: string]: boolean;
82
229
  }
83
230
 
84
231
  export class PerOperationSampler implements Sampler {
85
232
  constructor(protected readonly fallback: Sampler, protected readonly strategies: PerOperationSampling) {}
86
233
 
87
234
  name(): string {
88
- return 'PerOperationSampler';
235
+ return "PerOperationSampler";
89
236
  }
90
237
 
91
238
  toString(): string {
@@ -125,10 +272,32 @@ export class PerOperationSampler implements Sampler {
125
272
  return false; // TODO equal should be removed
126
273
  }
127
274
 
128
- close(callback: ()=>void): void {
275
+ close(callback: () => void): void {
129
276
  // all nested samplers are of simple types, so we do not need to Close them
130
277
  if (callback) {
131
278
  callback();
132
279
  }
133
280
  }
134
281
  }
282
+
283
+ // Augment interfaces with an leading parameter "TraceContext" on every method
284
+ type IsValidArg<T> = T extends object ? (keyof T extends never ? false : true) : true;
285
+ type AddTraceContext<T> = T extends (a: infer A, b: infer B, c: infer C, d: infer D, e: infer E, f: infer F) => infer R
286
+ ? IsValidArg<F> extends true
287
+ ? (ctx: TraceContextWithSpan, a: A, b: B, c: C, d: D, e: E, f: F) => R
288
+ : IsValidArg<E> extends true
289
+ ? (ctx: TraceContextWithSpan, a: A, b: B, c: C, d: D, e: E) => R
290
+ : IsValidArg<D> extends true
291
+ ? (ctx: TraceContextWithSpan, a: A, b: B, c: C, d: D) => R
292
+ : IsValidArg<C> extends true
293
+ ? (ctx: TraceContextWithSpan, a: A, b: B, c: C) => R
294
+ : IsValidArg<B> extends true
295
+ ? (ctx: TraceContextWithSpan, a: A, b: B) => R
296
+ : IsValidArg<A> extends true
297
+ ? (ctx: TraceContextWithSpan, a: A) => R
298
+ : (ctx: TraceContextWithSpan) => Promise<R>
299
+ : never;
300
+
301
+ export type InterfaceWithTraceContext<T> = {
302
+ [P in keyof T]: AddTraceContext<T[P]>;
303
+ };
@@ -5,16 +5,13 @@
5
5
  */
6
6
 
7
7
  /**
8
- * These cookies are set in the Theia frontend. This pattern is relied upon in:
9
- * - proxy:
10
- * - to filter it out on port locations
11
- * - to forward it to the server for authentication
12
- * - server:
13
- * - to authenticate access to port locations
14
- */
15
- export const worspacePortAuthCookieName = function(host: string, workspaceId: string): string {
16
- return host
17
- .replace(/https?/, '')
18
- .replace(/[\W_]+/g, "_")
19
- + `_ws_${workspaceId}_port_auth_`;
20
- };
8
+ * These cookies are set in the Theia frontend. This pattern is relied upon in:
9
+ * - proxy:
10
+ * - to filter it out on port locations
11
+ * - to forward it to the server for authentication
12
+ * - server:
13
+ * - to authenticate access to port locations
14
+ */
15
+ export const worspacePortAuthCookieName = function (host: string, workspaceId: string): string {
16
+ return host.replace(/https?/, "").replace(/[\W_]+/g, "_") + `_ws_${workspaceId}_port_auth_`;
17
+ };
@@ -4,10 +4,10 @@
4
4
  * See License-AGPL.txt in the project root for license information.
5
5
  */
6
6
 
7
- import * as fs from 'fs';
8
- import { filePathTelepresenceAware } from './env';
7
+ import * as fs from "fs";
8
+ import { filePathTelepresenceAware } from "./env";
9
9
  import { DeepPartial } from "./util/deep-partial";
10
- import { PermissionName } from './permission';
10
+ import { PermissionName } from "./permission";
11
11
 
12
12
  export interface WorkspaceCluster {
13
13
  // Name of the workspace cluster.
@@ -35,9 +35,6 @@ export interface WorkspaceCluster {
35
35
 
36
36
  // An optional set of constraints that limit who can start workspaces on the cluster
37
37
  admissionConstraints?: AdmissionConstraint[];
38
-
39
- // An optional set of admission preferences that guide cluster selection
40
- admissionPreferences?: AdmissionPreference[];
41
38
  }
42
39
 
43
40
  export type WorkspaceClusterState = "available" | "cordoned" | "draining";
@@ -50,19 +47,33 @@ export interface TLSConfig {
50
47
  crt: string;
51
48
  }
52
49
  export namespace TLSConfig {
53
- export const loadFromBase64File = (path: string): string => fs.readFileSync(filePathTelepresenceAware(path)).toString("base64");
50
+ export const loadFromBase64File = (path: string): string =>
51
+ fs.readFileSync(filePathTelepresenceAware(path)).toString("base64");
54
52
  }
55
53
  export type WorkspaceClusterWoTLS = Omit<WorkspaceCluster, "tls">;
56
54
  export type WorkspaceManagerConnectionInfo = Pick<WorkspaceCluster, "name" | "url" | "tls">;
57
55
 
58
- export type AdmissionConstraint = AdmissionConstraintFeaturePreview | AdmissionConstraintHasRole | AdmissionConstraintHasUserLevel;
56
+ export type AdmissionConstraint =
57
+ | AdmissionConstraintFeaturePreview
58
+ | AdmissionConstraintHasPermission
59
+ | AdmissionConstraintHasUserLevel
60
+ | AdmissionConstraintHasMoreResources;
59
61
  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
-
62
+ export type AdmissionConstraintHasPermission = { type: "has-permission"; permission: PermissionName };
63
+ export type AdmissionConstraintHasUserLevel = { type: "has-user-level"; level: string };
64
+ export type AdmissionConstraintHasMoreResources = { type: "has-more-resources" };
65
+
66
+ export namespace AdmissionConstraint {
67
+ export function is(o: any): o is AdmissionConstraint {
68
+ return !!o && "type" in o;
69
+ }
70
+ export function isHasPermissionConstraint(o: any): o is AdmissionConstraintHasPermission {
71
+ return is(o) && o.type === "has-permission";
72
+ }
73
+ export function hasPermission(ac: AdmissionConstraint, permission: PermissionName): boolean {
74
+ return isHasPermissionConstraint(ac) && ac.permission === permission;
75
+ }
76
+ }
66
77
 
67
78
  export const WorkspaceClusterDB = Symbol("WorkspaceClusterDB");
68
79
  export interface WorkspaceClusterDB {
@@ -93,4 +104,4 @@ export interface WorkspaceClusterDB {
93
104
  }
94
105
  export interface WorkspaceClusterFilter extends Pick<WorkspaceCluster, "state" | "govern" | "url"> {
95
106
  minScore: number;
96
- }
107
+ }