@blokjs/runner 0.2.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.
Files changed (307) hide show
  1. package/dist/Blok.d.ts +19 -0
  2. package/dist/Blok.js +184 -0
  3. package/dist/Blok.js.map +1 -0
  4. package/dist/BlokResponse.d.ts +16 -0
  5. package/dist/BlokResponse.js +28 -0
  6. package/dist/BlokResponse.js.map +1 -0
  7. package/dist/Configuration.d.ts +37 -0
  8. package/dist/Configuration.js +248 -0
  9. package/dist/Configuration.js.map +1 -0
  10. package/dist/ConfigurationResolver.d.ts +7 -0
  11. package/dist/ConfigurationResolver.js +15 -0
  12. package/dist/ConfigurationResolver.js.map +1 -0
  13. package/dist/DefaultLogger.d.ts +65 -0
  14. package/dist/DefaultLogger.js +101 -0
  15. package/dist/DefaultLogger.js.map +1 -0
  16. package/dist/LocalStorage.d.ts +7 -0
  17. package/dist/LocalStorage.js +56 -0
  18. package/dist/LocalStorage.js.map +1 -0
  19. package/dist/MemoryUsage.d.ts +22 -0
  20. package/dist/MemoryUsage.js +83 -0
  21. package/dist/MemoryUsage.js.map +1 -0
  22. package/dist/NodeMap.d.ts +7 -0
  23. package/dist/NodeMap.js +13 -0
  24. package/dist/NodeMap.js.map +1 -0
  25. package/dist/ResolverBase.d.ts +8 -0
  26. package/dist/ResolverBase.js +18 -0
  27. package/dist/ResolverBase.js.map +1 -0
  28. package/dist/Runner.d.ts +25 -0
  29. package/dist/Runner.js +32 -0
  30. package/dist/Runner.js.map +1 -0
  31. package/dist/RunnerNode.d.ts +9 -0
  32. package/dist/RunnerNode.js +8 -0
  33. package/dist/RunnerNode.js.map +1 -0
  34. package/dist/RunnerNodeBase.d.ts +4 -0
  35. package/dist/RunnerNodeBase.js +3 -0
  36. package/dist/RunnerNodeBase.js.map +1 -0
  37. package/dist/RunnerSteps.d.ts +14 -0
  38. package/dist/RunnerSteps.js +110 -0
  39. package/dist/RunnerSteps.js.map +1 -0
  40. package/dist/RuntimeAdapterNode.d.ts +19 -0
  41. package/dist/RuntimeAdapterNode.js +87 -0
  42. package/dist/RuntimeAdapterNode.js.map +1 -0
  43. package/dist/RuntimeRegistry.d.ts +61 -0
  44. package/dist/RuntimeRegistry.js +87 -0
  45. package/dist/RuntimeRegistry.js.map +1 -0
  46. package/dist/TriggerBase.d.ts +119 -0
  47. package/dist/TriggerBase.js +413 -0
  48. package/dist/TriggerBase.js.map +1 -0
  49. package/dist/adapters/BunRuntimeAdapter.d.ts +38 -0
  50. package/dist/adapters/BunRuntimeAdapter.js +169 -0
  51. package/dist/adapters/BunRuntimeAdapter.js.map +1 -0
  52. package/dist/adapters/DockerRuntimeAdapter.d.ts +85 -0
  53. package/dist/adapters/DockerRuntimeAdapter.js +298 -0
  54. package/dist/adapters/DockerRuntimeAdapter.js.map +1 -0
  55. package/dist/adapters/HttpRuntimeAdapter.d.ts +58 -0
  56. package/dist/adapters/HttpRuntimeAdapter.js +152 -0
  57. package/dist/adapters/HttpRuntimeAdapter.js.map +1 -0
  58. package/dist/adapters/NodeJsRuntimeAdapter.d.ts +23 -0
  59. package/dist/adapters/NodeJsRuntimeAdapter.js +67 -0
  60. package/dist/adapters/NodeJsRuntimeAdapter.js.map +1 -0
  61. package/dist/adapters/RuntimeAdapter.d.ts +42 -0
  62. package/dist/adapters/RuntimeAdapter.js +2 -0
  63. package/dist/adapters/RuntimeAdapter.js.map +1 -0
  64. package/dist/adapters/WasmRuntimeAdapter.d.ts +69 -0
  65. package/dist/adapters/WasmRuntimeAdapter.js +279 -0
  66. package/dist/adapters/WasmRuntimeAdapter.js.map +1 -0
  67. package/dist/cache/NodeResultCache.d.ts +286 -0
  68. package/dist/cache/NodeResultCache.js +499 -0
  69. package/dist/cache/NodeResultCache.js.map +1 -0
  70. package/dist/cache/index.d.ts +1 -0
  71. package/dist/cache/index.js +2 -0
  72. package/dist/cache/index.js.map +1 -0
  73. package/dist/cost/CostEstimator.d.ts +57 -0
  74. package/dist/cost/CostEstimator.js +171 -0
  75. package/dist/cost/CostEstimator.js.map +1 -0
  76. package/dist/cost/index.d.ts +4 -0
  77. package/dist/cost/index.js +3 -0
  78. package/dist/cost/index.js.map +1 -0
  79. package/dist/cost/pricing.d.ts +24 -0
  80. package/dist/cost/pricing.js +169 -0
  81. package/dist/cost/pricing.js.map +1 -0
  82. package/dist/defineNode.d.ts +155 -0
  83. package/dist/defineNode.js +191 -0
  84. package/dist/defineNode.js.map +1 -0
  85. package/dist/graphql/GraphQLSchemaGenerator.d.ts +129 -0
  86. package/dist/graphql/GraphQLSchemaGenerator.js +425 -0
  87. package/dist/graphql/GraphQLSchemaGenerator.js.map +1 -0
  88. package/dist/hmr/FileWatcher.d.ts +62 -0
  89. package/dist/hmr/FileWatcher.js +185 -0
  90. package/dist/hmr/FileWatcher.js.map +1 -0
  91. package/dist/hmr/HmrDevConsole.d.ts +13 -0
  92. package/dist/hmr/HmrDevConsole.js +46 -0
  93. package/dist/hmr/HmrDevConsole.js.map +1 -0
  94. package/dist/hmr/HotReloadManager.d.ts +84 -0
  95. package/dist/hmr/HotReloadManager.js +195 -0
  96. package/dist/hmr/HotReloadManager.js.map +1 -0
  97. package/dist/hmr/index.d.ts +39 -0
  98. package/dist/hmr/index.js +38 -0
  99. package/dist/hmr/index.js.map +1 -0
  100. package/dist/index.d.ts +107 -0
  101. package/dist/index.js +107 -0
  102. package/dist/index.js.map +1 -0
  103. package/dist/integrations/APMIntegration.d.ts +141 -0
  104. package/dist/integrations/APMIntegration.js +212 -0
  105. package/dist/integrations/APMIntegration.js.map +1 -0
  106. package/dist/integrations/AzureMonitorIntegration.d.ts +118 -0
  107. package/dist/integrations/AzureMonitorIntegration.js +254 -0
  108. package/dist/integrations/AzureMonitorIntegration.js.map +1 -0
  109. package/dist/integrations/CloudWatchIntegration.d.ts +135 -0
  110. package/dist/integrations/CloudWatchIntegration.js +293 -0
  111. package/dist/integrations/CloudWatchIntegration.js.map +1 -0
  112. package/dist/integrations/SentryIntegration.d.ts +153 -0
  113. package/dist/integrations/SentryIntegration.js +200 -0
  114. package/dist/integrations/SentryIntegration.js.map +1 -0
  115. package/dist/integrations/index.d.ts +19 -0
  116. package/dist/integrations/index.js +16 -0
  117. package/dist/integrations/index.js.map +1 -0
  118. package/dist/marketplace/RuntimeAutoScaler.d.ts +148 -0
  119. package/dist/marketplace/RuntimeAutoScaler.js +366 -0
  120. package/dist/marketplace/RuntimeAutoScaler.js.map +1 -0
  121. package/dist/marketplace/RuntimeCatalog.d.ts +174 -0
  122. package/dist/marketplace/RuntimeCatalog.js +339 -0
  123. package/dist/marketplace/RuntimeCatalog.js.map +1 -0
  124. package/dist/marketplace/RuntimeDiscovery.d.ts +86 -0
  125. package/dist/marketplace/RuntimeDiscovery.js +219 -0
  126. package/dist/marketplace/RuntimeDiscovery.js.map +1 -0
  127. package/dist/marketplace/RuntimeHealthMonitor.d.ts +100 -0
  128. package/dist/marketplace/RuntimeHealthMonitor.js +241 -0
  129. package/dist/marketplace/RuntimeHealthMonitor.js.map +1 -0
  130. package/dist/marketplace/RuntimeMetricsDashboard.d.ts +113 -0
  131. package/dist/marketplace/RuntimeMetricsDashboard.js +293 -0
  132. package/dist/marketplace/RuntimeMetricsDashboard.js.map +1 -0
  133. package/dist/monitoring/CircuitBreaker.d.ts +107 -0
  134. package/dist/monitoring/CircuitBreaker.js +238 -0
  135. package/dist/monitoring/CircuitBreaker.js.map +1 -0
  136. package/dist/monitoring/DistributedTracer.d.ts +125 -0
  137. package/dist/monitoring/DistributedTracer.js +230 -0
  138. package/dist/monitoring/DistributedTracer.js.map +1 -0
  139. package/dist/monitoring/HealthCheck.d.ts +54 -0
  140. package/dist/monitoring/HealthCheck.js +102 -0
  141. package/dist/monitoring/HealthCheck.js.map +1 -0
  142. package/dist/monitoring/PerformanceProfiler.d.ts +63 -0
  143. package/dist/monitoring/PerformanceProfiler.js +229 -0
  144. package/dist/monitoring/PerformanceProfiler.js.map +1 -0
  145. package/dist/monitoring/PrometheusBootstrap.d.ts +30 -0
  146. package/dist/monitoring/PrometheusBootstrap.js +71 -0
  147. package/dist/monitoring/PrometheusBootstrap.js.map +1 -0
  148. package/dist/monitoring/PrometheusMetricsBridge.d.ts +60 -0
  149. package/dist/monitoring/PrometheusMetricsBridge.js +216 -0
  150. package/dist/monitoring/PrometheusMetricsBridge.js.map +1 -0
  151. package/dist/monitoring/RateLimiter.d.ts +58 -0
  152. package/dist/monitoring/RateLimiter.js +128 -0
  153. package/dist/monitoring/RateLimiter.js.map +1 -0
  154. package/dist/monitoring/StructuredLogger.d.ts +131 -0
  155. package/dist/monitoring/StructuredLogger.js +207 -0
  156. package/dist/monitoring/StructuredLogger.js.map +1 -0
  157. package/dist/monitoring/TracingBootstrap.d.ts +69 -0
  158. package/dist/monitoring/TracingBootstrap.js +129 -0
  159. package/dist/monitoring/TracingBootstrap.js.map +1 -0
  160. package/dist/monitoring/TriggerMetricsCollector.d.ts +94 -0
  161. package/dist/monitoring/TriggerMetricsCollector.js +174 -0
  162. package/dist/monitoring/TriggerMetricsCollector.js.map +1 -0
  163. package/dist/monitoring/index.d.ts +9 -0
  164. package/dist/monitoring/index.js +10 -0
  165. package/dist/monitoring/index.js.map +1 -0
  166. package/dist/openapi/OpenAPIGenerator.d.ts +192 -0
  167. package/dist/openapi/OpenAPIGenerator.js +373 -0
  168. package/dist/openapi/OpenAPIGenerator.js.map +1 -0
  169. package/dist/openapi/index.d.ts +20 -0
  170. package/dist/openapi/index.js +20 -0
  171. package/dist/openapi/index.js.map +1 -0
  172. package/dist/security/ABAC.d.ts +224 -0
  173. package/dist/security/ABAC.js +380 -0
  174. package/dist/security/ABAC.js.map +1 -0
  175. package/dist/security/AuditLogger.d.ts +242 -0
  176. package/dist/security/AuditLogger.js +317 -0
  177. package/dist/security/AuditLogger.js.map +1 -0
  178. package/dist/security/AuthMiddleware.d.ts +163 -0
  179. package/dist/security/AuthMiddleware.js +274 -0
  180. package/dist/security/AuthMiddleware.js.map +1 -0
  181. package/dist/security/EncryptionAtRest.d.ts +206 -0
  182. package/dist/security/EncryptionAtRest.js +236 -0
  183. package/dist/security/EncryptionAtRest.js.map +1 -0
  184. package/dist/security/OAuthProvider.d.ts +334 -0
  185. package/dist/security/OAuthProvider.js +719 -0
  186. package/dist/security/OAuthProvider.js.map +1 -0
  187. package/dist/security/PIIDetector.d.ts +233 -0
  188. package/dist/security/PIIDetector.js +354 -0
  189. package/dist/security/PIIDetector.js.map +1 -0
  190. package/dist/security/RBAC.d.ts +143 -0
  191. package/dist/security/RBAC.js +285 -0
  192. package/dist/security/RBAC.js.map +1 -0
  193. package/dist/security/SecretManager.d.ts +652 -0
  194. package/dist/security/SecretManager.js +1146 -0
  195. package/dist/security/SecretManager.js.map +1 -0
  196. package/dist/security/TLSConfig.d.ts +305 -0
  197. package/dist/security/TLSConfig.js +550 -0
  198. package/dist/security/TLSConfig.js.map +1 -0
  199. package/dist/security/index.d.ts +79 -0
  200. package/dist/security/index.js +80 -0
  201. package/dist/security/index.js.map +1 -0
  202. package/dist/testing/TestHarness.d.ts +189 -0
  203. package/dist/testing/TestHarness.js +272 -0
  204. package/dist/testing/TestHarness.js.map +1 -0
  205. package/dist/testing/TestLogger.d.ts +103 -0
  206. package/dist/testing/TestLogger.js +153 -0
  207. package/dist/testing/TestLogger.js.map +1 -0
  208. package/dist/testing/WorkflowTestRunner.d.ts +172 -0
  209. package/dist/testing/WorkflowTestRunner.js +355 -0
  210. package/dist/testing/WorkflowTestRunner.js.map +1 -0
  211. package/dist/testing/index.d.ts +21 -0
  212. package/dist/testing/index.js +22 -0
  213. package/dist/testing/index.js.map +1 -0
  214. package/dist/tracing/InMemoryRunStore.d.ts +44 -0
  215. package/dist/tracing/InMemoryRunStore.js +341 -0
  216. package/dist/tracing/InMemoryRunStore.js.map +1 -0
  217. package/dist/tracing/PostgresRunStore.d.ts +82 -0
  218. package/dist/tracing/PostgresRunStore.js +640 -0
  219. package/dist/tracing/PostgresRunStore.js.map +1 -0
  220. package/dist/tracing/RunStore.d.ts +38 -0
  221. package/dist/tracing/RunStore.js +2 -0
  222. package/dist/tracing/RunStore.js.map +1 -0
  223. package/dist/tracing/RunTracker.d.ts +75 -0
  224. package/dist/tracing/RunTracker.js +374 -0
  225. package/dist/tracing/RunTracker.js.map +1 -0
  226. package/dist/tracing/SqliteRunStore.d.ts +53 -0
  227. package/dist/tracing/SqliteRunStore.js +703 -0
  228. package/dist/tracing/SqliteRunStore.js.map +1 -0
  229. package/dist/tracing/TraceRouter.d.ts +47 -0
  230. package/dist/tracing/TraceRouter.js +904 -0
  231. package/dist/tracing/TraceRouter.js.map +1 -0
  232. package/dist/tracing/TracingLogger.d.ts +21 -0
  233. package/dist/tracing/TracingLogger.js +62 -0
  234. package/dist/tracing/TracingLogger.js.map +1 -0
  235. package/dist/tracing/createStore.d.ts +30 -0
  236. package/dist/tracing/createStore.js +75 -0
  237. package/dist/tracing/createStore.js.map +1 -0
  238. package/dist/tracing/index.d.ts +13 -0
  239. package/dist/tracing/index.js +9 -0
  240. package/dist/tracing/index.js.map +1 -0
  241. package/dist/tracing/sanitize.d.ts +7 -0
  242. package/dist/tracing/sanitize.js +95 -0
  243. package/dist/tracing/sanitize.js.map +1 -0
  244. package/dist/tracing/types.d.ts +178 -0
  245. package/dist/tracing/types.js +3 -0
  246. package/dist/tracing/types.js.map +1 -0
  247. package/dist/types/Average.d.ts +11 -0
  248. package/dist/types/Average.js +2 -0
  249. package/dist/types/Average.js.map +1 -0
  250. package/dist/types/Condition.d.ts +8 -0
  251. package/dist/types/Condition.js +2 -0
  252. package/dist/types/Condition.js.map +1 -0
  253. package/dist/types/Conditions.d.ts +5 -0
  254. package/dist/types/Conditions.js +2 -0
  255. package/dist/types/Conditions.js.map +1 -0
  256. package/dist/types/Config.d.ts +12 -0
  257. package/dist/types/Config.js +2 -0
  258. package/dist/types/Config.js.map +1 -0
  259. package/dist/types/Flow.d.ts +5 -0
  260. package/dist/types/Flow.js +2 -0
  261. package/dist/types/Flow.js.map +1 -0
  262. package/dist/types/GlobalOptions.d.ts +11 -0
  263. package/dist/types/GlobalOptions.js +2 -0
  264. package/dist/types/GlobalOptions.js.map +1 -0
  265. package/dist/types/Inputs.d.ts +5 -0
  266. package/dist/types/Inputs.js +2 -0
  267. package/dist/types/Inputs.js.map +1 -0
  268. package/dist/types/JsonLikeObject.d.ts +3 -0
  269. package/dist/types/JsonLikeObject.js +2 -0
  270. package/dist/types/JsonLikeObject.js.map +1 -0
  271. package/dist/types/Mapper.d.ts +5 -0
  272. package/dist/types/Mapper.js +2 -0
  273. package/dist/types/Mapper.js.map +1 -0
  274. package/dist/types/Node.d.ts +10 -0
  275. package/dist/types/Node.js +2 -0
  276. package/dist/types/Node.js.map +1 -0
  277. package/dist/types/ParamsDictionary.d.ts +3 -0
  278. package/dist/types/ParamsDictionary.js +2 -0
  279. package/dist/types/ParamsDictionary.js.map +1 -0
  280. package/dist/types/Properties.d.ts +5 -0
  281. package/dist/types/Properties.js +2 -0
  282. package/dist/types/Properties.js.map +1 -0
  283. package/dist/types/Targets.d.ts +5 -0
  284. package/dist/types/Targets.js +2 -0
  285. package/dist/types/Targets.js.map +1 -0
  286. package/dist/types/Trigger.d.ts +5 -0
  287. package/dist/types/Trigger.js +2 -0
  288. package/dist/types/Trigger.js.map +1 -0
  289. package/dist/types/TriggerHttp.d.ts +7 -0
  290. package/dist/types/TriggerHttp.js +2 -0
  291. package/dist/types/TriggerHttp.js.map +1 -0
  292. package/dist/types/TriggerResponse.d.ts +6 -0
  293. package/dist/types/TriggerResponse.js +2 -0
  294. package/dist/types/TriggerResponse.js.map +1 -0
  295. package/dist/types/Triggers.d.ts +5 -0
  296. package/dist/types/Triggers.js +2 -0
  297. package/dist/types/Triggers.js.map +1 -0
  298. package/dist/types/TryCatch.d.ts +6 -0
  299. package/dist/types/TryCatch.js +2 -0
  300. package/dist/types/TryCatch.js.map +1 -0
  301. package/dist/visualization/NodeDependencyGraph.d.ts +76 -0
  302. package/dist/visualization/NodeDependencyGraph.js +418 -0
  303. package/dist/visualization/NodeDependencyGraph.js.map +1 -0
  304. package/dist/visualization/WorkflowVisualizer.d.ts +144 -0
  305. package/dist/visualization/WorkflowVisualizer.js +446 -0
  306. package/dist/visualization/WorkflowVisualizer.js.map +1 -0
  307. package/package.json +95 -0
@@ -0,0 +1,143 @@
1
+ /**
2
+ * Role-Based Access Control (RBAC) for Blok
3
+ *
4
+ * Provides fine-grained access control for workflow execution:
5
+ * - Role definitions with permissions
6
+ * - Resource-based access control
7
+ * - Hierarchical roles with inheritance
8
+ * - Workflow-level and node-level access control
9
+ *
10
+ * @example
11
+ * ```typescript
12
+ * const rbac = new RBAC();
13
+ *
14
+ * // Define roles
15
+ * rbac.addRole({
16
+ * name: "admin",
17
+ * permissions: [
18
+ * { resource: "workflow", actions: ["*"] },
19
+ * { resource: "node", actions: ["*"] },
20
+ * ],
21
+ * });
22
+ *
23
+ * rbac.addRole({
24
+ * name: "developer",
25
+ * permissions: [
26
+ * { resource: "workflow", actions: ["read", "execute"] },
27
+ * { resource: "node", actions: ["read", "execute"] },
28
+ * ],
29
+ * inherits: ["viewer"],
30
+ * });
31
+ *
32
+ * rbac.addRole({
33
+ * name: "viewer",
34
+ * permissions: [
35
+ * { resource: "workflow", actions: ["read"] },
36
+ * ],
37
+ * });
38
+ *
39
+ * // Check permissions
40
+ * rbac.can("admin", "workflow", "delete"); // true
41
+ * rbac.can("developer", "workflow", "execute"); // true
42
+ * rbac.can("viewer", "workflow", "execute"); // false
43
+ * ```
44
+ */
45
+ export type Action = "read" | "create" | "update" | "delete" | "execute" | "admin" | "*";
46
+ export interface Permission {
47
+ /** Resource type (e.g., "workflow", "node", "trigger", "runtime") */
48
+ resource: string;
49
+ /** Allowed actions on this resource */
50
+ actions: Action[];
51
+ /** Optional: restrict to specific resource instances by pattern */
52
+ resourcePattern?: string;
53
+ /** Optional: conditions that must be met (e.g., { "env": "staging" }) */
54
+ conditions?: Record<string, unknown>;
55
+ }
56
+ export interface RoleDefinition {
57
+ /** Unique role name */
58
+ name: string;
59
+ /** Human-readable description */
60
+ description?: string;
61
+ /** Permissions granted to this role */
62
+ permissions: Permission[];
63
+ /** Roles this role inherits from */
64
+ inherits?: string[];
65
+ }
66
+ export interface AccessCheckResult {
67
+ allowed: boolean;
68
+ role: string;
69
+ resource: string;
70
+ action: Action;
71
+ reason?: string;
72
+ matchedPermission?: Permission;
73
+ }
74
+ export interface RBACPolicy {
75
+ /** Named resource access policies */
76
+ workflows?: Record<string, {
77
+ allowedRoles: string[];
78
+ actions?: Action[];
79
+ }>;
80
+ /** Default policy when no specific policy matches */
81
+ defaultPolicy?: "allow" | "deny";
82
+ }
83
+ export declare class RBAC {
84
+ private roles;
85
+ private policies;
86
+ private roleCache;
87
+ /**
88
+ * Add a role definition
89
+ */
90
+ addRole(role: RoleDefinition): void;
91
+ /**
92
+ * Remove a role
93
+ */
94
+ removeRole(name: string): void;
95
+ /**
96
+ * Get a role definition
97
+ */
98
+ getRole(name: string): RoleDefinition | undefined;
99
+ /**
100
+ * Get all defined roles
101
+ */
102
+ getRoles(): RoleDefinition[];
103
+ /**
104
+ * Add a resource-specific policy
105
+ */
106
+ addPolicy(resourceId: string, policy: RBACPolicy): void;
107
+ /**
108
+ * Check if a role has permission to perform an action on a resource
109
+ */
110
+ can(roleName: string, resource: string, action: Action, resourceId?: string): AccessCheckResult;
111
+ /**
112
+ * Check if any of the given roles has permission
113
+ */
114
+ canAny(roles: string[], resource: string, action: Action, resourceId?: string): AccessCheckResult;
115
+ /**
116
+ * Check workflow-specific access
117
+ */
118
+ canAccessWorkflow(roles: string[], workflowPath: string, action?: Action): AccessCheckResult;
119
+ /**
120
+ * Get all effective permissions for a role (including inherited)
121
+ */
122
+ getEffectivePermissions(roleName: string, visited?: Set<string>): Permission[];
123
+ /**
124
+ * Export current RBAC configuration as JSON
125
+ */
126
+ toJSON(): {
127
+ roles: RoleDefinition[];
128
+ policies: Record<string, RBACPolicy>;
129
+ };
130
+ /**
131
+ * Load RBAC configuration from JSON
132
+ */
133
+ fromJSON(config: {
134
+ roles: RoleDefinition[];
135
+ policies?: Record<string, RBACPolicy>;
136
+ }): void;
137
+ private matchesPermission;
138
+ private matchesPattern;
139
+ }
140
+ /**
141
+ * Create a preconfigured RBAC instance with common roles
142
+ */
143
+ export declare function createDefaultRBAC(): RBAC;
@@ -0,0 +1,285 @@
1
+ /**
2
+ * Role-Based Access Control (RBAC) for Blok
3
+ *
4
+ * Provides fine-grained access control for workflow execution:
5
+ * - Role definitions with permissions
6
+ * - Resource-based access control
7
+ * - Hierarchical roles with inheritance
8
+ * - Workflow-level and node-level access control
9
+ *
10
+ * @example
11
+ * ```typescript
12
+ * const rbac = new RBAC();
13
+ *
14
+ * // Define roles
15
+ * rbac.addRole({
16
+ * name: "admin",
17
+ * permissions: [
18
+ * { resource: "workflow", actions: ["*"] },
19
+ * { resource: "node", actions: ["*"] },
20
+ * ],
21
+ * });
22
+ *
23
+ * rbac.addRole({
24
+ * name: "developer",
25
+ * permissions: [
26
+ * { resource: "workflow", actions: ["read", "execute"] },
27
+ * { resource: "node", actions: ["read", "execute"] },
28
+ * ],
29
+ * inherits: ["viewer"],
30
+ * });
31
+ *
32
+ * rbac.addRole({
33
+ * name: "viewer",
34
+ * permissions: [
35
+ * { resource: "workflow", actions: ["read"] },
36
+ * ],
37
+ * });
38
+ *
39
+ * // Check permissions
40
+ * rbac.can("admin", "workflow", "delete"); // true
41
+ * rbac.can("developer", "workflow", "execute"); // true
42
+ * rbac.can("viewer", "workflow", "execute"); // false
43
+ * ```
44
+ */
45
+ export class RBAC {
46
+ roles = new Map();
47
+ policies = new Map();
48
+ roleCache = new Map();
49
+ /**
50
+ * Add a role definition
51
+ */
52
+ addRole(role) {
53
+ this.roles.set(role.name, role);
54
+ // Invalidate cache for this role and any role that inherits from it
55
+ this.roleCache.clear();
56
+ }
57
+ /**
58
+ * Remove a role
59
+ */
60
+ removeRole(name) {
61
+ this.roles.delete(name);
62
+ this.roleCache.clear();
63
+ }
64
+ /**
65
+ * Get a role definition
66
+ */
67
+ getRole(name) {
68
+ return this.roles.get(name);
69
+ }
70
+ /**
71
+ * Get all defined roles
72
+ */
73
+ getRoles() {
74
+ return Array.from(this.roles.values());
75
+ }
76
+ /**
77
+ * Add a resource-specific policy
78
+ */
79
+ addPolicy(resourceId, policy) {
80
+ this.policies.set(resourceId, policy);
81
+ }
82
+ /**
83
+ * Check if a role has permission to perform an action on a resource
84
+ */
85
+ can(roleName, resource, action, resourceId) {
86
+ const permissions = this.getEffectivePermissions(roleName);
87
+ for (const perm of permissions) {
88
+ if (this.matchesPermission(perm, resource, action, resourceId)) {
89
+ return {
90
+ allowed: true,
91
+ role: roleName,
92
+ resource,
93
+ action,
94
+ matchedPermission: perm,
95
+ };
96
+ }
97
+ }
98
+ return {
99
+ allowed: false,
100
+ role: roleName,
101
+ resource,
102
+ action,
103
+ reason: `Role '${roleName}' does not have '${action}' permission on '${resource}'`,
104
+ };
105
+ }
106
+ /**
107
+ * Check if any of the given roles has permission
108
+ */
109
+ canAny(roles, resource, action, resourceId) {
110
+ for (const role of roles) {
111
+ const result = this.can(role, resource, action, resourceId);
112
+ if (result.allowed)
113
+ return result;
114
+ }
115
+ return {
116
+ allowed: false,
117
+ role: roles.join(","),
118
+ resource,
119
+ action,
120
+ reason: `None of roles [${roles.join(", ")}] have '${action}' permission on '${resource}'`,
121
+ };
122
+ }
123
+ /**
124
+ * Check workflow-specific access
125
+ */
126
+ canAccessWorkflow(roles, workflowPath, action = "execute") {
127
+ // Check resource-specific policy first
128
+ const policy = this.policies.get(workflowPath);
129
+ if (policy?.workflows) {
130
+ for (const [pattern, config] of Object.entries(policy.workflows)) {
131
+ if (this.matchesPattern(workflowPath, pattern)) {
132
+ const allowedActions = config.actions || ["execute"];
133
+ if (!allowedActions.includes(action) && !allowedActions.includes("*")) {
134
+ return {
135
+ allowed: false,
136
+ role: roles.join(","),
137
+ resource: workflowPath,
138
+ action,
139
+ reason: `Action '${action}' not allowed on workflow '${workflowPath}'`,
140
+ };
141
+ }
142
+ const hasAllowedRole = roles.some((r) => config.allowedRoles.includes(r));
143
+ if (hasAllowedRole) {
144
+ return {
145
+ allowed: true,
146
+ role: roles.find((r) => config.allowedRoles.includes(r)) || roles[0],
147
+ resource: workflowPath,
148
+ action,
149
+ };
150
+ }
151
+ }
152
+ }
153
+ }
154
+ // Fall back to general RBAC check
155
+ return this.canAny(roles, "workflow", action, workflowPath);
156
+ }
157
+ /**
158
+ * Get all effective permissions for a role (including inherited)
159
+ */
160
+ getEffectivePermissions(roleName, visited = new Set()) {
161
+ // Check cache
162
+ const cached = this.roleCache.get(roleName);
163
+ if (cached)
164
+ return cached;
165
+ // Guard against circular inheritance
166
+ if (visited.has(roleName))
167
+ return [];
168
+ visited.add(roleName);
169
+ const role = this.roles.get(roleName);
170
+ if (!role)
171
+ return [];
172
+ const permissions = [...role.permissions];
173
+ // Resolve inherited permissions
174
+ if (role.inherits) {
175
+ for (const parentRole of role.inherits) {
176
+ const inherited = this.getEffectivePermissions(parentRole, visited);
177
+ permissions.push(...inherited);
178
+ }
179
+ }
180
+ // Cache results
181
+ this.roleCache.set(roleName, permissions);
182
+ return permissions;
183
+ }
184
+ /**
185
+ * Export current RBAC configuration as JSON
186
+ */
187
+ toJSON() {
188
+ return {
189
+ roles: Array.from(this.roles.values()),
190
+ policies: Object.fromEntries(this.policies),
191
+ };
192
+ }
193
+ /**
194
+ * Load RBAC configuration from JSON
195
+ */
196
+ fromJSON(config) {
197
+ this.roles.clear();
198
+ this.policies.clear();
199
+ this.roleCache.clear();
200
+ for (const role of config.roles) {
201
+ this.addRole(role);
202
+ }
203
+ if (config.policies) {
204
+ for (const [id, policy] of Object.entries(config.policies)) {
205
+ this.addPolicy(id, policy);
206
+ }
207
+ }
208
+ }
209
+ matchesPermission(perm, resource, action, resourceId) {
210
+ // Check resource type
211
+ if (perm.resource !== resource && perm.resource !== "*")
212
+ return false;
213
+ // Check action
214
+ if (!perm.actions.includes(action) && !perm.actions.includes("*"))
215
+ return false;
216
+ // Check resource pattern if specified
217
+ if (perm.resourcePattern && resourceId) {
218
+ if (!this.matchesPattern(resourceId, perm.resourcePattern))
219
+ return false;
220
+ }
221
+ return true;
222
+ }
223
+ matchesPattern(value, pattern) {
224
+ // Support wildcards: "workflow/*", "workflow/user-*"
225
+ if (pattern === "*")
226
+ return true;
227
+ const regexStr = pattern.replace(/\*/g, ".*").replace(/\?/g, ".");
228
+ const regex = new RegExp(`^${regexStr}$`);
229
+ return regex.test(value);
230
+ }
231
+ }
232
+ /**
233
+ * Create a preconfigured RBAC instance with common roles
234
+ */
235
+ export function createDefaultRBAC() {
236
+ const rbac = new RBAC();
237
+ rbac.addRole({
238
+ name: "admin",
239
+ description: "Full access to all resources",
240
+ permissions: [{ resource: "*", actions: ["*"] }],
241
+ });
242
+ rbac.addRole({
243
+ name: "developer",
244
+ description: "Can read, create, and execute workflows and nodes",
245
+ permissions: [
246
+ { resource: "workflow", actions: ["read", "create", "update", "execute"] },
247
+ { resource: "node", actions: ["read", "create", "update", "execute"] },
248
+ { resource: "trigger", actions: ["read"] },
249
+ { resource: "runtime", actions: ["read", "execute"] },
250
+ ],
251
+ inherits: ["viewer"],
252
+ });
253
+ rbac.addRole({
254
+ name: "operator",
255
+ description: "Can execute and monitor workflows",
256
+ permissions: [
257
+ { resource: "workflow", actions: ["read", "execute"] },
258
+ { resource: "node", actions: ["read", "execute"] },
259
+ { resource: "trigger", actions: ["read"] },
260
+ { resource: "runtime", actions: ["read"] },
261
+ { resource: "metrics", actions: ["read"] },
262
+ { resource: "health", actions: ["read"] },
263
+ ],
264
+ });
265
+ rbac.addRole({
266
+ name: "viewer",
267
+ description: "Read-only access to workflows and nodes",
268
+ permissions: [
269
+ { resource: "workflow", actions: ["read"] },
270
+ { resource: "node", actions: ["read"] },
271
+ { resource: "metrics", actions: ["read"] },
272
+ { resource: "health", actions: ["read"] },
273
+ ],
274
+ });
275
+ rbac.addRole({
276
+ name: "service",
277
+ description: "Machine-to-machine service account",
278
+ permissions: [
279
+ { resource: "workflow", actions: ["execute"] },
280
+ { resource: "node", actions: ["execute"] },
281
+ ],
282
+ });
283
+ return rbac;
284
+ }
285
+ //# sourceMappingURL=RBAC.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RBAC.js","sourceRoot":"","sources":["../../src/security/RBAC.ts"],"names":[],"mappings":"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"}