@versori/run 0.2.28 → 0.3.0-beta.2

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 (425) hide show
  1. package/esm/src/connection/DirectConnectionFactory.d.ts +29 -0
  2. package/esm/src/connection/DirectConnectionFactory.d.ts.map +1 -0
  3. package/esm/src/connection/DirectConnectionFactory.js +82 -0
  4. package/esm/src/connection/DynamicFetchFactory.d.ts +30 -0
  5. package/esm/src/connection/DynamicFetchFactory.d.ts.map +1 -0
  6. package/esm/src/connection/DynamicFetchFactory.js +113 -0
  7. package/esm/src/connection/StaticFetchFactory.d.ts +11 -0
  8. package/esm/src/connection/StaticFetchFactory.d.ts.map +1 -0
  9. package/esm/src/connection/StaticFetchFactory.js +35 -0
  10. package/esm/src/connection/internal/CredentialHolder.d.ts +11 -0
  11. package/esm/src/connection/internal/CredentialHolder.d.ts.map +1 -0
  12. package/esm/src/connection/internal/CredentialHolder.js +66 -0
  13. package/esm/src/connection/internal/FetchBuilder.d.ts +15 -0
  14. package/esm/src/connection/internal/FetchBuilder.d.ts.map +1 -0
  15. package/esm/src/connection/internal/FetchBuilder.js +89 -0
  16. package/esm/src/connection/internal/HttpClientFactory.d.ts +14 -0
  17. package/esm/src/connection/internal/HttpClientFactory.d.ts.map +1 -0
  18. package/esm/src/connection/internal/HttpClientFactory.js +42 -0
  19. package/esm/src/connection/internal/InboundConnectionFactory.d.ts +19 -0
  20. package/esm/src/connection/internal/InboundConnectionFactory.d.ts.map +1 -0
  21. package/esm/src/connection/internal/InboundConnectionFactory.js +390 -0
  22. package/esm/src/connection/internal/OutboundConnectionFactory.d.ts +31 -0
  23. package/esm/src/connection/internal/OutboundConnectionFactory.d.ts.map +1 -0
  24. package/esm/src/connection/internal/OutboundConnectionFactory.js +447 -0
  25. package/esm/src/connection/types.d.ts +32 -0
  26. package/esm/src/connection/types.d.ts.map +1 -0
  27. package/esm/src/connection/types.js +1 -0
  28. package/esm/src/context/ActivationImpl.d.ts +18 -0
  29. package/esm/src/context/ActivationImpl.d.ts.map +1 -0
  30. package/esm/src/context/ActivationImpl.js +82 -0
  31. package/esm/src/context/Context.d.ts +5 -6
  32. package/esm/src/context/Context.d.ts.map +1 -1
  33. package/esm/src/context/Context.js +9 -16
  34. package/esm/src/context/ContextProvider.d.ts +7 -3
  35. package/esm/src/context/ContextProvider.d.ts.map +1 -1
  36. package/esm/src/context/ContextProvider.js +28 -10
  37. package/esm/src/dsl/http/default.d.ts.map +1 -1
  38. package/esm/src/dsl/http/default.js +3 -1
  39. package/esm/src/dsl/http/types.d.ts +9 -4
  40. package/esm/src/dsl/http/types.d.ts.map +1 -1
  41. package/esm/src/dsl/http/versori/configloader.d.ts.map +1 -1
  42. package/esm/src/dsl/http/versori/configloader.js +3 -1
  43. package/esm/src/dsl/http/versori/constants.d.ts.map +1 -1
  44. package/esm/src/dsl/http/versori/constants.js +1 -0
  45. package/esm/src/dsl/http/versori/contextcredentials.d.ts.map +1 -1
  46. package/esm/src/dsl/http/versori/platformapi.d.ts.map +1 -1
  47. package/esm/src/dsl/http/versori/proxyroundtripper.d.ts +5 -3
  48. package/esm/src/dsl/http/versori/proxyroundtripper.d.ts.map +1 -1
  49. package/esm/src/dsl/http/versori/proxyroundtripper.js +31 -8
  50. package/esm/src/dsl/http/versori/webhookmiddleware.d.ts +8 -5
  51. package/esm/src/dsl/http/versori/webhookmiddleware.d.ts.map +1 -1
  52. package/esm/src/dsl/http/versori/webhookmiddleware.js +106 -115
  53. package/esm/src/dsl/tasks/HttpTask.d.ts +7 -5
  54. package/esm/src/dsl/tasks/HttpTask.d.ts.map +1 -1
  55. package/esm/src/dsl/tasks/HttpTask.js +22 -22
  56. package/esm/src/internal/InternalAuth.d.ts +15 -0
  57. package/esm/src/internal/InternalAuth.d.ts.map +1 -0
  58. package/esm/src/internal/InternalAuth.js +90 -0
  59. package/esm/src/internal/cli.d.ts +2 -0
  60. package/esm/src/internal/cli.d.ts.map +1 -0
  61. package/esm/src/internal/cli.js +20 -0
  62. package/esm/src/internal/constants.d.ts +20 -0
  63. package/esm/src/internal/constants.d.ts.map +1 -0
  64. package/esm/src/internal/constants.js +24 -0
  65. package/esm/src/interpreter/durable/DurableInterpreter.d.ts +14 -5
  66. package/esm/src/interpreter/durable/DurableInterpreter.d.ts.map +1 -1
  67. package/esm/src/interpreter/durable/DurableInterpreter.js +20 -18
  68. package/esm/src/interpreter/durable/ObservableCompiler.d.ts +6 -3
  69. package/esm/src/interpreter/durable/ObservableCompiler.d.ts.map +1 -1
  70. package/esm/src/interpreter/durable/compilers/durableworkflow.d.ts.map +1 -1
  71. package/esm/src/interpreter/durable/compilers/durableworkflow.js +10 -1
  72. package/esm/src/interpreter/durable/compilers/http.d.ts.map +1 -1
  73. package/esm/src/interpreter/durable/compilers/http.js +26 -9
  74. package/esm/src/interpreter/durable/compilers/schedule.d.ts.map +1 -1
  75. package/esm/src/interpreter/durable/compilers/schedule.js +41 -18
  76. package/esm/src/interpreter/durable/compilers/webhook.d.ts.map +1 -1
  77. package/esm/src/interpreter/durable/compilers/webhook.js +30 -33
  78. package/esm/src/interpreter/memory/MemoryInterpreter.d.ts +4 -4
  79. package/esm/src/interpreter/memory/MemoryInterpreter.d.ts.map +1 -1
  80. package/esm/src/interpreter/memory/MemoryInterpreter.js +14 -23
  81. package/esm/src/interpreter/memory/ObservableCompiler.d.ts +6 -3
  82. package/esm/src/interpreter/memory/ObservableCompiler.d.ts.map +1 -1
  83. package/esm/src/interpreter/memory/compilers/http.d.ts.map +1 -1
  84. package/esm/src/interpreter/memory/compilers/http.js +26 -9
  85. package/esm/src/interpreter/memory/compilers/schedule.d.ts.map +1 -1
  86. package/esm/src/interpreter/memory/compilers/schedule.js +34 -18
  87. package/esm/src/interpreter/memory/compilers/webhook.d.ts.map +1 -1
  88. package/esm/src/interpreter/memory/compilers/webhook.js +31 -34
  89. package/esm/src/kv/nats/NatsKeyValueProvider.d.ts.map +1 -1
  90. package/esm/src/kv/nats/NatsKeyValueProvider.js +16 -0
  91. package/esm/src/kv/sdk/SDKKeyValueProvider.d.ts.map +1 -1
  92. package/esm/src/kv/sdk/SDKKeyValueProvider.js +14 -0
  93. package/esm/src/services/credentials/credential-v1alpha1.d.ts +4 -0
  94. package/esm/src/services/credentials/credential-v1alpha1.d.ts.map +1 -0
  95. package/esm/src/services/credentials/credential-v1alpha1.js +3 -0
  96. package/esm/src/services/credentials/generated/versori/credential/oauth1/v1/authorization_metadata_pb.d.ts +119 -0
  97. package/esm/src/services/credentials/generated/versori/credential/oauth1/v1/authorization_metadata_pb.d.ts.map +1 -0
  98. package/esm/src/services/credentials/generated/versori/credential/oauth1/v1/authorization_metadata_pb.js +67 -0
  99. package/esm/src/services/credentials/generated/versori/credential/oauth1/v1/authorization_service_pb.d.ts +245 -0
  100. package/esm/src/services/credentials/generated/versori/credential/oauth1/v1/authorization_service_pb.d.ts.map +1 -0
  101. package/esm/src/services/credentials/generated/versori/credential/oauth1/v1/authorization_service_pb.js +44 -0
  102. package/esm/src/services/credentials/generated/versori/credential/oauth2/v1/token_pb.d.ts +38 -0
  103. package/esm/src/services/credentials/generated/versori/credential/oauth2/v1/token_pb.d.ts.map +1 -0
  104. package/esm/src/{dsl/http → services/credentials/generated}/versori/credential/oauth2/v1/token_pb.js +1 -1
  105. package/esm/src/services/credentials/generated/versori/credential/oauth2/v1/token_service_pb.d.ts +471 -0
  106. package/esm/src/services/credentials/generated/versori/credential/oauth2/v1/token_service_pb.d.ts.map +1 -0
  107. package/esm/src/{dsl/http → services/credentials/generated}/versori/credential/oauth2/v1/token_service_pb.js +1 -1
  108. package/esm/src/services/credentials/generated/versori/credential/tokens/v1/token_pb.d.ts +38 -0
  109. package/esm/src/services/credentials/generated/versori/credential/tokens/v1/token_pb.d.ts.map +1 -0
  110. package/esm/src/{dsl/http → services/credentials/generated}/versori/credential/tokens/v1/token_pb.js +1 -1
  111. package/esm/src/services/credentials/generated/versori/credential/tokens/v1/token_service_pb.d.ts +128 -0
  112. package/esm/src/services/credentials/generated/versori/credential/tokens/v1/token_service_pb.d.ts.map +1 -0
  113. package/esm/src/{dsl/http → services/credentials/generated}/versori/credential/tokens/v1/token_service_pb.js +1 -1
  114. package/esm/src/services/credentials/generated/versori/credential/v1alpha1/common_pb.d.ts +90 -0
  115. package/esm/src/services/credentials/generated/versori/credential/v1alpha1/common_pb.d.ts.map +1 -0
  116. package/esm/src/{dsl/http → services/credentials/generated}/versori/credential/v1alpha1/common_pb.js +16 -6
  117. package/esm/src/services/credentials/generated/versori/credential/v1alpha1/credential_pb.d.ts +1468 -0
  118. package/esm/src/services/credentials/generated/versori/credential/v1alpha1/credential_pb.d.ts.map +1 -0
  119. package/esm/src/services/credentials/generated/versori/credential/v1alpha1/credential_pb.js +534 -0
  120. package/esm/src/services/credentials/generated/versori/credential/v1alpha1/credential_service_pb.d.ts +390 -0
  121. package/esm/src/services/credentials/generated/versori/credential/v1alpha1/credential_service_pb.d.ts.map +1 -0
  122. package/esm/src/{dsl/http → services/credentials/generated}/versori/credential/v1alpha1/credential_service_pb.js +1 -1
  123. package/esm/src/services/credentials/isTokenValid.d.ts +3 -0
  124. package/esm/src/services/credentials/isTokenValid.d.ts.map +1 -0
  125. package/esm/src/services/credentials/isTokenValid.js +8 -0
  126. package/esm/src/services/credentials/mod.d.ts +5 -0
  127. package/esm/src/services/credentials/mod.d.ts.map +1 -0
  128. package/esm/src/services/credentials/mod.js +4 -0
  129. package/esm/src/services/credentials/oauth1-v1.d.ts +3 -0
  130. package/esm/src/services/credentials/oauth1-v1.d.ts.map +1 -0
  131. package/esm/src/services/credentials/oauth1-v1.js +2 -0
  132. package/esm/src/services/credentials/oauth2-v1.d.ts +3 -0
  133. package/esm/src/services/credentials/oauth2-v1.d.ts.map +1 -0
  134. package/esm/src/services/credentials/oauth2-v1.js +2 -0
  135. package/esm/src/services/credentials/tokens-v1.d.ts +3 -0
  136. package/esm/src/services/credentials/tokens-v1.d.ts.map +1 -0
  137. package/esm/src/services/credentials/tokens-v1.js +2 -0
  138. package/esm/src/services/platform/PlatformApi.d.ts +7 -0
  139. package/esm/src/services/platform/PlatformApi.d.ts.map +1 -0
  140. package/esm/src/services/platform/PlatformApi.js +25 -0
  141. package/esm/src/services/platform/generated/client/client.gen.d.ts +3 -0
  142. package/esm/src/services/platform/generated/client/client.gen.d.ts.map +1 -0
  143. package/esm/src/services/platform/generated/client/client.gen.js +176 -0
  144. package/esm/src/services/platform/generated/client/index.d.ts +8 -0
  145. package/esm/src/services/platform/generated/client/index.d.ts.map +1 -0
  146. package/esm/src/services/platform/generated/client/index.js +5 -0
  147. package/esm/src/services/platform/generated/client/types.gen.d.ts +125 -0
  148. package/esm/src/services/platform/generated/client/types.gen.d.ts.map +1 -0
  149. package/esm/src/services/platform/generated/client/types.gen.js +2 -0
  150. package/esm/src/services/platform/generated/client/utils.gen.d.ts +39 -0
  151. package/esm/src/services/platform/generated/client/utils.gen.d.ts.map +1 -0
  152. package/esm/src/services/platform/generated/client/utils.gen.js +234 -0
  153. package/esm/src/services/platform/generated/client.gen.d.ts +13 -0
  154. package/esm/src/services/platform/generated/client.gen.d.ts.map +1 -0
  155. package/esm/src/services/platform/generated/client.gen.js +5 -0
  156. package/esm/src/services/platform/generated/core/auth.gen.d.ts +19 -0
  157. package/esm/src/services/platform/generated/core/auth.gen.d.ts.map +1 -0
  158. package/esm/src/services/platform/generated/core/auth.gen.js +14 -0
  159. package/esm/src/services/platform/generated/core/bodySerializer.gen.d.ts +18 -0
  160. package/esm/src/services/platform/generated/core/bodySerializer.gen.d.ts.map +1 -0
  161. package/esm/src/services/platform/generated/core/bodySerializer.gen.js +57 -0
  162. package/esm/src/services/platform/generated/core/params.gen.d.ts +34 -0
  163. package/esm/src/services/platform/generated/core/params.gen.d.ts.map +1 -0
  164. package/esm/src/services/platform/generated/core/params.gen.js +88 -0
  165. package/esm/src/services/platform/generated/core/pathSerializer.gen.d.ts +34 -0
  166. package/esm/src/services/platform/generated/core/pathSerializer.gen.d.ts.map +1 -0
  167. package/esm/src/services/platform/generated/core/pathSerializer.gen.js +114 -0
  168. package/esm/src/services/platform/generated/core/serverSentEvents.gen.d.ts +60 -0
  169. package/esm/src/services/platform/generated/core/serverSentEvents.gen.d.ts.map +1 -0
  170. package/esm/src/services/platform/generated/core/serverSentEvents.gen.js +121 -0
  171. package/esm/src/services/platform/generated/core/types.gen.d.ts +79 -0
  172. package/esm/src/services/platform/generated/core/types.gen.d.ts.map +1 -0
  173. package/esm/src/services/platform/generated/core/types.gen.js +2 -0
  174. package/esm/src/services/platform/generated/core/utils.gen.d.ts +15 -0
  175. package/esm/src/services/platform/generated/core/utils.gen.d.ts.map +1 -0
  176. package/esm/src/services/platform/generated/core/utils.gen.js +69 -0
  177. package/esm/src/services/platform/generated/index.d.ts +3 -0
  178. package/esm/src/services/platform/generated/index.d.ts.map +1 -0
  179. package/esm/src/services/platform/generated/index.js +3 -0
  180. package/esm/src/services/platform/generated/sdk.gen.d.ts +494 -0
  181. package/esm/src/services/platform/generated/sdk.gen.d.ts.map +1 -0
  182. package/esm/src/services/platform/generated/sdk.gen.js +1908 -0
  183. package/esm/src/services/platform/generated/types.gen.d.ts +3798 -0
  184. package/esm/src/services/platform/generated/types.gen.d.ts.map +1 -0
  185. package/esm/src/services/platform/generated/types.gen.js +2 -0
  186. package/esm/src/services/platform/mod.d.ts +5 -0
  187. package/esm/src/services/platform/mod.d.ts.map +1 -0
  188. package/esm/src/services/platform/mod.js +2 -0
  189. package/package.json +4 -4
  190. package/script/src/connection/DirectConnectionFactory.d.ts +29 -0
  191. package/script/src/connection/DirectConnectionFactory.d.ts.map +1 -0
  192. package/script/src/connection/DirectConnectionFactory.js +86 -0
  193. package/script/src/connection/DynamicFetchFactory.d.ts +30 -0
  194. package/script/src/connection/DynamicFetchFactory.d.ts.map +1 -0
  195. package/script/src/connection/DynamicFetchFactory.js +117 -0
  196. package/script/src/connection/StaticFetchFactory.d.ts +11 -0
  197. package/script/src/connection/StaticFetchFactory.d.ts.map +1 -0
  198. package/script/src/connection/StaticFetchFactory.js +39 -0
  199. package/script/src/connection/internal/CredentialHolder.d.ts +11 -0
  200. package/script/src/connection/internal/CredentialHolder.d.ts.map +1 -0
  201. package/script/src/connection/internal/CredentialHolder.js +71 -0
  202. package/script/src/connection/internal/FetchBuilder.d.ts +15 -0
  203. package/script/src/connection/internal/FetchBuilder.d.ts.map +1 -0
  204. package/script/src/connection/internal/FetchBuilder.js +93 -0
  205. package/script/src/connection/internal/HttpClientFactory.d.ts +14 -0
  206. package/script/src/connection/internal/HttpClientFactory.d.ts.map +1 -0
  207. package/script/src/connection/internal/HttpClientFactory.js +46 -0
  208. package/script/src/connection/internal/InboundConnectionFactory.d.ts +19 -0
  209. package/script/src/connection/internal/InboundConnectionFactory.d.ts.map +1 -0
  210. package/script/src/connection/internal/InboundConnectionFactory.js +394 -0
  211. package/script/src/connection/internal/OutboundConnectionFactory.d.ts +31 -0
  212. package/script/src/connection/internal/OutboundConnectionFactory.d.ts.map +1 -0
  213. package/script/src/connection/internal/OutboundConnectionFactory.js +454 -0
  214. package/script/src/connection/types.d.ts +32 -0
  215. package/script/src/connection/types.d.ts.map +1 -0
  216. package/script/src/connection/types.js +2 -0
  217. package/script/src/context/ActivationImpl.d.ts +18 -0
  218. package/script/src/context/ActivationImpl.d.ts.map +1 -0
  219. package/script/src/context/ActivationImpl.js +86 -0
  220. package/script/src/context/Context.d.ts +5 -6
  221. package/script/src/context/Context.d.ts.map +1 -1
  222. package/script/src/context/Context.js +9 -16
  223. package/script/src/context/ContextProvider.d.ts +7 -3
  224. package/script/src/context/ContextProvider.d.ts.map +1 -1
  225. package/script/src/context/ContextProvider.js +28 -10
  226. package/script/src/dsl/http/default.d.ts.map +1 -1
  227. package/script/src/dsl/http/default.js +3 -1
  228. package/script/src/dsl/http/types.d.ts +9 -4
  229. package/script/src/dsl/http/types.d.ts.map +1 -1
  230. package/script/src/dsl/http/versori/configloader.d.ts.map +1 -1
  231. package/script/src/dsl/http/versori/configloader.js +3 -1
  232. package/script/src/dsl/http/versori/constants.d.ts.map +1 -1
  233. package/script/src/dsl/http/versori/constants.js +1 -0
  234. package/script/src/dsl/http/versori/contextcredentials.d.ts.map +1 -1
  235. package/script/src/dsl/http/versori/platformapi.d.ts.map +1 -1
  236. package/script/src/dsl/http/versori/proxyroundtripper.d.ts +5 -3
  237. package/script/src/dsl/http/versori/proxyroundtripper.d.ts.map +1 -1
  238. package/script/src/dsl/http/versori/proxyroundtripper.js +31 -8
  239. package/script/src/dsl/http/versori/webhookmiddleware.d.ts +8 -5
  240. package/script/src/dsl/http/versori/webhookmiddleware.d.ts.map +1 -1
  241. package/script/src/dsl/http/versori/webhookmiddleware.js +106 -115
  242. package/script/src/dsl/tasks/HttpTask.d.ts +7 -5
  243. package/script/src/dsl/tasks/HttpTask.d.ts.map +1 -1
  244. package/script/src/dsl/tasks/HttpTask.js +22 -22
  245. package/script/src/internal/InternalAuth.d.ts +15 -0
  246. package/script/src/internal/InternalAuth.d.ts.map +1 -0
  247. package/script/src/internal/InternalAuth.js +94 -0
  248. package/script/src/internal/cli.d.ts +2 -0
  249. package/script/src/internal/cli.d.ts.map +1 -0
  250. package/script/src/internal/cli.js +23 -0
  251. package/script/src/internal/constants.d.ts +20 -0
  252. package/script/src/internal/constants.d.ts.map +1 -0
  253. package/script/src/internal/constants.js +27 -0
  254. package/script/src/interpreter/durable/DurableInterpreter.d.ts +14 -5
  255. package/script/src/interpreter/durable/DurableInterpreter.d.ts.map +1 -1
  256. package/script/src/interpreter/durable/DurableInterpreter.js +20 -18
  257. package/script/src/interpreter/durable/ObservableCompiler.d.ts +6 -3
  258. package/script/src/interpreter/durable/ObservableCompiler.d.ts.map +1 -1
  259. package/script/src/interpreter/durable/compilers/durableworkflow.d.ts.map +1 -1
  260. package/script/src/interpreter/durable/compilers/durableworkflow.js +10 -1
  261. package/script/src/interpreter/durable/compilers/http.d.ts.map +1 -1
  262. package/script/src/interpreter/durable/compilers/http.js +26 -9
  263. package/script/src/interpreter/durable/compilers/schedule.d.ts.map +1 -1
  264. package/script/src/interpreter/durable/compilers/schedule.js +41 -18
  265. package/script/src/interpreter/durable/compilers/webhook.d.ts.map +1 -1
  266. package/script/src/interpreter/durable/compilers/webhook.js +30 -33
  267. package/script/src/interpreter/memory/MemoryInterpreter.d.ts +4 -4
  268. package/script/src/interpreter/memory/MemoryInterpreter.d.ts.map +1 -1
  269. package/script/src/interpreter/memory/MemoryInterpreter.js +14 -23
  270. package/script/src/interpreter/memory/ObservableCompiler.d.ts +6 -3
  271. package/script/src/interpreter/memory/ObservableCompiler.d.ts.map +1 -1
  272. package/script/src/interpreter/memory/compilers/http.d.ts.map +1 -1
  273. package/script/src/interpreter/memory/compilers/http.js +26 -9
  274. package/script/src/interpreter/memory/compilers/schedule.d.ts.map +1 -1
  275. package/script/src/interpreter/memory/compilers/schedule.js +34 -18
  276. package/script/src/interpreter/memory/compilers/webhook.d.ts.map +1 -1
  277. package/script/src/interpreter/memory/compilers/webhook.js +31 -34
  278. package/script/src/kv/nats/NatsKeyValueProvider.d.ts.map +1 -1
  279. package/script/src/kv/nats/NatsKeyValueProvider.js +16 -0
  280. package/script/src/kv/sdk/SDKKeyValueProvider.d.ts.map +1 -1
  281. package/script/src/kv/sdk/SDKKeyValueProvider.js +14 -0
  282. package/script/src/services/credentials/credential-v1alpha1.d.ts +4 -0
  283. package/script/src/services/credentials/credential-v1alpha1.d.ts.map +1 -0
  284. package/script/src/services/credentials/credential-v1alpha1.js +19 -0
  285. package/script/src/services/credentials/generated/versori/credential/oauth1/v1/authorization_metadata_pb.d.ts +119 -0
  286. package/script/src/services/credentials/generated/versori/credential/oauth1/v1/authorization_metadata_pb.d.ts.map +1 -0
  287. package/script/src/services/credentials/generated/versori/credential/oauth1/v1/authorization_metadata_pb.js +70 -0
  288. package/script/src/services/credentials/generated/versori/credential/oauth1/v1/authorization_service_pb.d.ts +245 -0
  289. package/script/src/services/credentials/generated/versori/credential/oauth1/v1/authorization_service_pb.d.ts.map +1 -0
  290. package/script/src/services/credentials/generated/versori/credential/oauth1/v1/authorization_service_pb.js +47 -0
  291. package/script/src/services/credentials/generated/versori/credential/oauth2/v1/token_pb.d.ts +38 -0
  292. package/script/src/services/credentials/generated/versori/credential/oauth2/v1/token_pb.d.ts.map +1 -0
  293. package/script/src/{dsl/http → services/credentials/generated}/versori/credential/oauth2/v1/token_pb.js +1 -1
  294. package/script/src/services/credentials/generated/versori/credential/oauth2/v1/token_service_pb.d.ts +471 -0
  295. package/script/src/services/credentials/generated/versori/credential/oauth2/v1/token_service_pb.d.ts.map +1 -0
  296. package/script/src/{dsl/http → services/credentials/generated}/versori/credential/oauth2/v1/token_service_pb.js +1 -1
  297. package/script/src/services/credentials/generated/versori/credential/tokens/v1/token_pb.d.ts +38 -0
  298. package/script/src/services/credentials/generated/versori/credential/tokens/v1/token_pb.d.ts.map +1 -0
  299. package/script/src/{dsl/http → services/credentials/generated}/versori/credential/tokens/v1/token_pb.js +1 -1
  300. package/script/src/services/credentials/generated/versori/credential/tokens/v1/token_service_pb.d.ts +128 -0
  301. package/script/src/services/credentials/generated/versori/credential/tokens/v1/token_service_pb.d.ts.map +1 -0
  302. package/script/src/{dsl/http → services/credentials/generated}/versori/credential/tokens/v1/token_service_pb.js +1 -1
  303. package/script/src/services/credentials/generated/versori/credential/v1alpha1/common_pb.d.ts +90 -0
  304. package/script/src/services/credentials/generated/versori/credential/v1alpha1/common_pb.d.ts.map +1 -0
  305. package/script/src/{dsl/http → services/credentials/generated}/versori/credential/v1alpha1/common_pb.js +16 -6
  306. package/script/src/services/credentials/generated/versori/credential/v1alpha1/credential_pb.d.ts +1468 -0
  307. package/script/src/services/credentials/generated/versori/credential/v1alpha1/credential_pb.d.ts.map +1 -0
  308. package/script/src/services/credentials/generated/versori/credential/v1alpha1/credential_pb.js +538 -0
  309. package/script/src/services/credentials/generated/versori/credential/v1alpha1/credential_service_pb.d.ts +390 -0
  310. package/script/src/services/credentials/generated/versori/credential/v1alpha1/credential_service_pb.d.ts.map +1 -0
  311. package/script/src/{dsl/http → services/credentials/generated}/versori/credential/v1alpha1/credential_service_pb.js +1 -1
  312. package/script/src/services/credentials/isTokenValid.d.ts +3 -0
  313. package/script/src/services/credentials/isTokenValid.d.ts.map +1 -0
  314. package/script/src/services/credentials/isTokenValid.js +11 -0
  315. package/script/src/services/credentials/mod.d.ts +5 -0
  316. package/script/src/services/credentials/mod.d.ts.map +1 -0
  317. package/script/src/services/credentials/mod.js +30 -0
  318. package/script/src/services/credentials/oauth1-v1.d.ts +3 -0
  319. package/script/src/services/credentials/oauth1-v1.d.ts.map +1 -0
  320. package/script/src/services/credentials/oauth1-v1.js +18 -0
  321. package/script/src/services/credentials/oauth2-v1.d.ts +3 -0
  322. package/script/src/services/credentials/oauth2-v1.d.ts.map +1 -0
  323. package/script/src/services/credentials/oauth2-v1.js +18 -0
  324. package/script/src/services/credentials/tokens-v1.d.ts +3 -0
  325. package/script/src/services/credentials/tokens-v1.d.ts.map +1 -0
  326. package/script/src/services/credentials/tokens-v1.js +18 -0
  327. package/script/src/services/platform/PlatformApi.d.ts +7 -0
  328. package/script/src/services/platform/PlatformApi.d.ts.map +1 -0
  329. package/script/src/services/platform/PlatformApi.js +52 -0
  330. package/script/src/services/platform/generated/client/client.gen.d.ts +3 -0
  331. package/script/src/services/platform/generated/client/client.gen.d.ts.map +1 -0
  332. package/script/src/services/platform/generated/client/client.gen.js +180 -0
  333. package/script/src/services/platform/generated/client/index.d.ts +8 -0
  334. package/script/src/services/platform/generated/client/index.d.ts.map +1 -0
  335. package/script/src/services/platform/generated/client/index.js +15 -0
  336. package/script/src/services/platform/generated/client/types.gen.d.ts +125 -0
  337. package/script/src/services/platform/generated/client/types.gen.d.ts.map +1 -0
  338. package/script/src/services/platform/generated/client/types.gen.js +3 -0
  339. package/script/src/services/platform/generated/client/utils.gen.d.ts +39 -0
  340. package/script/src/services/platform/generated/client/utils.gen.d.ts.map +1 -0
  341. package/script/src/services/platform/generated/client/utils.gen.js +245 -0
  342. package/script/src/services/platform/generated/client.gen.d.ts +13 -0
  343. package/script/src/services/platform/generated/client.gen.d.ts.map +1 -0
  344. package/script/src/services/platform/generated/client.gen.js +8 -0
  345. package/script/src/services/platform/generated/core/auth.gen.d.ts +19 -0
  346. package/script/src/services/platform/generated/core/auth.gen.d.ts.map +1 -0
  347. package/script/src/services/platform/generated/core/auth.gen.js +18 -0
  348. package/script/src/services/platform/generated/core/bodySerializer.gen.d.ts +18 -0
  349. package/script/src/services/platform/generated/core/bodySerializer.gen.d.ts.map +1 -0
  350. package/script/src/services/platform/generated/core/bodySerializer.gen.js +60 -0
  351. package/script/src/services/platform/generated/core/params.gen.d.ts +34 -0
  352. package/script/src/services/platform/generated/core/params.gen.d.ts.map +1 -0
  353. package/script/src/services/platform/generated/core/params.gen.js +92 -0
  354. package/script/src/services/platform/generated/core/pathSerializer.gen.d.ts +34 -0
  355. package/script/src/services/platform/generated/core/pathSerializer.gen.d.ts.map +1 -0
  356. package/script/src/services/platform/generated/core/pathSerializer.gen.js +123 -0
  357. package/script/src/services/platform/generated/core/serverSentEvents.gen.d.ts +60 -0
  358. package/script/src/services/platform/generated/core/serverSentEvents.gen.d.ts.map +1 -0
  359. package/script/src/services/platform/generated/core/serverSentEvents.gen.js +125 -0
  360. package/script/src/services/platform/generated/core/types.gen.d.ts +79 -0
  361. package/script/src/services/platform/generated/core/types.gen.d.ts.map +1 -0
  362. package/script/src/services/platform/generated/core/types.gen.js +3 -0
  363. package/script/src/services/platform/generated/core/utils.gen.d.ts +15 -0
  364. package/script/src/services/platform/generated/core/utils.gen.d.ts.map +1 -0
  365. package/script/src/services/platform/generated/core/utils.gen.js +74 -0
  366. package/script/src/services/platform/generated/index.d.ts +3 -0
  367. package/script/src/services/platform/generated/index.d.ts.map +1 -0
  368. package/script/src/services/platform/generated/index.js +19 -0
  369. package/script/src/services/platform/generated/sdk.gen.d.ts +494 -0
  370. package/script/src/services/platform/generated/sdk.gen.d.ts.map +1 -0
  371. package/script/src/services/platform/generated/sdk.gen.js +1992 -0
  372. package/script/src/services/platform/generated/types.gen.d.ts +3798 -0
  373. package/script/src/services/platform/generated/types.gen.d.ts.map +1 -0
  374. package/script/src/services/platform/generated/types.gen.js +3 -0
  375. package/script/src/services/platform/mod.d.ts +5 -0
  376. package/script/src/services/platform/mod.d.ts.map +1 -0
  377. package/script/src/services/platform/mod.js +18 -0
  378. package/esm/src/dsl/http/versori/credential/client.d.ts +0 -13
  379. package/esm/src/dsl/http/versori/credential/client.d.ts.map +0 -1
  380. package/esm/src/dsl/http/versori/credential/client.js +0 -35
  381. package/esm/src/dsl/http/versori/credential/credentials.d.ts +0 -98
  382. package/esm/src/dsl/http/versori/credential/credentials.d.ts.map +0 -1
  383. package/esm/src/dsl/http/versori/credential/credentials.js +0 -40
  384. package/esm/src/dsl/http/versori/credential/mod.d.ts +0 -2
  385. package/esm/src/dsl/http/versori/credential/mod.d.ts.map +0 -1
  386. package/esm/src/dsl/http/versori/credential/mod.js +0 -1
  387. package/esm/src/dsl/http/versori/credential/oauth2/v1/token_pb.d.ts +0 -13
  388. package/esm/src/dsl/http/versori/credential/oauth2/v1/token_pb.d.ts.map +0 -1
  389. package/esm/src/dsl/http/versori/credential/oauth2/v1/token_service_pb.d.ts +0 -102
  390. package/esm/src/dsl/http/versori/credential/oauth2/v1/token_service_pb.d.ts.map +0 -1
  391. package/esm/src/dsl/http/versori/credential/tokens/v1/token_pb.d.ts +0 -13
  392. package/esm/src/dsl/http/versori/credential/tokens/v1/token_pb.d.ts.map +0 -1
  393. package/esm/src/dsl/http/versori/credential/tokens/v1/token_service_pb.d.ts +0 -46
  394. package/esm/src/dsl/http/versori/credential/tokens/v1/token_service_pb.d.ts.map +0 -1
  395. package/esm/src/dsl/http/versori/credential/v1alpha1/common_pb.d.ts +0 -40
  396. package/esm/src/dsl/http/versori/credential/v1alpha1/common_pb.d.ts.map +0 -1
  397. package/esm/src/dsl/http/versori/credential/v1alpha1/credential_service_pb.d.ts +0 -129
  398. package/esm/src/dsl/http/versori/credential/v1alpha1/credential_service_pb.d.ts.map +0 -1
  399. package/esm/src/dsl/http/versori/roundtripper.d.ts +0 -61
  400. package/esm/src/dsl/http/versori/roundtripper.d.ts.map +0 -1
  401. package/esm/src/dsl/http/versori/roundtripper.js +0 -967
  402. package/script/src/dsl/http/versori/credential/client.d.ts +0 -13
  403. package/script/src/dsl/http/versori/credential/client.d.ts.map +0 -1
  404. package/script/src/dsl/http/versori/credential/client.js +0 -39
  405. package/script/src/dsl/http/versori/credential/credentials.d.ts +0 -98
  406. package/script/src/dsl/http/versori/credential/credentials.d.ts.map +0 -1
  407. package/script/src/dsl/http/versori/credential/credentials.js +0 -46
  408. package/script/src/dsl/http/versori/credential/mod.d.ts +0 -2
  409. package/script/src/dsl/http/versori/credential/mod.d.ts.map +0 -1
  410. package/script/src/dsl/http/versori/credential/mod.js +0 -5
  411. package/script/src/dsl/http/versori/credential/oauth2/v1/token_pb.d.ts +0 -13
  412. package/script/src/dsl/http/versori/credential/oauth2/v1/token_pb.d.ts.map +0 -1
  413. package/script/src/dsl/http/versori/credential/oauth2/v1/token_service_pb.d.ts +0 -102
  414. package/script/src/dsl/http/versori/credential/oauth2/v1/token_service_pb.d.ts.map +0 -1
  415. package/script/src/dsl/http/versori/credential/tokens/v1/token_pb.d.ts +0 -13
  416. package/script/src/dsl/http/versori/credential/tokens/v1/token_pb.d.ts.map +0 -1
  417. package/script/src/dsl/http/versori/credential/tokens/v1/token_service_pb.d.ts +0 -46
  418. package/script/src/dsl/http/versori/credential/tokens/v1/token_service_pb.d.ts.map +0 -1
  419. package/script/src/dsl/http/versori/credential/v1alpha1/common_pb.d.ts +0 -40
  420. package/script/src/dsl/http/versori/credential/v1alpha1/common_pb.d.ts.map +0 -1
  421. package/script/src/dsl/http/versori/credential/v1alpha1/credential_service_pb.d.ts +0 -129
  422. package/script/src/dsl/http/versori/credential/v1alpha1/credential_service_pb.d.ts.map +0 -1
  423. package/script/src/dsl/http/versori/roundtripper.d.ts +0 -61
  424. package/script/src/dsl/http/versori/roundtripper.d.ts.map +0 -1
  425. package/script/src/dsl/http/versori/roundtripper.js +0 -974
@@ -1,967 +0,0 @@
1
- import { Code, ConnectError } from '@connectrpc/connect';
2
- import { ConsoleLogger } from '../../../observability/mod.js';
3
- import { VersoriConfigReader } from './configloader.js';
4
- import { envVarCredsBaseURL, envVarEnvId, envVarOrgId, envVarPlatformApiBaseURL, } from './constants.js';
5
- import { VersoriCredentialClient } from './credential/mod.js';
6
- import { isValidURL } from './helpers.js';
7
- import { PlatformAPIClient } from './platformapi.js';
8
- import { URLSearchParams } from 'node:url';
9
- import { createHmac } from 'node:crypto';
10
- import { LRUCache } from 'lru-cache';
11
- import { timestampMs } from '@bufbuild/protobuf/wkt';
12
- import OAuth from 'oauth-1.0a'; // Importing the OAuth class as default export
13
- /**
14
- * VersoriRoundTripper is an implementation of the RoundTripperFactory interface for Versori connections.
15
- * This is the intended implementation for when projects/services are hosted on Versori infrastructure.
16
- *
17
- * @example
18
- * ```typescript
19
- * const factory = new VersoriCredentialsFactory(connectAPIClient, tokenClient);
20
- * const customFetch = await factory.create('connectionName');
21
- * const response = await customFetch('https://api.example.com/data');
22
- * ```
23
- */
24
- export class VersoriCredentialsFactory {
25
- constructor(credsClient, credsBaseURL, platformAPIClient, logger, tracer, cfgReader) {
26
- Object.defineProperty(this, "tokenClient", {
27
- enumerable: true,
28
- configurable: true,
29
- writable: true,
30
- value: void 0
31
- });
32
- Object.defineProperty(this, "credsBaseURL", {
33
- enumerable: true,
34
- configurable: true,
35
- writable: true,
36
- value: void 0
37
- });
38
- Object.defineProperty(this, "platformAPIClient", {
39
- enumerable: true,
40
- configurable: true,
41
- writable: true,
42
- value: void 0
43
- });
44
- Object.defineProperty(this, "cfgReader", {
45
- enumerable: true,
46
- configurable: true,
47
- writable: true,
48
- value: void 0
49
- });
50
- Object.defineProperty(this, "log", {
51
- enumerable: true,
52
- configurable: true,
53
- writable: true,
54
- value: void 0
55
- });
56
- Object.defineProperty(this, "tracer", {
57
- enumerable: true,
58
- configurable: true,
59
- writable: true,
60
- value: void 0
61
- });
62
- Object.defineProperty(this, "oauth2Cache", {
63
- enumerable: true,
64
- configurable: true,
65
- writable: true,
66
- value: void 0
67
- });
68
- Object.defineProperty(this, "defaultDynamic", {
69
- enumerable: true,
70
- configurable: true,
71
- writable: true,
72
- value: (msg, values) => {
73
- return (_, input, init) => {
74
- this.log.error(msg, values);
75
- return globalThis.fetch(input, init);
76
- };
77
- }
78
- });
79
- this.tokenClient = credsClient;
80
- this.credsBaseURL = credsBaseURL;
81
- this.platformAPIClient = platformAPIClient;
82
- this.cfgReader = cfgReader;
83
- this.log = logger;
84
- this.tracer = tracer;
85
- this.oauth2Cache = new LRUCache({
86
- max: 1000,
87
- ttl: 2000 * 60 * 5,
88
- });
89
- // lost 15 minutes because of this one
90
- this.traceFetch = this.traceFetch.bind(this);
91
- this.credentials = this.credentials.bind(this);
92
- }
93
- static fromEnv(logger, tracer) {
94
- const credsBaseURL = Deno.env.get(envVarCredsBaseURL);
95
- const platformApiBaseURL = Deno.env.get(envVarPlatformApiBaseURL);
96
- const orgId = Deno.env.get(envVarOrgId);
97
- const envId = Deno.env.get(envVarEnvId);
98
- const cfgReader = VersoriConfigReader.fromEnv(logger);
99
- if (!orgId || !envId || !platformApiBaseURL || !credsBaseURL) {
100
- const missingVars = [];
101
- if (!orgId)
102
- missingVars.push(envVarOrgId);
103
- if (!envId)
104
- missingVars.push(envVarEnvId);
105
- if (!platformApiBaseURL)
106
- missingVars.push(envVarPlatformApiBaseURL);
107
- if (!credsBaseURL)
108
- missingVars.push(envVarCredsBaseURL);
109
- throw new Error(`Missing environment variables: ${missingVars.join(', ')}`);
110
- }
111
- const log = logger || new ConsoleLogger('debug');
112
- const pAPIClient = new PlatformAPIClient(platformApiBaseURL, orgId, envId, log);
113
- const tokenClient = new VersoriCredentialClient(credsBaseURL);
114
- return new VersoriCredentialsFactory(tokenClient, credsBaseURL, pAPIClient, log, tracer, cfgReader);
115
- }
116
- // takes the info and modifies the url using changeBaseUrl if necessary
117
- // if a full valid URL is passed as a string, it will be returned as is
118
- // if a valid URL object is passed, it will be returned as is
119
- changeRequestInit(info, conn) {
120
- if (typeof info === 'string') {
121
- if (isValidURL(info)) {
122
- return info;
123
- }
124
- return this.changeBaseUrl(info, conn);
125
- }
126
- else if (info instanceof URL) {
127
- return info;
128
- }
129
- else if (info instanceof Request) {
130
- const url = this.changeBaseUrl(info.url, conn);
131
- return new Request(url, info);
132
- }
133
- return info;
134
- }
135
- changeBaseUrl(pathname, conn) {
136
- const connBaseURL = conn.baseUrl;
137
- // if the connection has no baseUrl set, but the pathname is a valid URL, return it as is
138
- if (!connBaseURL && isValidURL(pathname)) {
139
- this.log.debug('Using given URL as is', { url: pathname });
140
- return pathname;
141
- }
142
- const connBaseURLObj = new URL(connBaseURL);
143
- let _pathname = pathname;
144
- if (isValidURL(pathname)) {
145
- const pathnameObj = new URL(pathname);
146
- _pathname = pathnameObj.pathname;
147
- }
148
- const newURL = new URL(_pathname, connBaseURLObj.origin);
149
- this.log.debug('Using baseURL from connection', { url: newURL.toString() });
150
- return newURL.toString();
151
- }
152
- async create(connName) {
153
- const cnxId = this.cfgReader.getConnectionID(connName);
154
- if (!cnxId) {
155
- return Promise.resolve(undefined);
156
- }
157
- const conn = await this.platformAPIClient.getStaticConnection(cnxId);
158
- let _fetch = this.traceFetch;
159
- if (!conn) {
160
- this.log.error('Connection not found - using default fetch', { 'connectionName': connName, 'connectionID': cnxId });
161
- return _fetch;
162
- }
163
- for (const cred of conn?.credentials ?? []) {
164
- switch (cred.authSchemeConfig.type) {
165
- case 'api-key': {
166
- const apiTokenResponse = await this.getToken(cred.credential.id);
167
- if (!apiTokenResponse?.token?.accessToken || !cred.authSchemeConfig.apiKey) {
168
- this.log.error('API Key credential is missing token or configuration', {
169
- connectionName: connName,
170
- credentialId: cred.credential.id,
171
- });
172
- continue;
173
- }
174
- _fetch = this.apiKeyFetcherStatic(apiTokenResponse.token.accessToken, cred.authSchemeConfig.apiKey, _fetch);
175
- break;
176
- }
177
- case 'basic-auth': {
178
- const basicTokenResponse = await this.getToken(cred.credential.id);
179
- if (!basicTokenResponse?.token?.accessToken) {
180
- this.log.error('Basic Auth credential is missing token', {
181
- connectionName: connName,
182
- credentialId: cred.credential.id,
183
- });
184
- continue;
185
- }
186
- _fetch = this.basicAuthFetcherStatic(basicTokenResponse.token.accessToken, _fetch);
187
- break;
188
- }
189
- case 'jwt-bearer': {
190
- const bearerTokenResponse = await this.getToken(cred.credential.id);
191
- if (!bearerTokenResponse?.token?.accessToken) {
192
- this.log.error('Bearer Token credential is missing token', {
193
- connectionName: connName,
194
- credentialId: cred.credential.id,
195
- });
196
- continue;
197
- }
198
- _fetch = this.bearerTokenFetcherStatic(bearerTokenResponse.token.accessToken, _fetch);
199
- break;
200
- }
201
- case 'oauth2': {
202
- if (!cred.credential?.id) {
203
- this.log.error('OAuth2 credential is missing credential ID', {
204
- connectionName: connName,
205
- credentialId: cred.credential.id,
206
- });
207
- continue;
208
- }
209
- _fetch = this.oauth2FetcherStatic(cred.credential.id, _fetch);
210
- break;
211
- }
212
- case 'oauth1': {
213
- const oauth1Metadata = await this.getOAuth1Metadata(cred.credential.id);
214
- if (!oauth1Metadata?.authorizationMetadata) {
215
- this.log.error('OAuth1 credential is missing metadata', {
216
- connectionName: connName,
217
- credentialId: cred.credential.id,
218
- });
219
- continue;
220
- }
221
- _fetch = this.oauth1FetcherStatic(oauth1Metadata, _fetch);
222
- break;
223
- }
224
- case 'certificate': {
225
- const mtlsData = await this.getRaw(cred.credential.id);
226
- if (!mtlsData?.credential?.data['cert'] || !mtlsData?.credential?.data['key']) {
227
- this.log.error('mTLS credential is missing cert or key data', {
228
- connectionName: connName,
229
- credentialId: cred.credential.id,
230
- });
231
- continue;
232
- }
233
- _fetch = this.mtlsFetcherStatic({
234
- cert: mtlsData.credential.data['cert'],
235
- key: mtlsData.credential.data['key'],
236
- ca: mtlsData.credential.data['ca'],
237
- }, _fetch);
238
- break;
239
- }
240
- }
241
- }
242
- const _fn = async (input, init) => {
243
- const _input = this.changeRequestInit(input, conn);
244
- return _fetch(_input, init);
245
- };
246
- return _fn;
247
- }
248
- apiKeyFetcherStatic(token, asc, fn) {
249
- const _fn = async (input, init) => {
250
- if (!token) {
251
- throw new Error('Token not found');
252
- }
253
- if (!asc) {
254
- throw new Error('API Key configuration not found');
255
- }
256
- if (!init) {
257
- init = {};
258
- }
259
- switch (asc.in) {
260
- case 'header':
261
- if (!init.headers) {
262
- init.headers = new Headers();
263
- }
264
- if (init.headers instanceof Headers) {
265
- init.headers.set(asc.name, token);
266
- }
267
- else if (init.headers instanceof Array) {
268
- init.headers.push([asc.name, token]);
269
- }
270
- else {
271
- init.headers = {
272
- ...init.headers,
273
- [asc.name]: token,
274
- };
275
- }
276
- break;
277
- case 'query':
278
- if (typeof input === 'string') {
279
- const _input = new URL(input);
280
- _input.searchParams.append(asc.name, token);
281
- input = _input.toString();
282
- }
283
- else if (input instanceof Request) {
284
- const _input = new URL(input.url);
285
- _input.searchParams.append(asc.name, token);
286
- input = new Request(_input.toString(), init);
287
- }
288
- else if (input instanceof URL) {
289
- input.searchParams.append(asc.name, token);
290
- }
291
- break;
292
- }
293
- return fn(input, init);
294
- };
295
- return _fn;
296
- }
297
- basicAuthFetcherStatic(token, fn) {
298
- const _fn = async (input, init) => {
299
- if (!init) {
300
- init = {};
301
- }
302
- if (!init.headers) {
303
- init.headers = new Headers();
304
- }
305
- if (init.headers instanceof Headers) {
306
- init.headers.set('Authorization', `Basic ${token}`);
307
- }
308
- else if (init.headers instanceof Array) {
309
- init.headers.push(['Authorization', `Basic ${token}`]);
310
- }
311
- else {
312
- init.headers = {
313
- ...init.headers,
314
- ['Authorization']: `Basic ${token}`,
315
- };
316
- }
317
- return fn(input, init);
318
- };
319
- return _fn;
320
- }
321
- bearerTokenFetcherStatic(token, fn) {
322
- const _fn = async (input, init) => {
323
- if (!init) {
324
- init = {};
325
- }
326
- if (!init.headers) {
327
- init.headers = new Headers();
328
- }
329
- if (init.headers instanceof Headers) {
330
- init.headers.set('Authorization', `Bearer ${token}`);
331
- }
332
- else if (init.headers instanceof Array) {
333
- init.headers.push(['Authorization', `Bearer ${token}`]);
334
- }
335
- else {
336
- init.headers = {
337
- ...init.headers,
338
- ['Authorization']: `Bearer ${token}`,
339
- };
340
- }
341
- return fn(input, init);
342
- };
343
- return _fn;
344
- }
345
- // getOauth2Token fetches an OAuth2 token, stores the result in a cache, and returns the token.
346
- // If forceRefresh is true, it will bypass the cache and fetch a new token then update the cache.
347
- async getOAuth2Token(credId, forceRefresh = false) {
348
- if (!forceRefresh && this.oauth2Cache.has(credId)) {
349
- // we do cache.has so it will be there, hence the ! operator
350
- const cached = this.oauth2Cache.get(credId);
351
- // check the expiry: if the oauth2 token has an expiry and it is going to expire
352
- // after the next 10 minutes, then simply return. Otherswise set forceRefresh to true,
353
- // get a new token and update the cache
354
- if (cached.expiry) {
355
- if (this.checkExpiry(cached.expiry)) {
356
- return Promise.resolve(cached);
357
- }
358
- else {
359
- forceRefresh = true;
360
- }
361
- }
362
- }
363
- let tokenResponse = await this.getToken(credId, forceRefresh);
364
- // we need to check the expiry of this new token in case it is going to expire soon.
365
- if (tokenResponse?.token?.expiry && !this.checkExpiry(tokenResponse.token.expiry)) {
366
- tokenResponse = await this.getToken(credId, true);
367
- }
368
- const newOauthTokenData = {
369
- token: tokenResponse.token?.accessToken || '',
370
- tokenType: tokenResponse.token?.tokenType,
371
- expiry: tokenResponse.token?.expiry,
372
- };
373
- this.oauth2Cache.set(credId, newOauthTokenData);
374
- return Promise.resolve(newOauthTokenData);
375
- }
376
- // Check if the given timestamp is expiring in the next 10 minutes.
377
- // Returns true if not expiring, false otherwise
378
- checkExpiry(ts) {
379
- return timestampMs(ts) > (Date.now() + 10 * 60 * 1000);
380
- }
381
- oauth2FetcherStatic(credId, fn) {
382
- const refreshFn = async (input, init, forceRefresh = false) => {
383
- const tokenResponse = await this.getOAuth2Token(credId, forceRefresh);
384
- const token = tokenResponse.token;
385
- const _tokenType = () => {
386
- const _tt = tokenResponse.tokenType?.toLowerCase();
387
- switch (_tt) {
388
- case 'bearer':
389
- return 'Bearer';
390
- case 'mac':
391
- return 'MAC';
392
- case 'basic':
393
- return 'Basic';
394
- default:
395
- return 'Bearer';
396
- }
397
- };
398
- if (!init) {
399
- init = {};
400
- }
401
- if (!init.headers) {
402
- init.headers = new Headers();
403
- }
404
- if (init.headers instanceof Headers) {
405
- init.headers.set('Authorization', `${_tokenType()} ${token}`);
406
- }
407
- else if (init.headers instanceof Array) {
408
- init.headers.push(['Authorization', `${_tokenType()} ${token}`]);
409
- }
410
- else {
411
- init.headers = {
412
- ...init.headers,
413
- ['Authorization']: `${_tokenType()} ${token}`,
414
- };
415
- }
416
- return fn(input, init);
417
- };
418
- const _fn = async (input, init) => {
419
- const resp = await refreshFn(input, init);
420
- if (resp.status === 401 || resp.status === 403) {
421
- this.log.debug('Received unauthorized response, attempting to refresh token', {
422
- url: input,
423
- status: resp.status,
424
- });
425
- return refreshFn(input, init, true);
426
- }
427
- return resp;
428
- };
429
- return _fn;
430
- }
431
- oauth1FetcherStatic(metadata, fn) {
432
- const _fn = async (input, init) => {
433
- const authParams = new URLSearchParams(metadata.authorizationMetadata?.authorizationParams);
434
- if (!metadata.authorizationMetadata) {
435
- throw new Error('OAuth1 metadata not found');
436
- }
437
- const oauth = new OAuth({
438
- consumer: {
439
- key: metadata.authorizationMetadata.consumerKey,
440
- secret: metadata.authorizationMetadata.consumerSecret,
441
- },
442
- signature_method: 'HMAC-SHA256',
443
- hash_function: (baseString, key) => createHmac('sha256', key).update(baseString).digest('base64'),
444
- realm: authParams.get('realm') || undefined,
445
- });
446
- let url;
447
- if (input instanceof Request) {
448
- url = input.url;
449
- }
450
- else if (input instanceof URL) {
451
- url = input.toString();
452
- }
453
- else if (typeof input === 'string') {
454
- url = input;
455
- }
456
- else {
457
- throw new Error('Invalid input type for OAuth1 fetcher');
458
- }
459
- const header = oauth.toHeader(oauth.authorize({
460
- url: url,
461
- method: init?.method || 'GET',
462
- }, {
463
- key: metadata.authorizationMetadata?.oauthToken,
464
- secret: metadata.authorizationMetadata?.oauthTokenSecret,
465
- }));
466
- const authHeader = header.Authorization;
467
- if (!init) {
468
- init = {};
469
- }
470
- if (!init.headers) {
471
- init.headers = new Headers();
472
- }
473
- if (init.headers instanceof Headers) {
474
- init.headers.set('Authorization', authHeader);
475
- }
476
- else if (init.headers instanceof Array) {
477
- init.headers.push(['Authorization', authHeader]);
478
- }
479
- else {
480
- init.headers = {
481
- ...init.headers,
482
- ['Authorization']: authHeader,
483
- };
484
- }
485
- return fn(input, init);
486
- };
487
- return _fn;
488
- }
489
- mtlsFetcherStatic(mtlsdata, fn) {
490
- const _fn = async (input, init) => {
491
- const cert = new TextDecoder().decode(mtlsdata.cert);
492
- const key = new TextDecoder().decode(mtlsdata.key);
493
- const caCerts = new TextDecoder().decode(mtlsdata.ca ?? new Uint8Array());
494
- const httpClient = Deno.createHttpClient({
495
- cert,
496
- key,
497
- caCerts: caCerts ? [caCerts] : [],
498
- });
499
- return fn(input, {
500
- ...init,
501
- client: httpClient,
502
- });
503
- };
504
- return _fn;
505
- }
506
- createDynamic(templateName) {
507
- const template = this.cfgReader.getTemplateID(templateName);
508
- if (!template) {
509
- return Promise.resolve(undefined);
510
- }
511
- const _fn = async (activation, input, init) => {
512
- const conn = await this.platformAPIClient.getActivationConnection(template, activation.id);
513
- if (!conn) {
514
- return this.defaultDynamic('Connection not found for user, using default fetch', {
515
- templateName: templateName,
516
- userId: activation.user.id,
517
- activationId: activation.id,
518
- })(activation, input, init);
519
- }
520
- const _input = this.changeRequestInit(input, conn);
521
- let _fetch = this.traceFetch;
522
- conn.credentials.forEach((cred) => {
523
- switch (cred.authSchemeConfig.type) {
524
- case 'api-key':
525
- _fetch = this.apiKeyFetcher(cred, _fetch);
526
- break;
527
- case 'basic-auth':
528
- _fetch = this.basicAuthFetcher(cred, _fetch);
529
- break;
530
- case 'jwt-bearer':
531
- _fetch = this.bearerTokenFetcher(cred, _fetch);
532
- break;
533
- case 'oauth2':
534
- _fetch = this.oauth2Fetcher(cred, _fetch);
535
- break;
536
- case 'certificate':
537
- _fetch = this.mtlsFetcher(cred, _fetch);
538
- break;
539
- default:
540
- break;
541
- }
542
- });
543
- return _fetch(_input, init);
544
- };
545
- return Promise.resolve(_fn);
546
- }
547
- traceFetch(input, init) {
548
- return this.tracer.startActiveSpan('fetch', async (span) => {
549
- const response = await globalThis.fetch(input, init);
550
- let url = new URL('http://localhost');
551
- try {
552
- url = new URL(input.toString());
553
- }
554
- catch (error) {
555
- this.log.error('Error parsing URL when tracing request', { error });
556
- }
557
- const method = input instanceof Request ? input.method : 'GET';
558
- span.setAttributes({
559
- // Error attributes
560
- 'error.type': response.status >= 400 ? 'HTTP_ERROR' : undefined,
561
- // HTTP request attributes
562
- 'http.request.method': method,
563
- 'http.response.status_code': response.status,
564
- // Server attributes
565
- 'server.address': url.hostname,
566
- 'server.port': url.port || (url.protocol === 'https:' ? '443' : '80'),
567
- // URL attributes
568
- 'url.full': url.toString(),
569
- 'url.path': url.pathname,
570
- 'url.query': url.search,
571
- 'url.scheme': url.protocol.replace(':', ''),
572
- });
573
- span.end();
574
- return response;
575
- });
576
- }
577
- credentials() {
578
- return {
579
- getRaw: this.getRawByName.bind(this),
580
- getAccessToken: this.getTokenByName.bind(this),
581
- getOAuth1Metadata: this.getOAuth1Metadata.bind(this),
582
- };
583
- }
584
- baseUrlFetcher(templateName) {
585
- let isDynamic = false;
586
- let cnxId = this.cfgReader.getConnectionID(templateName);
587
- if (!cnxId) {
588
- this.log.debug('Connection not found in config, could be a dynamic connection', {
589
- connectionName: templateName,
590
- });
591
- isDynamic = true;
592
- cnxId = this.cfgReader.getTemplateID(templateName);
593
- }
594
- return async (activationId) => {
595
- if (!activationId) {
596
- throw new Error(`Activation ID is required for base URL fetching for connection ${templateName}`);
597
- }
598
- if (isDynamic) {
599
- const dynamicConn = await this.platformAPIClient.getActivationConnection(cnxId, activationId);
600
- if (!dynamicConn) {
601
- throw new Error(`Dynamic connection ${templateName} not found for activation ${activationId}`);
602
- }
603
- return dynamicConn.baseUrl;
604
- }
605
- const staticConn = await this.platformAPIClient.getStaticConnection(cnxId);
606
- if (!staticConn) {
607
- throw new Error(`Static connection ${templateName} not found`);
608
- }
609
- return staticConn.baseUrl;
610
- };
611
- }
612
- async getTokenByName(name, forceRefresh = false, activationId) {
613
- const credId = await this.getCredentialIDFromName(name, activationId);
614
- const token = await this.getToken(credId, forceRefresh);
615
- if (!token?.token) {
616
- throw new Error(`Token not found for connection ${name} with credential ID ${credId}`);
617
- }
618
- return {
619
- accessToken: token.token.accessToken,
620
- tokenType: token.token.tokenType,
621
- expiry: token.token.expiry
622
- ? new Date(Number(token.token.expiry.seconds) * 1000)
623
- : undefined,
624
- };
625
- }
626
- async getRawByName(name, activationId) {
627
- const credId = await this.getCredentialIDFromName(name, activationId);
628
- const raw = await this.getRaw(credId);
629
- if (!raw) {
630
- throw new Error(`Raw data not found for connection ${name} with credential ID ${credId}`);
631
- }
632
- const buffer = raw?.credential?.data['raw'] ?? undefined;
633
- if (!buffer) {
634
- throw new Error(`Credential ${raw?.credential?.id} is missing raw data, please contact your administrator`);
635
- }
636
- return Promise.resolve(buffer);
637
- }
638
- async getCredentialIDFromName(name, activationId) {
639
- // fin connection config from versori file
640
- const conn = this.cfgReader.getCnxMapping(name);
641
- if (!conn) {
642
- return '';
643
- }
644
- // if connection is dynamic try and load the activation
645
- if (conn.dynamic) {
646
- if (!activationId) {
647
- throw new Error(`Connection ${name} is dynamic, but no activation ID was found on the context`);
648
- }
649
- if (!conn.templateId) {
650
- throw new Error(`Connection ${name} is dynamic, but no template ID was found on the config`);
651
- }
652
- const dynamicConn = await this.platformAPIClient.getActivationConnection(conn.templateId, activationId);
653
- if (!dynamicConn) {
654
- throw new Error(`Connection ${name} not found`);
655
- }
656
- return dynamicConn.credentials[0].credential.id;
657
- }
658
- // connection is not dynamic try and load static connection
659
- if (!conn.connId) {
660
- throw new Error(`Connection ${name} is static, but no connection ID was found on the config`);
661
- }
662
- const staticConn = await this.platformAPIClient.getStaticConnection(conn.connId);
663
- if (!conn) {
664
- throw new Error(`Connection ${name} not found`);
665
- }
666
- if (!staticConn?.credentials[0]?.credential?.id) {
667
- throw new Error(`Connection ${name}/${conn.connId} has no credentials defined on it`);
668
- }
669
- return staticConn.credentials[0].credential.id;
670
- }
671
- apiKeyFetcher(cred, fn) {
672
- const _fn = async (input, init) => {
673
- const tokenResponse = await this.getToken(cred.credential.id);
674
- const token = tokenResponse.token?.accessToken;
675
- const asc = cred.authSchemeConfig.apiKey;
676
- if (!token) {
677
- throw new Error('Token not found');
678
- }
679
- if (!asc) {
680
- throw new Error('API Key configuration not found');
681
- }
682
- if (!init) {
683
- init = {};
684
- }
685
- switch (asc.in) {
686
- case 'header':
687
- if (!init.headers) {
688
- init.headers = new Headers();
689
- }
690
- if (init.headers instanceof Headers) {
691
- init.headers.set(asc.name, token);
692
- }
693
- else if (init.headers instanceof Array) {
694
- init.headers.push([asc.name, token]);
695
- }
696
- else {
697
- init.headers = {
698
- ...init.headers,
699
- [asc.name]: token,
700
- };
701
- }
702
- break;
703
- case 'query':
704
- if (typeof input === 'string') {
705
- input += `?${asc.name}=${token}`;
706
- }
707
- else if (input instanceof Request) {
708
- input = new Request(input.url + `?${asc.name}=${token}`, init);
709
- }
710
- else if (input instanceof URL) {
711
- input.searchParams.append(asc.name, token);
712
- }
713
- break;
714
- }
715
- return fn(input, init);
716
- };
717
- return _fn;
718
- }
719
- basicAuthFetcher(cred, fn) {
720
- const _fn = async (input, init) => {
721
- const tokenResponse = await this.getToken(cred.credential.id);
722
- const token = tokenResponse.token?.accessToken;
723
- if (!token) {
724
- throw new Error('Token not found');
725
- }
726
- if (!init) {
727
- init = {};
728
- }
729
- if (!init.headers) {
730
- init.headers = new Headers();
731
- }
732
- if (init.headers instanceof Headers) {
733
- init.headers.set('Authorization', `Basic ${token}`);
734
- }
735
- else if (init.headers instanceof Array) {
736
- init.headers.push(['Authorization', `Basic ${token}`]);
737
- }
738
- else {
739
- init.headers = {
740
- ...init.headers,
741
- ['Authorization']: `Basic ${token}`,
742
- };
743
- }
744
- return fn(input, init);
745
- };
746
- return _fn;
747
- }
748
- // TODO: need to make the prefix and header name configurable from authschemeconfig
749
- bearerTokenFetcher(cred, fn) {
750
- const _fn = async (input, init) => {
751
- const tokenResponse = await this.getToken(cred.credential.id);
752
- const token = tokenResponse.token?.accessToken;
753
- if (!token) {
754
- throw new Error('Token not found');
755
- }
756
- if (!init) {
757
- init = {};
758
- }
759
- if (!init.headers) {
760
- init.headers = new Headers();
761
- }
762
- if (init.headers instanceof Headers) {
763
- init.headers.set('Authorization', `Bearer ${token}`);
764
- }
765
- else if (init.headers instanceof Array) {
766
- init.headers.push(['Authorization', `Bearer ${token}`]);
767
- }
768
- else {
769
- init.headers = {
770
- ...init.headers,
771
- ['Authorization']: `Bearer ${token}`,
772
- };
773
- }
774
- return fn(input, init);
775
- };
776
- return _fn;
777
- }
778
- oauth2Fetcher(cred, fn) {
779
- const refreshFn = async (input, init, forceRefresh = false) => {
780
- const tokenResponse = await this.getToken(cred.credential.id, forceRefresh);
781
- const token = tokenResponse.token?.accessToken;
782
- const tokenType = tokenResponse.token?.tokenType;
783
- if (!token) {
784
- throw new Error('Token not found');
785
- }
786
- const _tokenType = () => {
787
- const _tt = tokenType?.toLowerCase();
788
- switch (_tt) {
789
- case 'bearer':
790
- return 'Bearer';
791
- case 'mac':
792
- return 'MAC';
793
- case 'basic':
794
- return 'Basic';
795
- default:
796
- return 'Bearer';
797
- }
798
- };
799
- if (!init) {
800
- init = {};
801
- }
802
- if (!init.headers) {
803
- init.headers = new Headers();
804
- }
805
- if (init.headers instanceof Headers) {
806
- init.headers.set('Authorization', `${_tokenType()} ${token}`);
807
- }
808
- else if (init.headers instanceof Array) {
809
- init.headers.push(['Authorization', `${_tokenType()} ${token}`]);
810
- }
811
- else {
812
- init.headers = {
813
- ...init.headers,
814
- ['Authorization']: `${_tokenType()} ${token}`,
815
- };
816
- }
817
- return fn(input, init);
818
- };
819
- const _fn = async (input, init) => {
820
- const resp = await refreshFn(input, init);
821
- if (resp.status === 401) {
822
- this.log.debug('Received 401 Unauthorized response, attempting refresh', {
823
- url: input,
824
- status: resp.status,
825
- });
826
- // TODO: attempt refresh until precondition failed??
827
- return refreshFn(input, init, true);
828
- }
829
- return Promise.resolve(resp);
830
- };
831
- return _fn;
832
- }
833
- oauth1Fetcher(cred, fn) {
834
- const _fn = async (input, init) => {
835
- const metadata = await this.getOAuth1Metadata(cred.credential.id);
836
- const authParams = new URLSearchParams(metadata.authorizationMetadata?.authorizationParams);
837
- if (!metadata.authorizationMetadata) {
838
- throw new Error('OAuth1 metadata not found');
839
- }
840
- const oauth = new OAuth({
841
- consumer: {
842
- key: metadata.authorizationMetadata.consumerKey,
843
- secret: metadata.authorizationMetadata.consumerSecret,
844
- },
845
- signature_method: 'HMAC-SHA256',
846
- hash_function: (baseString, key) => createHmac('sha256', key).update(baseString).digest('base64'),
847
- realm: authParams.get('realm') || undefined,
848
- });
849
- let url;
850
- if (input instanceof Request) {
851
- url = input.url;
852
- }
853
- else if (input instanceof URL) {
854
- url = input.toString();
855
- }
856
- else if (typeof input === 'string') {
857
- url = input;
858
- }
859
- else {
860
- throw new Error('Invalid input type for OAuth1 fetcher');
861
- }
862
- const header = oauth.toHeader(oauth.authorize({
863
- url: url,
864
- method: init?.method || 'GET',
865
- }, {
866
- key: metadata.authorizationMetadata?.oauthToken,
867
- secret: metadata.authorizationMetadata?.oauthTokenSecret,
868
- }));
869
- const authHeader = header.Authorization;
870
- if (!init) {
871
- init = {};
872
- }
873
- if (!init.headers) {
874
- init.headers = new Headers();
875
- }
876
- if (init.headers instanceof Headers) {
877
- init.headers.set('Authorization', authHeader);
878
- }
879
- else if (init.headers instanceof Array) {
880
- init.headers.push(['Authorization', authHeader]);
881
- }
882
- else {
883
- init.headers = {
884
- ...init.headers,
885
- ['Authorization']: authHeader,
886
- };
887
- }
888
- return fn(input, init);
889
- };
890
- return _fn;
891
- }
892
- mtlsFetcher(cred, fn) {
893
- const _fn = async (input, init) => {
894
- const raw = await this.getRaw(cred.credential.id);
895
- if (!raw?.credential?.data) {
896
- throw new Error(`Cannot fetch MTLS credentials for connection ${cred.credential.name}, no data found`);
897
- }
898
- const cert = new TextDecoder().decode(raw.credential.data['certificate']);
899
- const key = new TextDecoder().decode(raw.credential.data['key']);
900
- const caCerts = new TextDecoder().decode(raw.credential.data['ca'] || '');
901
- const httpClient = Deno.createHttpClient({
902
- cert,
903
- key,
904
- caCerts: caCerts ? [caCerts] : [],
905
- });
906
- return fn(input, {
907
- ...init,
908
- client: httpClient,
909
- });
910
- };
911
- return _fn;
912
- }
913
- async getToken(id, forceRefresh = false) {
914
- try {
915
- return await this.tokenClient.getToken(id, forceRefresh);
916
- }
917
- catch (error) {
918
- this.log.error('unable to get token credential', { error });
919
- if (error instanceof ConnectError) {
920
- if (error.rawMessage.includes('connection error received: not a result of an error') &&
921
- error.code === Code.Internal) {
922
- this.log.info('Connection error received, attempting to reconnect');
923
- this.tokenClient = new VersoriCredentialClient(this.credsBaseURL);
924
- return await this.tokenClient.getToken(id);
925
- }
926
- throw error;
927
- }
928
- throw error;
929
- }
930
- }
931
- async getRaw(id) {
932
- try {
933
- return await this.tokenClient.getRaw(id);
934
- }
935
- catch (error) {
936
- this.log.error('unable to get raw credential', { error });
937
- if (error instanceof ConnectError) {
938
- if (error.rawMessage.includes('connection error received: not a result of an error') &&
939
- error.code === Code.Internal) {
940
- this.log.info('Connection error received, attempting to reconnect');
941
- this.tokenClient = new VersoriCredentialClient(this.credsBaseURL);
942
- return await this.tokenClient.getRaw(id);
943
- }
944
- throw error;
945
- }
946
- throw error;
947
- }
948
- }
949
- async getOAuth1Metadata(id) {
950
- try {
951
- return await this.tokenClient.getOAuth1Metadata(id);
952
- }
953
- catch (error) {
954
- this.log.error('unable to get OAuth1 metadata', { error });
955
- if (error instanceof ConnectError) {
956
- if (error.rawMessage.includes('connection error received: not a result of an error') &&
957
- error.code === Code.Internal) {
958
- this.log.info('Connection error received, attempting to reconnect');
959
- this.tokenClient = new VersoriCredentialClient(this.credsBaseURL);
960
- return await this.tokenClient.getOAuth1Metadata(id);
961
- }
962
- throw error;
963
- }
964
- throw error;
965
- }
966
- }
967
- }