@gitpod/gitpod-protocol 0.1.5-tweak-workspaceconfig-origin-docs-fork.0 → 0.1.5-update-yarnlock.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/data/gitpod-schema.json +150 -8
- package/lib/accounting-protocol.d.ts +21 -11
- package/lib/accounting-protocol.d.ts.map +1 -1
- package/lib/accounting-protocol.js +44 -33
- package/lib/accounting-protocol.js.map +1 -1
- package/lib/admin-protocol.d.ts +29 -1
- package/lib/admin-protocol.d.ts.map +1 -1
- package/lib/admin-protocol.js +1 -1
- package/lib/admin-protocol.js.map +1 -1
- package/lib/analytics.d.ts +5 -6
- package/lib/analytics.d.ts.map +1 -1
- package/lib/analytics.js +1 -1
- package/lib/analytics.js.map +1 -1
- package/lib/attribution.d.ts +25 -0
- package/lib/attribution.d.ts.map +1 -0
- package/lib/attribution.js +58 -0
- package/lib/attribution.js.map +1 -0
- package/lib/auth.d.ts +1 -1
- package/lib/auth.d.ts.map +1 -1
- package/lib/auth.js +1 -1
- package/lib/billing-mode.d.ts +45 -0
- package/lib/billing-mode.d.ts.map +1 -0
- package/lib/billing-mode.js +44 -0
- package/lib/billing-mode.js.map +1 -0
- package/lib/blocked-repositories-protocol.d.ts +13 -0
- package/lib/blocked-repositories-protocol.d.ts.map +1 -0
- package/lib/blocked-repositories-protocol.js +8 -0
- package/lib/blocked-repositories-protocol.js.map +1 -0
- package/lib/context-url.d.ts +19 -7
- package/lib/context-url.d.ts.map +1 -1
- package/lib/context-url.js +60 -9
- package/lib/context-url.js.map +1 -1
- package/lib/context-url.spec.d.ts +3 -3
- package/lib/context-url.spec.d.ts.map +1 -1
- package/lib/context-url.spec.js +20 -12
- package/lib/context-url.spec.js.map +1 -1
- package/lib/encryption/container-module.d.ts +1 -1
- package/lib/encryption/container-module.d.ts.map +1 -1
- package/lib/encryption/container-module.js +2 -2
- package/lib/encryption/container-module.js.map +1 -1
- package/lib/encryption/encryption-engine.d.ts +1 -1
- package/lib/encryption/encryption-engine.d.ts.map +1 -1
- package/lib/encryption/encryption-engine.js +10 -10
- package/lib/encryption/encryption-engine.js.map +1 -1
- package/lib/encryption/encryption-engine.spec.d.ts +1 -1
- package/lib/encryption/encryption-engine.spec.d.ts.map +1 -1
- package/lib/encryption/encryption-engine.spec.js +3 -4
- package/lib/encryption/encryption-engine.spec.js.map +1 -1
- package/lib/encryption/encryption-service.d.ts +1 -1
- package/lib/encryption/encryption-service.d.ts.map +1 -1
- package/lib/encryption/encryption-service.js +2 -2
- package/lib/encryption/encryption-service.js.map +1 -1
- package/lib/encryption/key-provider.d.ts +1 -1
- package/lib/encryption/key-provider.d.ts.map +1 -1
- package/lib/encryption/key-provider.js +8 -10
- package/lib/encryption/key-provider.js.map +1 -1
- package/lib/env.d.ts +1 -6
- package/lib/env.d.ts.map +1 -1
- package/lib/env.js +2 -21
- package/lib/env.js.map +1 -1
- package/lib/experiments/always-default.d.ts +8 -0
- package/lib/experiments/always-default.d.ts.map +1 -0
- package/lib/experiments/always-default.js +20 -0
- package/lib/experiments/always-default.js.map +1 -0
- package/lib/experiments/configcat-server.d.ts +10 -0
- package/lib/experiments/configcat-server.d.ts.map +1 -0
- package/lib/experiments/configcat-server.js +37 -0
- package/lib/experiments/configcat-server.js.map +1 -0
- package/lib/experiments/configcat.d.ts +21 -0
- package/lib/experiments/configcat.d.ts.map +1 -0
- package/lib/experiments/configcat.js +51 -0
- package/lib/experiments/configcat.js.map +1 -0
- package/lib/experiments/types.d.ts +22 -0
- package/lib/experiments/types.d.ts.map +1 -0
- package/lib/experiments/types.js +10 -0
- package/lib/experiments/types.js.map +1 -0
- package/lib/frontend-dashboard-service.d.ts +99 -0
- package/lib/frontend-dashboard-service.d.ts.map +1 -0
- package/lib/frontend-dashboard-service.js +55 -0
- package/lib/frontend-dashboard-service.js.map +1 -0
- package/lib/gitpod-file-parser.d.ts +1 -1
- package/lib/gitpod-file-parser.d.ts.map +1 -1
- package/lib/gitpod-file-parser.js +7 -7
- package/lib/gitpod-file-parser.js.map +1 -1
- package/lib/gitpod-file-parser.spec.d.ts +1 -1
- package/lib/gitpod-file-parser.spec.js +43 -40
- package/lib/gitpod-file-parser.spec.js.map +1 -1
- package/lib/gitpod-service.d.ts +143 -51
- package/lib/gitpod-service.d.ts.map +1 -1
- package/lib/gitpod-service.js +78 -36
- package/lib/gitpod-service.js.map +1 -1
- package/lib/headless-workspace-log.d.ts +2 -1
- package/lib/headless-workspace-log.d.ts.map +1 -1
- package/lib/headless-workspace-log.js +3 -2
- package/lib/headless-workspace-log.js.map +1 -1
- package/lib/ide-frontend-service.d.ts +2 -2
- package/lib/ide-frontend-service.js +1 -1
- package/lib/ide-protocol.d.ts +53 -8
- package/lib/ide-protocol.d.ts.map +1 -1
- package/lib/ide-protocol.js +11 -1
- package/lib/ide-protocol.js.map +1 -1
- package/lib/index.d.ts +17 -15
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +4 -2
- package/lib/index.js.map +1 -1
- package/lib/installation-admin-protocol.d.ts +30 -0
- package/lib/installation-admin-protocol.d.ts.map +1 -0
- package/lib/installation-admin-protocol.js +31 -0
- package/lib/installation-admin-protocol.js.map +1 -0
- package/lib/license-protocol.d.ts +8 -1
- package/lib/license-protocol.d.ts.map +1 -1
- package/lib/license-protocol.js +1 -1
- package/lib/license-protocol.js.map +1 -1
- package/lib/messaging/browser/connection.d.ts +1 -1
- package/lib/messaging/browser/connection.d.ts.map +1 -1
- package/lib/messaging/browser/connection.js +19 -19
- package/lib/messaging/browser/connection.js.map +1 -1
- package/lib/messaging/browser/window-connection.d.ts +5 -5
- package/lib/messaging/browser/window-connection.d.ts.map +1 -1
- package/lib/messaging/browser/window-connection.js +10 -7
- package/lib/messaging/browser/window-connection.js.map +1 -1
- package/lib/messaging/client-call-metrics.d.ts +5 -19
- package/lib/messaging/client-call-metrics.d.ts.map +1 -1
- package/lib/messaging/client-call-metrics.js +35 -23
- package/lib/messaging/client-call-metrics.js.map +1 -1
- package/lib/messaging/error.d.ts +12 -2
- package/lib/messaging/error.d.ts.map +1 -1
- package/lib/messaging/error.js +26 -4
- package/lib/messaging/error.js.map +1 -1
- package/lib/messaging/handler.d.ts.map +1 -1
- package/lib/messaging/handler.js +1 -1
- package/lib/messaging/node/connection.d.ts +1 -17
- package/lib/messaging/node/connection.d.ts.map +1 -1
- package/lib/messaging/node/connection.js +23 -59
- package/lib/messaging/node/connection.js.map +1 -1
- package/lib/messaging/proxy-factory.d.ts +1 -1
- package/lib/messaging/proxy-factory.d.ts.map +1 -1
- package/lib/messaging/proxy-factory.js +7 -9
- package/lib/messaging/proxy-factory.js.map +1 -1
- package/lib/oss-allowlist.d.ts +14 -0
- package/lib/oss-allowlist.d.ts.map +1 -0
- package/lib/oss-allowlist.js +8 -0
- package/lib/oss-allowlist.js.map +1 -0
- package/lib/payment-protocol.d.ts +1 -1
- package/lib/payment-protocol.d.ts.map +1 -1
- package/lib/payment-protocol.js +2 -2
- package/lib/payment-protocol.js.map +1 -1
- package/lib/permission.d.ts +13 -4
- package/lib/permission.d.ts.map +1 -1
- package/lib/permission.js +38 -26
- package/lib/permission.js.map +1 -1
- package/lib/plans.d.ts +8 -5
- package/lib/plans.d.ts.map +1 -1
- package/lib/plans.js +227 -172
- package/lib/plans.js.map +1 -1
- package/lib/protocol.d.ts +238 -104
- package/lib/protocol.d.ts.map +1 -1
- package/lib/protocol.js +322 -105
- package/lib/protocol.js.map +1 -1
- package/lib/protocol.spec.d.ts +7 -0
- package/lib/protocol.spec.d.ts.map +1 -0
- package/lib/protocol.spec.js +127 -0
- package/lib/protocol.spec.js.map +1 -0
- package/lib/snapshot-url.d.ts +1 -1
- package/lib/snapshot-url.js +1 -1
- package/lib/snapshot-url.spec.d.ts +1 -1
- package/lib/snapshot-url.spec.js +1 -1
- package/lib/snapshot-url.spec.js.map +1 -1
- package/lib/team-subscription-protocol.d.ts +24 -4
- package/lib/team-subscription-protocol.d.ts.map +1 -1
- package/lib/team-subscription-protocol.js +25 -6
- package/lib/team-subscription-protocol.js.map +1 -1
- package/lib/teams-projects-protocol.d.ts +39 -6
- package/lib/teams-projects-protocol.d.ts.map +1 -1
- package/lib/teams-projects-protocol.js +21 -3
- package/lib/teams-projects-protocol.js.map +1 -1
- package/lib/typings/globals.d.ts +7 -3
- package/lib/typings/globals.d.ts.map +1 -1
- package/lib/typings/globals.js +1 -1
- package/lib/usage.d.ts +73 -0
- package/lib/usage.d.ts.map +1 -0
- package/lib/usage.js +20 -0
- package/lib/usage.js.map +1 -0
- package/lib/util/analytics.d.ts +1 -1
- package/lib/util/analytics.d.ts.map +1 -1
- package/lib/util/analytics.js +13 -4
- package/lib/util/analytics.js.map +1 -1
- package/lib/util/async-iterator.d.ts +1 -1
- package/lib/util/async-iterator.d.ts.map +1 -1
- package/lib/util/async-iterator.js +4 -4
- package/lib/util/async-iterator.js.map +1 -1
- package/lib/util/cancelable.d.ts +1 -1
- package/lib/util/cancelable.js +1 -1
- package/lib/util/cancelable.js.map +1 -1
- package/lib/util/date-time.d.ts +1 -1
- package/lib/util/date-time.js +7 -7
- package/lib/util/date-time.js.map +1 -1
- package/lib/util/debug-app.d.ts +25 -0
- package/lib/util/debug-app.d.ts.map +1 -0
- package/lib/util/debug-app.js +100 -0
- package/lib/util/debug-app.js.map +1 -0
- package/lib/util/deep-partial.d.ts +1 -1
- package/lib/util/deep-partial.js +1 -1
- package/lib/util/deferred.d.ts +1 -1
- package/lib/util/deferred.js +1 -1
- package/lib/util/deferred.js.map +1 -1
- package/lib/util/disposable.d.ts.map +1 -1
- package/lib/util/disposable.js +2 -2
- package/lib/util/disposable.js.map +1 -1
- package/lib/util/event.d.ts.map +1 -1
- package/lib/util/event.js +5 -3
- package/lib/util/event.js.map +1 -1
- package/lib/util/garbage-collected-cache.d.ts +2 -1
- package/lib/util/garbage-collected-cache.d.ts.map +1 -1
- package/lib/util/garbage-collected-cache.js +12 -3
- package/lib/util/garbage-collected-cache.js.map +1 -1
- package/lib/util/generate-workspace-id.d.ts +6 -1
- package/lib/util/generate-workspace-id.d.ts.map +1 -1
- package/lib/util/generate-workspace-id.js +461 -440
- package/lib/util/generate-workspace-id.js.map +1 -1
- package/lib/util/generate-workspace-id.spec.d.ts +1 -1
- package/lib/util/generate-workspace-id.spec.js +37 -2
- package/lib/util/generate-workspace-id.spec.js.map +1 -1
- package/lib/util/gitpod-cookie.d.ts +2 -2
- package/lib/util/gitpod-cookie.d.ts.map +1 -1
- package/lib/util/gitpod-cookie.js +1 -4
- package/lib/util/gitpod-cookie.js.map +1 -1
- package/lib/util/gitpod-host-url.d.ts +12 -5
- package/lib/util/gitpod-host-url.d.ts.map +1 -1
- package/lib/util/gitpod-host-url.js +69 -41
- package/lib/util/gitpod-host-url.js.map +1 -1
- package/lib/util/gitpod-host-url.spec.d.ts +1 -1
- package/lib/util/gitpod-host-url.spec.d.ts.map +1 -1
- package/lib/util/gitpod-host-url.spec.js +16 -6
- package/lib/util/gitpod-host-url.spec.js.map +1 -1
- package/lib/util/grpc.d.ts +21 -1
- package/lib/util/grpc.d.ts.map +1 -1
- package/lib/util/grpc.js +74 -2
- package/lib/util/grpc.js.map +1 -1
- package/lib/util/jaeger-client-types.d.ts +68 -0
- package/lib/util/jaeger-client-types.d.ts.map +1 -0
- package/lib/{theia-plugins.js → util/jaeger-client-types.js} +2 -2
- package/lib/util/jaeger-client-types.js.map +1 -0
- package/lib/util/logging.d.ts +2 -2
- package/lib/util/logging.d.ts.map +1 -1
- package/lib/util/logging.js +32 -26
- package/lib/util/logging.js.map +1 -1
- package/lib/util/logging.spec.d.ts +7 -0
- package/lib/util/logging.spec.d.ts.map +1 -0
- package/lib/util/logging.spec.js +52 -0
- package/lib/util/logging.spec.js.map +1 -0
- package/lib/util/make-link.d.ts +1 -1
- package/lib/util/make-link.js +6 -6
- package/lib/util/make-link.js.map +1 -1
- package/lib/util/nice-grpc.d.ts +9 -0
- package/lib/util/nice-grpc.d.ts.map +1 -0
- package/lib/util/nice-grpc.js +121 -0
- package/lib/util/nice-grpc.js.map +1 -0
- package/lib/util/parse-workspace-id.d.ts +1 -1
- package/lib/util/parse-workspace-id.d.ts.map +1 -1
- package/lib/util/parse-workspace-id.js +3 -4
- package/lib/util/parse-workspace-id.js.map +1 -1
- package/lib/util/parse-workspace-id.spec.d.ts +1 -1
- package/lib/util/parse-workspace-id.spec.d.ts.map +1 -1
- package/lib/util/parse-workspace-id.spec.js +1 -1
- package/lib/util/parse-workspace-id.spec.js.map +1 -1
- package/lib/util/queue.d.ts +1 -1
- package/lib/util/queue.js +1 -1
- package/lib/util/queue.spec.d.ts +1 -1
- package/lib/util/queue.spec.js +10 -7
- package/lib/util/queue.spec.js.map +1 -1
- package/lib/util/repeat.d.ts +15 -0
- package/lib/util/repeat.d.ts.map +1 -0
- package/lib/util/repeat.js +55 -0
- package/lib/util/repeat.js.map +1 -0
- package/lib/util/semaphore.d.ts +1 -1
- package/lib/util/semaphore.d.ts.map +1 -1
- package/lib/util/semaphore.js +1 -1
- package/lib/util/semaphore.js.map +1 -1
- package/lib/util/skip-if.d.ts +1 -1
- package/lib/util/skip-if.d.ts.map +1 -1
- package/lib/util/skip-if.js +1 -1
- package/lib/util/skip-if.js.map +1 -1
- package/lib/util/timeutil.d.ts +3 -1
- package/lib/util/timeutil.d.ts.map +1 -1
- package/lib/util/timeutil.js +16 -4
- package/lib/util/timeutil.js.map +1 -1
- package/lib/util/timeutil.spec.d.ts +3 -1
- package/lib/util/timeutil.spec.d.ts.map +1 -1
- package/lib/util/timeutil.spec.js +35 -1
- package/lib/util/timeutil.spec.js.map +1 -1
- package/lib/util/tracing.d.ts +47 -13
- package/lib/util/tracing.d.ts.map +1 -1
- package/lib/util/tracing.js +141 -32
- package/lib/util/tracing.js.map +1 -1
- package/lib/util/tracing.spec.d.ts +7 -0
- package/lib/util/tracing.spec.d.ts.map +1 -0
- package/lib/util/tracing.spec.js +121 -0
- package/lib/util/tracing.spec.js.map +1 -0
- package/lib/util/workspace-port-authentication.d.ts +8 -8
- package/lib/util/workspace-port-authentication.d.ts.map +1 -1
- package/lib/util/workspace-port-authentication.js +9 -12
- package/lib/util/workspace-port-authentication.js.map +1 -1
- package/lib/webhook-event.d.ts +44 -0
- package/lib/webhook-event.d.ts.map +1 -0
- package/lib/webhook-event.js +8 -0
- package/lib/webhook-event.js.map +1 -0
- package/lib/workspace-class.d.ts +14 -0
- package/lib/workspace-class.d.ts.map +1 -0
- package/lib/workspace-class.js +8 -0
- package/lib/workspace-class.js.map +1 -0
- package/lib/workspace-cluster.d.ts +24 -18
- package/lib/workspace-cluster.d.ts.map +1 -1
- package/lib/workspace-cluster.js +22 -2
- package/lib/workspace-cluster.js.map +1 -1
- package/lib/workspace-instance.d.ts +41 -4
- package/lib/workspace-instance.d.ts.map +1 -1
- package/lib/workspace-instance.js +1 -1
- package/lib/wsready.d.ts +8 -2
- package/lib/wsready.d.ts.map +1 -1
- package/lib/wsready.js +3 -3
- package/package.json +18 -8
- package/pkg-yarn.lock +11 -6
- package/provenance-bundle.jsonl +2 -0
- package/src/accounting-protocol.ts +76 -52
- package/src/admin-protocol.ts +59 -19
- package/src/analytics.ts +27 -29
- package/src/attribution.ts +67 -0
- package/src/auth.ts +3 -3
- package/src/billing-mode.ts +84 -0
- package/src/blocked-repositories-protocol.ts +13 -0
- package/src/context-url.spec.ts +25 -15
- package/src/context-url.ts +93 -37
- package/src/encryption/container-module.ts +3 -4
- package/src/encryption/encryption-engine.spec.ts +10 -9
- package/src/encryption/encryption-engine.ts +21 -17
- package/src/encryption/encryption-service.ts +5 -6
- package/src/encryption/key-provider.ts +17 -20
- package/src/env.ts +2 -25
- package/src/experiments/always-default.ts +24 -0
- package/src/experiments/configcat-server.ts +42 -0
- package/src/experiments/configcat.ts +56 -0
- package/src/experiments/types.ts +34 -0
- package/src/frontend-dashboard-service.ts +148 -0
- package/src/gitpod-file-parser.spec.ts +56 -62
- package/src/gitpod-file-parser.ts +17 -18
- package/src/gitpod-service.ts +315 -136
- package/src/headless-workspace-log.ts +7 -5
- package/src/ide-frontend-service.ts +3 -3
- package/src/ide-protocol.ts +63 -8
- package/src/index.ts +17 -15
- package/src/installation-admin-protocol.ts +45 -0
- package/src/license-protocol.ts +13 -7
- package/src/messaging/browser/connection.ts +45 -47
- package/src/messaging/browser/window-connection.ts +40 -30
- package/src/messaging/client-call-metrics.ts +79 -82
- package/src/messaging/error.ts +37 -8
- package/src/messaging/handler.ts +6 -6
- package/src/messaging/node/connection.ts +23 -70
- package/src/messaging/proxy-factory.ts +23 -30
- package/src/oss-allowlist.ts +15 -0
- package/src/payment-protocol.ts +3 -3
- package/src/permission.ts +45 -33
- package/src/plans.ts +257 -190
- package/src/protocol.spec.ts +97 -0
- package/src/protocol.ts +650 -305
- package/src/snapshot-url.spec.ts +10 -8
- package/src/snapshot-url.ts +1 -1
- package/src/team-subscription-protocol.ts +63 -23
- package/src/teams-projects-protocol.ts +60 -12
- package/src/typings/globals.ts +12 -5
- package/src/usage.ts +85 -0
- package/src/util/analytics.ts +47 -25
- package/src/util/async-iterator.ts +5 -6
- package/src/util/cancelable.ts +4 -4
- package/src/util/date-time.ts +9 -9
- package/src/util/debug-app.ts +81 -0
- package/src/util/deep-partial.ts +1 -1
- package/src/util/deferred.ts +7 -7
- package/src/util/disposable.ts +3 -6
- package/src/util/event.ts +9 -11
- package/src/util/garbage-collected-cache.ts +15 -7
- package/src/util/generate-workspace-id.spec.ts +35 -8
- package/src/util/generate-workspace-id.ts +465 -441
- package/src/util/gitpod-cookie.ts +9 -10
- package/src/util/gitpod-host-url.spec.ts +41 -14
- package/src/util/gitpod-host-url.ts +81 -46
- package/src/util/grpc.ts +94 -2
- package/src/util/jaeger-client-types.ts +102 -0
- package/src/util/logging.spec.ts +23 -0
- package/src/util/logging.ts +61 -43
- package/src/util/make-link.ts +7 -8
- package/src/util/nice-grpc.ts +96 -0
- package/src/util/parse-workspace-id.spec.ts +18 -9
- package/src/util/parse-workspace-id.ts +7 -8
- package/src/util/queue.spec.ts +28 -26
- package/src/util/queue.ts +1 -1
- package/src/util/repeat.ts +45 -0
- package/src/util/semaphore.ts +5 -7
- package/src/util/skip-if.ts +10 -7
- package/src/util/timeutil.spec.ts +41 -15
- package/src/util/timeutil.ts +28 -12
- package/src/util/tracing.spec.ts +88 -0
- package/src/util/tracing.ts +175 -59
- package/src/util/workspace-port-authentication.ts +11 -14
- package/src/webhook-event.ts +55 -0
- package/src/workspace-class.ts +14 -0
- package/src/workspace-cluster.ts +46 -21
- package/src/workspace-instance.ts +84 -22
- package/src/wsready.ts +11 -4
- package/data/builtin-theia-plugins.json +0 -372
- package/lib/email-protocol.d.ts +0 -49
- package/lib/email-protocol.d.ts.map +0 -1
- package/lib/email-protocol.js +0 -28
- package/lib/email-protocol.js.map +0 -1
- package/lib/messaging/connection-error-handler.d.ts +0 -27
- package/lib/messaging/connection-error-handler.d.ts.map +0 -1
- package/lib/messaging/connection-error-handler.js +0 -34
- package/lib/messaging/connection-error-handler.js.map +0 -1
- package/lib/theia-plugins.d.ts +0 -11
- package/lib/theia-plugins.d.ts.map +0 -1
- package/lib/theia-plugins.js.map +0 -1
- package/lib/util/repeater.d.ts +0 -22
- package/lib/util/repeater.d.ts.map +0 -1
- package/lib/util/repeater.js +0 -65
- package/lib/util/repeater.js.map +0 -1
- package/lib/util/safe-promise.d.ts +0 -11
- package/lib/util/safe-promise.d.ts.map +0 -1
- package/lib/util/safe-promise.js +0 -31
- package/lib/util/safe-promise.js.map +0 -1
- package/src/email-protocol.ts +0 -66
- package/src/messaging/connection-error-handler.ts +0 -62
- package/src/theia-plugins.ts +0 -11
- package/src/util/jaeger-client.d.ts +0 -105
- package/src/util/repeater.ts +0 -49
- package/src/util/safe-promise.ts +0 -26
package/src/util/semaphore.ts
CHANGED
|
@@ -1,22 +1,21 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Copyright (c) 2020 Gitpod GmbH. All rights reserved.
|
|
3
3
|
* Licensed under the GNU Affero General Public License (AGPL).
|
|
4
|
-
* See License
|
|
4
|
+
* See License.AGPL.txt in the project root for license information.
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
|
|
8
7
|
export class Semaphore {
|
|
9
8
|
protected queue: (() => void)[] = [];
|
|
10
9
|
protected used: number;
|
|
11
10
|
|
|
12
11
|
constructor(protected readonly capacity: number) {
|
|
13
|
-
if(capacity < 1) {
|
|
12
|
+
if (capacity < 1) {
|
|
14
13
|
throw new Error("Capacity cannot be less than 1");
|
|
15
14
|
}
|
|
16
15
|
}
|
|
17
16
|
|
|
18
17
|
public release() {
|
|
19
|
-
if(this.used == 0) return;
|
|
18
|
+
if (this.used == 0) return;
|
|
20
19
|
|
|
21
20
|
const queued = this.queue.shift();
|
|
22
21
|
if (queued) {
|
|
@@ -28,7 +27,7 @@ export class Semaphore {
|
|
|
28
27
|
|
|
29
28
|
public async acquire(): Promise<void> {
|
|
30
29
|
this.used++;
|
|
31
|
-
if(this.used <= this.capacity) {
|
|
30
|
+
if (this.used <= this.capacity) {
|
|
32
31
|
return Promise.resolve();
|
|
33
32
|
}
|
|
34
33
|
|
|
@@ -36,5 +35,4 @@ export class Semaphore {
|
|
|
36
35
|
this.queue.push(rs);
|
|
37
36
|
});
|
|
38
37
|
}
|
|
39
|
-
|
|
40
|
-
}
|
|
38
|
+
}
|
package/src/util/skip-if.ts
CHANGED
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Copyright (c) 2020 Gitpod GmbH. All rights reserved.
|
|
3
3
|
* Licensed under the GNU Affero General Public License (AGPL).
|
|
4
|
-
* See License
|
|
4
|
+
* See License.AGPL.txt in the project root for license information.
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
|
|
8
7
|
/**
|
|
9
8
|
* The subset of actually available fields and methods which are not exported but we care about
|
|
10
9
|
*/
|
|
@@ -18,14 +17,18 @@ interface TestSuiteContext extends Mocha.ISuiteCallbackContext {
|
|
|
18
17
|
* @param doSkip A function which takes a TestSuite and decides if it should be skipped
|
|
19
18
|
*/
|
|
20
19
|
export function skipIf(doSkip: (suite: TestSuiteContext) => boolean): MochaTypeScript.SuiteTrait {
|
|
21
|
-
const trait: MochaTypeScript.SuiteTrait = function(
|
|
22
|
-
|
|
20
|
+
const trait: MochaTypeScript.SuiteTrait = function (
|
|
21
|
+
this: Mocha.ISuiteCallbackContext,
|
|
22
|
+
ctx: Mocha.ISuiteCallbackContext,
|
|
23
|
+
ctor: Function,
|
|
24
|
+
): void {
|
|
25
|
+
const suite = ctx as any as TestSuiteContext; // No idea why those fields are not exported in the types
|
|
23
26
|
const skip = doSkip(suite);
|
|
24
|
-
suite.beforeEach(function(this: Mocha.IHookCallbackContext) {
|
|
27
|
+
suite.beforeEach(function (this: Mocha.IHookCallbackContext) {
|
|
25
28
|
if (skip) {
|
|
26
29
|
this.skip();
|
|
27
30
|
}
|
|
28
|
-
})
|
|
31
|
+
});
|
|
29
32
|
};
|
|
30
33
|
|
|
31
34
|
// Mark as "trait": mimics the behavior of https://github.com/testdeck/testdeck/blob/9d2dd6a458c2c86c945f6f2999b8278b7528a7a7/index.ts#L433
|
|
@@ -45,4 +48,4 @@ export function skipIfEnvVarNotSet(name: string): MochaTypeScript.SuiteTrait {
|
|
|
45
48
|
}
|
|
46
49
|
return skip;
|
|
47
50
|
});
|
|
48
|
-
}
|
|
51
|
+
}
|
|
@@ -1,43 +1,69 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Copyright (c) 2020 Gitpod GmbH. All rights reserved.
|
|
3
3
|
* Licensed under the GNU Affero General Public License (AGPL).
|
|
4
|
-
* See License
|
|
4
|
+
* See License.AGPL.txt in the project root for license information.
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
import * as chai from
|
|
7
|
+
import * as chai from "chai";
|
|
8
8
|
const expect = chai.expect;
|
|
9
|
-
import { suite, test } from
|
|
10
|
-
import { oneMonthLater } from
|
|
9
|
+
import { suite, test } from "mocha-typescript";
|
|
10
|
+
import { daysBefore, hoursBefore, oneMonthLater } from "./timeutil";
|
|
11
11
|
|
|
12
12
|
@suite()
|
|
13
13
|
export class TimeutilSpec {
|
|
14
|
+
@test
|
|
15
|
+
testDaysBefore() {
|
|
16
|
+
const now = new Date().toISOString();
|
|
17
|
+
expect(daysBefore(now, 2)).to.be.eq(hoursBefore(now, 48));
|
|
18
|
+
}
|
|
14
19
|
|
|
15
20
|
@test
|
|
16
21
|
testTimeutil() {
|
|
17
22
|
// targeting a 1st, 1th of Jan => 1st of Feb
|
|
18
|
-
this.isOneMonthLater(new Date(2000, 0, 1), 1, new Date(2000, 1, 1))
|
|
23
|
+
this.isOneMonthLater(new Date(2000, 0, 1), 1, new Date(2000, 1, 1));
|
|
19
24
|
|
|
20
25
|
// targeting a 31th, 30th of Apr => 31st of May
|
|
21
|
-
this.isOneMonthLater(new Date(2000, 3, 30), 31, new Date(2000, 4, 31))
|
|
26
|
+
this.isOneMonthLater(new Date(2000, 3, 30), 31, new Date(2000, 4, 31));
|
|
22
27
|
|
|
23
28
|
// targeting a 31th, 31th of Mar => 30th of Apr
|
|
24
|
-
this.isOneMonthLater(new Date(2000, 2, 31), 31, new Date(2000, 3, 30))
|
|
29
|
+
this.isOneMonthLater(new Date(2000, 2, 31), 31, new Date(2000, 3, 30));
|
|
25
30
|
|
|
26
31
|
// targeting a 30th, 30th of Mar => 30th of Apr
|
|
27
|
-
this.isOneMonthLater(new Date(2000, 2, 30), 30, new Date(2000, 3, 30))
|
|
32
|
+
this.isOneMonthLater(new Date(2000, 2, 30), 30, new Date(2000, 3, 30));
|
|
28
33
|
|
|
29
34
|
// next year
|
|
30
|
-
this.isOneMonthLater(new Date(2000, 11, 1), 1, new Date(2001, 0, 1))
|
|
31
|
-
this.isOneMonthLater(new Date(2000, 11, 31), 31, new Date(2001, 0, 31))
|
|
35
|
+
this.isOneMonthLater(new Date(2000, 11, 1), 1, new Date(2001, 0, 1));
|
|
36
|
+
this.isOneMonthLater(new Date(2000, 11, 31), 31, new Date(2001, 0, 31));
|
|
32
37
|
|
|
33
38
|
// Feb
|
|
34
|
-
this.isOneMonthLater(new Date(2001, 0, 31), 31, new Date(2001, 1, 28))
|
|
39
|
+
this.isOneMonthLater(new Date(2001, 0, 31), 31, new Date(2001, 1, 28));
|
|
35
40
|
// Feb leap year
|
|
36
|
-
this.isOneMonthLater(new Date(2000, 0, 31), 31, new Date(2000, 1, 29))
|
|
41
|
+
this.isOneMonthLater(new Date(2000, 0, 31), 31, new Date(2000, 1, 29));
|
|
37
42
|
}
|
|
38
43
|
|
|
39
44
|
isOneMonthLater(from: Date, day: number, expectation: Date) {
|
|
40
|
-
const later = oneMonthLater(from.toISOString(), day)
|
|
41
|
-
expect(later, `expected ${later} to be equal ${expectation}`).to.be.equal(expectation.toISOString())
|
|
45
|
+
const later = oneMonthLater(from.toISOString(), day);
|
|
46
|
+
expect(later, `expected ${later} to be equal ${expectation}`).to.be.equal(expectation.toISOString());
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
@test
|
|
50
|
+
testDaysBefore2() {
|
|
51
|
+
const tests: { date: Date; daysEarlier: number; expectation: string }[] = [
|
|
52
|
+
{
|
|
53
|
+
date: new Date("2021-07-13T00:00:00.000Z"),
|
|
54
|
+
daysEarlier: 365,
|
|
55
|
+
expectation: "2020-07-13T00:00:00.000Z",
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
date: new Date("2019-02-01T00:00:00.000Z"),
|
|
59
|
+
daysEarlier: 365,
|
|
60
|
+
expectation: "2018-02-01T00:00:00.000Z",
|
|
61
|
+
},
|
|
62
|
+
];
|
|
63
|
+
|
|
64
|
+
for (const t of tests) {
|
|
65
|
+
const actual = daysBefore(t.date.toISOString(), t.daysEarlier);
|
|
66
|
+
expect(actual).to.equal(t.expectation, `expected ${actual} to be equal ${t.expectation}`);
|
|
67
|
+
}
|
|
42
68
|
}
|
|
43
|
-
}
|
|
69
|
+
}
|
package/src/util/timeutil.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Copyright (c) 2020 Gitpod GmbH. All rights reserved.
|
|
3
3
|
* Licensed under the GNU Affero General Public License (AGPL).
|
|
4
|
-
* See License
|
|
4
|
+
* See License.AGPL.txt in the project root for license information.
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
7
|
/**
|
|
@@ -24,28 +24,44 @@ 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 =>
|
|
28
|
-
|
|
29
|
-
|
|
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) =>
|
|
34
|
-
|
|
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 =>
|
|
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 daysBefore(date: string, days: number): string {
|
|
51
|
+
const result = new Date(date);
|
|
52
|
+
result.setDate(result.getDate() - days);
|
|
53
|
+
return result.toISOString();
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
export function hoursBefore(date: string, hours: number): string {
|
|
57
|
+
const result = new Date(date);
|
|
58
|
+
result.setHours(result.getHours() - hours);
|
|
59
|
+
return result.toISOString();
|
|
60
|
+
}
|
|
61
|
+
|
|
46
62
|
export function hoursLater(date: string, hours: number): string {
|
|
47
|
-
const result = new Date(date)
|
|
48
|
-
result.setHours(result.getHours() + hours)
|
|
63
|
+
const result = new Date(date);
|
|
64
|
+
result.setHours(result.getHours() + hours);
|
|
49
65
|
return result.toISOString();
|
|
50
66
|
}
|
|
51
67
|
|
|
@@ -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();
|
package/src/util/tracing.ts
CHANGED
|
@@ -1,96 +1,204 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Copyright (c) 2020 Gitpod GmbH. All rights reserved.
|
|
3
3
|
* Licensed under the GNU Affero General Public License (AGPL).
|
|
4
|
-
* See License
|
|
4
|
+
* See License.AGPL.txt in the project root for license information.
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
|
|
8
|
-
import
|
|
9
|
-
import {
|
|
10
|
-
import { initGlobalTracer } from
|
|
11
|
-
import { injectable } from
|
|
12
|
-
import { ResponseError } from
|
|
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";
|
|
13
14
|
|
|
14
15
|
export interface TraceContext {
|
|
15
|
-
span?: opentracing.Span
|
|
16
|
+
span?: opentracing.Span;
|
|
16
17
|
}
|
|
17
18
|
export type TraceContextWithSpan = TraceContext & {
|
|
18
|
-
span: opentracing.Span
|
|
19
|
-
}
|
|
20
|
-
|
|
19
|
+
span: opentracing.Span;
|
|
20
|
+
};
|
|
21
21
|
|
|
22
22
|
export namespace TraceContext {
|
|
23
|
-
export function startSpan(operation: string, parentCtx
|
|
24
|
-
const options: opentracing.SpanOptions = {
|
|
25
|
-
|
|
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
|
+
}
|
|
26
33
|
}
|
|
34
|
+
|
|
27
35
|
return opentracing.globalTracer().startSpan(operation, options);
|
|
28
36
|
}
|
|
29
37
|
|
|
30
|
-
export function
|
|
38
|
+
export function childContext(operation: string, parentCtx: TraceContext): TraceContextWithSpan {
|
|
31
39
|
const span = startSpan(operation, parentCtx);
|
|
32
40
|
return { span };
|
|
33
41
|
}
|
|
34
42
|
|
|
35
|
-
export function
|
|
36
|
-
|
|
37
|
-
if (
|
|
38
|
-
|
|
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();
|
|
39
58
|
}
|
|
40
|
-
return opentracing.globalTracer().startSpan(operation, options);
|
|
41
59
|
}
|
|
42
60
|
|
|
43
|
-
export function
|
|
61
|
+
export function setError(ctx: TraceContext, err: Error) {
|
|
44
62
|
if (!ctx.span) {
|
|
45
63
|
return;
|
|
46
64
|
}
|
|
47
65
|
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
66
|
+
TraceContext.addNestedTags(ctx, {
|
|
67
|
+
error: {
|
|
68
|
+
message: err.message,
|
|
69
|
+
stacktrace: err.stack,
|
|
70
|
+
},
|
|
71
|
+
});
|
|
52
72
|
ctx.span.setTag("error", true);
|
|
53
73
|
}
|
|
54
74
|
|
|
55
|
-
export function
|
|
75
|
+
export function setJsonRPCMetadata(ctx: TraceContext, method?: string) {
|
|
56
76
|
if (!ctx.span) {
|
|
57
77
|
return;
|
|
58
78
|
}
|
|
59
|
-
logError(ctx, err);
|
|
60
79
|
|
|
61
|
-
|
|
62
|
-
ctx.span.addTags({
|
|
80
|
+
const tags: { [key: string]: any } = {
|
|
63
81
|
rpc: {
|
|
64
82
|
system: "jsonrpc",
|
|
65
|
-
|
|
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: {
|
|
66
107
|
jsonrpc: {
|
|
67
108
|
error_code: err.code,
|
|
68
109
|
error_message: err.message,
|
|
69
110
|
},
|
|
70
111
|
},
|
|
71
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);
|
|
117
|
+
}
|
|
72
118
|
}
|
|
73
119
|
|
|
74
|
-
export function addJsonRPCParameters(ctx: TraceContext,
|
|
120
|
+
export function addJsonRPCParameters(ctx: TraceContext, params: { [key: string]: any }) {
|
|
75
121
|
if (!ctx.span) {
|
|
76
122
|
return;
|
|
77
123
|
}
|
|
78
124
|
|
|
79
|
-
ctx
|
|
125
|
+
setJsonRPCMetadata(ctx);
|
|
126
|
+
addNestedTags(ctx, {
|
|
80
127
|
rpc: {
|
|
81
|
-
system: "jsonrpc",
|
|
82
|
-
method,
|
|
83
128
|
jsonrpc: {
|
|
84
|
-
parameters:
|
|
129
|
+
parameters: params,
|
|
85
130
|
},
|
|
86
131
|
},
|
|
87
132
|
});
|
|
88
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
|
+
});
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
export function finishOnce(span: opentracing.Span): () => void {
|
|
191
|
+
let done = false;
|
|
192
|
+
return () => {
|
|
193
|
+
if (done) return;
|
|
194
|
+
span.finish();
|
|
195
|
+
done = true;
|
|
196
|
+
};
|
|
197
|
+
}
|
|
89
198
|
}
|
|
90
199
|
|
|
91
200
|
@injectable()
|
|
92
201
|
export class TracingManager {
|
|
93
|
-
|
|
94
202
|
public setup(serviceName: string, opts?: CustomTracerOpts) {
|
|
95
203
|
initGlobalTracer(this.getTracerForService(serviceName, opts));
|
|
96
204
|
}
|
|
@@ -99,13 +207,18 @@ export class TracingManager {
|
|
|
99
207
|
const config: TracingConfig = {
|
|
100
208
|
disable: false,
|
|
101
209
|
reporter: {
|
|
102
|
-
logSpans: false
|
|
210
|
+
logSpans: false,
|
|
103
211
|
},
|
|
104
|
-
serviceName
|
|
105
|
-
}
|
|
212
|
+
serviceName,
|
|
213
|
+
};
|
|
106
214
|
const t = initTracerFromEnv(config, {
|
|
107
|
-
logger: console
|
|
215
|
+
logger: console,
|
|
216
|
+
tags: {
|
|
217
|
+
"service.build.commit": process.env.GITPOD_BUILD_GIT_COMMIT,
|
|
218
|
+
"service.build.version": process.env.GITPOD_BUILD_VERSION,
|
|
219
|
+
},
|
|
108
220
|
});
|
|
221
|
+
|
|
109
222
|
if (opts) {
|
|
110
223
|
if (opts.perOpSampling) {
|
|
111
224
|
(t as any)._sampler = new PerOperationSampler((t as any)._sampler, opts.perOpSampling);
|
|
@@ -113,24 +226,22 @@ export class TracingManager {
|
|
|
113
226
|
}
|
|
114
227
|
return t;
|
|
115
228
|
}
|
|
116
|
-
|
|
117
229
|
}
|
|
118
230
|
|
|
119
231
|
export interface CustomTracerOpts {
|
|
120
|
-
perOpSampling?: PerOperationSampling
|
|
232
|
+
perOpSampling?: PerOperationSampling;
|
|
121
233
|
}
|
|
122
234
|
|
|
123
|
-
|
|
124
235
|
// has to conform to https://github.com/jaegertracing/jaeger-client-node/blob/0042b1c0a0796bb655eb93e77ff76ab5e94c2bb6/src/_flow/sampler-thrift.js#L32
|
|
125
236
|
export interface PerOperationSampling {
|
|
126
|
-
[key: string]: boolean
|
|
237
|
+
[key: string]: boolean;
|
|
127
238
|
}
|
|
128
239
|
|
|
129
240
|
export class PerOperationSampler implements Sampler {
|
|
130
241
|
constructor(protected readonly fallback: Sampler, protected readonly strategies: PerOperationSampling) {}
|
|
131
242
|
|
|
132
243
|
name(): string {
|
|
133
|
-
return
|
|
244
|
+
return "PerOperationSampler";
|
|
134
245
|
}
|
|
135
246
|
|
|
136
247
|
toString(): string {
|
|
@@ -170,7 +281,7 @@ export class PerOperationSampler implements Sampler {
|
|
|
170
281
|
return false; // TODO equal should be removed
|
|
171
282
|
}
|
|
172
283
|
|
|
173
|
-
close(callback: ()=>void): void {
|
|
284
|
+
close(callback: () => void): void {
|
|
174
285
|
// all nested samplers are of simple types, so we do not need to Close them
|
|
175
286
|
if (callback) {
|
|
176
287
|
callback();
|
|
@@ -179,18 +290,23 @@ export class PerOperationSampler implements Sampler {
|
|
|
179
290
|
}
|
|
180
291
|
|
|
181
292
|
// Augment interfaces with an leading parameter "TraceContext" on every method
|
|
182
|
-
type IsValidArg<T> = T extends object ? keyof T extends never ? false : true : true;
|
|
183
|
-
type AddTraceContext<T> =
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
IsValidArg<E> extends true
|
|
187
|
-
|
|
188
|
-
IsValidArg<
|
|
189
|
-
|
|
190
|
-
IsValidArg<
|
|
191
|
-
(ctx: TraceContextWithSpan) =>
|
|
192
|
-
|
|
293
|
+
type IsValidArg<T> = T extends object ? (keyof T extends never ? false : true) : true;
|
|
294
|
+
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
|
|
295
|
+
? IsValidArg<F> extends true
|
|
296
|
+
? (ctx: TraceContextWithSpan, a: A, b: B, c: C, d: D, e: E, f: F) => R
|
|
297
|
+
: IsValidArg<E> extends true
|
|
298
|
+
? (ctx: TraceContextWithSpan, a: A, b: B, c: C, d: D, e: E) => R
|
|
299
|
+
: IsValidArg<D> extends true
|
|
300
|
+
? (ctx: TraceContextWithSpan, a: A, b: B, c: C, d: D) => R
|
|
301
|
+
: IsValidArg<C> extends true
|
|
302
|
+
? (ctx: TraceContextWithSpan, a: A, b: B, c: C) => R
|
|
303
|
+
: IsValidArg<B> extends true
|
|
304
|
+
? (ctx: TraceContextWithSpan, a: A, b: B) => R
|
|
305
|
+
: IsValidArg<A> extends true
|
|
306
|
+
? (ctx: TraceContextWithSpan, a: A) => R
|
|
307
|
+
: (ctx: TraceContextWithSpan) => Promise<R>
|
|
308
|
+
: never;
|
|
193
309
|
|
|
194
310
|
export type InterfaceWithTraceContext<T> = {
|
|
195
|
-
[P in keyof T]: AddTraceContext<T[P]
|
|
196
|
-
};
|
|
311
|
+
[P in keyof T]: AddTraceContext<T[P]>;
|
|
312
|
+
};
|