@agent-assembly/sdk 0.0.1-alpha.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (256) hide show
  1. package/LICENSE +176 -0
  2. package/README.md +182 -0
  3. package/dist/cjs/adapters/adapter-registry.js +2 -0
  4. package/dist/cjs/adapters/adapter.js +2 -0
  5. package/dist/cjs/adapters/index.js +2 -0
  6. package/dist/cjs/adapters/langchain/assembly-callback-handler.js +93 -0
  7. package/dist/cjs/adapters/langchain/index.js +8 -0
  8. package/dist/cjs/adapters/langchain/wrap-tool-with-assembly.js +55 -0
  9. package/dist/cjs/audit/encode.js +176 -0
  10. package/dist/cjs/audit/index.js +8 -0
  11. package/dist/cjs/core/gateway-resolver.js +254 -0
  12. package/dist/cjs/core/index.js +9 -0
  13. package/dist/cjs/core/init-assembly.js +224 -0
  14. package/dist/cjs/errors/configuration-error.js +17 -0
  15. package/dist/cjs/errors/gateway-error.js +17 -0
  16. package/dist/cjs/errors/index.js +11 -0
  17. package/dist/cjs/errors/op-terminated-error.js +20 -0
  18. package/dist/cjs/errors/policy-violation-error.js +10 -0
  19. package/dist/cjs/gateway/client.js +15 -0
  20. package/dist/cjs/gateway/index.js +5 -0
  21. package/dist/cjs/hooks/adapter-registry.js +7 -0
  22. package/dist/cjs/hooks/ai-sdk-detection.js +14 -0
  23. package/dist/cjs/hooks/ai-sdk.js +164 -0
  24. package/dist/cjs/hooks/langchain.js +9 -0
  25. package/dist/cjs/hooks/langgraph-detection.js +14 -0
  26. package/dist/cjs/hooks/langgraph.js +107 -0
  27. package/dist/cjs/hooks/mastra-detection.js +14 -0
  28. package/dist/cjs/hooks/mastra.js +120 -0
  29. package/dist/cjs/hooks/openai-agents-detection.js +14 -0
  30. package/dist/cjs/hooks/openai-agents.js +189 -0
  31. package/dist/cjs/index.js +25 -0
  32. package/dist/cjs/lineage/agent-context-store.js +20 -0
  33. package/dist/cjs/lineage/index.js +7 -0
  34. package/dist/cjs/native/client.js +160 -0
  35. package/dist/cjs/op-control.js +150 -0
  36. package/dist/cjs/package.json +3 -0
  37. package/dist/cjs/proto/generated/common.js +365 -0
  38. package/dist/cjs/proto/generated/policy.js +1418 -0
  39. package/dist/cjs/runtime.js +144 -0
  40. package/dist/cjs/types/assembly-config.js +2 -0
  41. package/dist/cjs/types/assembly-context.js +2 -0
  42. package/dist/cjs/types/assembly-mode.js +2 -0
  43. package/dist/cjs/types/audit.js +5 -0
  44. package/dist/cjs/types/enforcement-mode.js +9 -0
  45. package/dist/cjs/types/gateway-governance.js +2 -0
  46. package/dist/cjs/types/index.js +5 -0
  47. package/dist/cjs/types/langchain-adapter.js +2 -0
  48. package/dist/cjs/types/openai-agents-adapter.js +2 -0
  49. package/dist/cjs/types/policy.js +2 -0
  50. package/dist/cjs/types/tool-map.js +2 -0
  51. package/dist/cjs/types/vercel-ai-adapter.js +2 -0
  52. package/dist/cjs/wrappers/index.js +5 -0
  53. package/dist/cjs/wrappers/with-assembly.js +82 -0
  54. package/dist/esm/adapters/adapter-registry.js +2 -0
  55. package/dist/esm/adapters/adapter-registry.js.map +1 -0
  56. package/dist/esm/adapters/adapter.js +2 -0
  57. package/dist/esm/adapters/adapter.js.map +1 -0
  58. package/dist/esm/adapters/index.js +2 -0
  59. package/dist/esm/adapters/index.js.map +1 -0
  60. package/dist/esm/adapters/langchain/assembly-callback-handler.js +90 -0
  61. package/dist/esm/adapters/langchain/assembly-callback-handler.js.map +1 -0
  62. package/dist/esm/adapters/langchain/index.js +3 -0
  63. package/dist/esm/adapters/langchain/index.js.map +1 -0
  64. package/dist/esm/adapters/langchain/wrap-tool-with-assembly.js +52 -0
  65. package/dist/esm/adapters/langchain/wrap-tool-with-assembly.js.map +1 -0
  66. package/dist/esm/audit/encode.js +171 -0
  67. package/dist/esm/audit/encode.js.map +1 -0
  68. package/dist/esm/audit/index.js +2 -0
  69. package/dist/esm/audit/index.js.map +1 -0
  70. package/dist/esm/core/gateway-resolver.js +213 -0
  71. package/dist/esm/core/gateway-resolver.js.map +1 -0
  72. package/dist/esm/core/index.js +2 -0
  73. package/dist/esm/core/index.js.map +1 -0
  74. package/dist/esm/core/init-assembly.js +218 -0
  75. package/dist/esm/core/init-assembly.js.map +1 -0
  76. package/dist/esm/errors/configuration-error.js +14 -0
  77. package/dist/esm/errors/configuration-error.js.map +1 -0
  78. package/dist/esm/errors/gateway-error.js +14 -0
  79. package/dist/esm/errors/gateway-error.js.map +1 -0
  80. package/dist/esm/errors/index.js +5 -0
  81. package/dist/esm/errors/index.js.map +1 -0
  82. package/dist/esm/errors/op-terminated-error.js +17 -0
  83. package/dist/esm/errors/op-terminated-error.js.map +1 -0
  84. package/dist/esm/errors/policy-violation-error.js +7 -0
  85. package/dist/esm/errors/policy-violation-error.js.map +1 -0
  86. package/dist/esm/gateway/client.js +13 -0
  87. package/dist/esm/gateway/client.js.map +1 -0
  88. package/dist/esm/gateway/index.js +2 -0
  89. package/dist/esm/gateway/index.js.map +1 -0
  90. package/dist/esm/hooks/adapter-registry.js +5 -0
  91. package/dist/esm/hooks/adapter-registry.js.map +1 -0
  92. package/dist/esm/hooks/ai-sdk-detection.js +12 -0
  93. package/dist/esm/hooks/ai-sdk-detection.js.map +1 -0
  94. package/dist/esm/hooks/ai-sdk.js +123 -0
  95. package/dist/esm/hooks/ai-sdk.js.map +1 -0
  96. package/dist/esm/hooks/langchain.js +7 -0
  97. package/dist/esm/hooks/langchain.js.map +1 -0
  98. package/dist/esm/hooks/langgraph-detection.js +12 -0
  99. package/dist/esm/hooks/langgraph-detection.js.map +1 -0
  100. package/dist/esm/hooks/langgraph.js +69 -0
  101. package/dist/esm/hooks/langgraph.js.map +1 -0
  102. package/dist/esm/hooks/mastra-detection.js +12 -0
  103. package/dist/esm/hooks/mastra-detection.js.map +1 -0
  104. package/dist/esm/hooks/mastra.js +83 -0
  105. package/dist/esm/hooks/mastra.js.map +1 -0
  106. package/dist/esm/hooks/openai-agents-detection.js +12 -0
  107. package/dist/esm/hooks/openai-agents-detection.js.map +1 -0
  108. package/dist/esm/hooks/openai-agents.js +145 -0
  109. package/dist/esm/hooks/openai-agents.js.map +1 -0
  110. package/dist/esm/index.js +12 -0
  111. package/dist/esm/index.js.map +1 -0
  112. package/dist/esm/lineage/agent-context-store.js +16 -0
  113. package/dist/esm/lineage/agent-context-store.js.map +1 -0
  114. package/dist/esm/lineage/index.js +2 -0
  115. package/dist/esm/lineage/index.js.map +1 -0
  116. package/dist/esm/native/client.js +150 -0
  117. package/dist/esm/native/client.js.map +1 -0
  118. package/dist/esm/op-control.js +147 -0
  119. package/dist/esm/op-control.js.map +1 -0
  120. package/dist/esm/proto/generated/common.js +357 -0
  121. package/dist/esm/proto/generated/common.js.map +1 -0
  122. package/dist/esm/proto/generated/policy.js +1414 -0
  123. package/dist/esm/proto/generated/policy.js.map +1 -0
  124. package/dist/esm/runtime.js +138 -0
  125. package/dist/esm/runtime.js.map +1 -0
  126. package/dist/esm/types/assembly-config.js +2 -0
  127. package/dist/esm/types/assembly-config.js.map +1 -0
  128. package/dist/esm/types/assembly-context.js +2 -0
  129. package/dist/esm/types/assembly-context.js.map +1 -0
  130. package/dist/esm/types/assembly-mode.js +2 -0
  131. package/dist/esm/types/assembly-mode.js.map +1 -0
  132. package/dist/esm/types/audit.js +5 -0
  133. package/dist/esm/types/audit.js.map +1 -0
  134. package/dist/esm/types/enforcement-mode.js +7 -0
  135. package/dist/esm/types/enforcement-mode.js.map +1 -0
  136. package/dist/esm/types/gateway-governance.js +2 -0
  137. package/dist/esm/types/gateway-governance.js.map +1 -0
  138. package/dist/esm/types/index.js +2 -0
  139. package/dist/esm/types/index.js.map +1 -0
  140. package/dist/esm/types/langchain-adapter.js +2 -0
  141. package/dist/esm/types/langchain-adapter.js.map +1 -0
  142. package/dist/esm/types/openai-agents-adapter.js +2 -0
  143. package/dist/esm/types/openai-agents-adapter.js.map +1 -0
  144. package/dist/esm/types/policy.js +2 -0
  145. package/dist/esm/types/policy.js.map +1 -0
  146. package/dist/esm/types/tool-map.js +2 -0
  147. package/dist/esm/types/tool-map.js.map +1 -0
  148. package/dist/esm/types/vercel-ai-adapter.js +2 -0
  149. package/dist/esm/types/vercel-ai-adapter.js.map +1 -0
  150. package/dist/esm/wrappers/index.js +2 -0
  151. package/dist/esm/wrappers/index.js.map +1 -0
  152. package/dist/esm/wrappers/with-assembly.js +80 -0
  153. package/dist/esm/wrappers/with-assembly.js.map +1 -0
  154. package/dist/types/adapters/adapter-registry.d.ts +7 -0
  155. package/dist/types/adapters/adapter-registry.d.ts.map +1 -0
  156. package/dist/types/adapters/adapter.d.ts +6 -0
  157. package/dist/types/adapters/adapter.d.ts.map +1 -0
  158. package/dist/types/adapters/index.d.ts +3 -0
  159. package/dist/types/adapters/index.d.ts.map +1 -0
  160. package/dist/types/adapters/langchain/assembly-callback-handler.d.ts +21 -0
  161. package/dist/types/adapters/langchain/assembly-callback-handler.d.ts.map +1 -0
  162. package/dist/types/adapters/langchain/index.d.ts +4 -0
  163. package/dist/types/adapters/langchain/index.d.ts.map +1 -0
  164. package/dist/types/adapters/langchain/wrap-tool-with-assembly.d.ts +9 -0
  165. package/dist/types/adapters/langchain/wrap-tool-with-assembly.d.ts.map +1 -0
  166. package/dist/types/audit/encode.d.ts +77 -0
  167. package/dist/types/audit/encode.d.ts.map +1 -0
  168. package/dist/types/audit/index.d.ts +3 -0
  169. package/dist/types/audit/index.d.ts.map +1 -0
  170. package/dist/types/core/gateway-resolver.d.ts +92 -0
  171. package/dist/types/core/gateway-resolver.d.ts.map +1 -0
  172. package/dist/types/core/index.d.ts +2 -0
  173. package/dist/types/core/index.d.ts.map +1 -0
  174. package/dist/types/core/init-assembly.d.ts +10 -0
  175. package/dist/types/core/init-assembly.d.ts.map +1 -0
  176. package/dist/types/errors/configuration-error.d.ts +11 -0
  177. package/dist/types/errors/configuration-error.d.ts.map +1 -0
  178. package/dist/types/errors/gateway-error.d.ts +11 -0
  179. package/dist/types/errors/gateway-error.d.ts.map +1 -0
  180. package/dist/types/errors/index.d.ts +5 -0
  181. package/dist/types/errors/index.d.ts.map +1 -0
  182. package/dist/types/errors/op-terminated-error.d.ts +13 -0
  183. package/dist/types/errors/op-terminated-error.d.ts.map +1 -0
  184. package/dist/types/errors/policy-violation-error.d.ts +4 -0
  185. package/dist/types/errors/policy-violation-error.d.ts.map +1 -0
  186. package/dist/types/gateway/client.d.ts +14 -0
  187. package/dist/types/gateway/client.d.ts.map +1 -0
  188. package/dist/types/gateway/index.d.ts +3 -0
  189. package/dist/types/gateway/index.d.ts.map +1 -0
  190. package/dist/types/hooks/adapter-registry.d.ts +3 -0
  191. package/dist/types/hooks/adapter-registry.d.ts.map +1 -0
  192. package/dist/types/hooks/ai-sdk-detection.d.ts +2 -0
  193. package/dist/types/hooks/ai-sdk-detection.d.ts.map +1 -0
  194. package/dist/types/hooks/ai-sdk.d.ts +36 -0
  195. package/dist/types/hooks/ai-sdk.d.ts.map +1 -0
  196. package/dist/types/hooks/langchain.d.ts +3 -0
  197. package/dist/types/hooks/langchain.d.ts.map +1 -0
  198. package/dist/types/hooks/langgraph-detection.d.ts +2 -0
  199. package/dist/types/hooks/langgraph-detection.d.ts.map +1 -0
  200. package/dist/types/hooks/langgraph.d.ts +26 -0
  201. package/dist/types/hooks/langgraph.d.ts.map +1 -0
  202. package/dist/types/hooks/mastra-detection.d.ts +2 -0
  203. package/dist/types/hooks/mastra-detection.d.ts.map +1 -0
  204. package/dist/types/hooks/mastra.d.ts +29 -0
  205. package/dist/types/hooks/mastra.d.ts.map +1 -0
  206. package/dist/types/hooks/openai-agents-detection.d.ts +2 -0
  207. package/dist/types/hooks/openai-agents-detection.d.ts.map +1 -0
  208. package/dist/types/hooks/openai-agents.d.ts +42 -0
  209. package/dist/types/hooks/openai-agents.d.ts.map +1 -0
  210. package/dist/types/index.d.ts +10 -0
  211. package/dist/types/index.d.ts.map +1 -0
  212. package/dist/types/lineage/agent-context-store.d.ts +12 -0
  213. package/dist/types/lineage/agent-context-store.d.ts.map +1 -0
  214. package/dist/types/lineage/index.d.ts +2 -0
  215. package/dist/types/lineage/index.d.ts.map +1 -0
  216. package/dist/types/native/client.d.ts +26 -0
  217. package/dist/types/native/client.d.ts.map +1 -0
  218. package/dist/types/op-control.d.ts +85 -0
  219. package/dist/types/op-control.d.ts.map +1 -0
  220. package/dist/types/proto/generated/common.d.ts +90 -0
  221. package/dist/types/proto/generated/common.d.ts.map +1 -0
  222. package/dist/types/proto/generated/policy.d.ts +298 -0
  223. package/dist/types/proto/generated/policy.d.ts.map +1 -0
  224. package/dist/types/runtime.d.ts +59 -0
  225. package/dist/types/runtime.d.ts.map +1 -0
  226. package/dist/types/types/assembly-config.d.ts +47 -0
  227. package/dist/types/types/assembly-config.d.ts.map +1 -0
  228. package/dist/types/types/assembly-context.d.ts +12 -0
  229. package/dist/types/types/assembly-context.d.ts.map +1 -0
  230. package/dist/types/types/assembly-mode.d.ts +2 -0
  231. package/dist/types/types/assembly-mode.d.ts.map +1 -0
  232. package/dist/types/types/audit.d.ts +76 -0
  233. package/dist/types/types/audit.d.ts.map +1 -0
  234. package/dist/types/types/enforcement-mode.d.ts +20 -0
  235. package/dist/types/types/enforcement-mode.d.ts.map +1 -0
  236. package/dist/types/types/gateway-governance.d.ts +31 -0
  237. package/dist/types/types/gateway-governance.d.ts.map +1 -0
  238. package/dist/types/types/index.d.ts +12 -0
  239. package/dist/types/types/index.d.ts.map +1 -0
  240. package/dist/types/types/langchain-adapter.d.ts +25 -0
  241. package/dist/types/types/langchain-adapter.d.ts.map +1 -0
  242. package/dist/types/types/openai-agents-adapter.d.ts +17 -0
  243. package/dist/types/types/openai-agents-adapter.d.ts.map +1 -0
  244. package/dist/types/types/policy.d.ts +10 -0
  245. package/dist/types/types/policy.d.ts.map +1 -0
  246. package/dist/types/types/tool-map.d.ts +2 -0
  247. package/dist/types/types/tool-map.d.ts.map +1 -0
  248. package/dist/types/types/vercel-ai-adapter.d.ts +12 -0
  249. package/dist/types/types/vercel-ai-adapter.d.ts.map +1 -0
  250. package/dist/types/wrappers/index.d.ts +3 -0
  251. package/dist/types/wrappers/index.d.ts.map +1 -0
  252. package/dist/types/wrappers/with-assembly.d.ts +9 -0
  253. package/dist/types/wrappers/with-assembly.d.ts.map +1 -0
  254. package/native/aa-ffi-node/index.cjs +20 -0
  255. package/native/aa-ffi-node/index.d.ts +23 -0
  256. package/package.json +95 -0
@@ -0,0 +1,1418 @@
1
+ "use strict";
2
+ // AUTO-GENERATED by scripts/gen-proto.mjs from ../agent-assembly/proto/. Do not edit by hand.
3
+ // Code generated by protoc-gen-ts_proto. DO NOT EDIT.
4
+ // versions:
5
+ // protoc-gen-ts_proto v2.11.8
6
+ // protoc v3.19.1
7
+ // source: policy.proto
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.PolicyServiceClient = exports.PolicyServiceService = exports.OpControlMessage = exports.OpControlSubscribeRequest = exports.BatchCheckResponse = exports.BatchCheckRequest = exports.RedactRule = exports.RedactInstructions = exports.CheckActionResponse = exports.ProcessExecContext = exports.NetworkCallContext = exports.FileOpContext = exports.ToolCallContext = exports.LLMCallContext = exports.ActionContext = exports.CheckActionRequest = exports.OpControlSignal = exports.protobufPackage = void 0;
10
+ exports.opControlSignalFromJSON = opControlSignalFromJSON;
11
+ exports.opControlSignalToJSON = opControlSignalToJSON;
12
+ /* eslint-disable */
13
+ const wire_1 = require("@bufbuild/protobuf/wire");
14
+ const grpc_js_1 = require("@grpc/grpc-js");
15
+ const common_js_1 = require("./common.js");
16
+ exports.protobufPackage = "assembly.policy.v1";
17
+ /**
18
+ * OpControlSignal classifies the lifecycle action the gateway is pushing to
19
+ * the SDK. Mirrors the OpsRegistry transitions in aa-gateway/src/ops/mod.rs.
20
+ */
21
+ var OpControlSignal;
22
+ (function (OpControlSignal) {
23
+ /** OP_CONTROL_SIGNAL_UNSPECIFIED - Default — never wired; treated as a malformed message by the SDK. */
24
+ OpControlSignal[OpControlSignal["OP_CONTROL_SIGNAL_UNSPECIFIED"] = 0] = "OP_CONTROL_SIGNAL_UNSPECIFIED";
25
+ /**
26
+ * OP_CONTROL_SIGNAL_PAUSE - Operator paused the op via POST /api/v1/ops/{id}/pause. SDK should
27
+ * cooperatively yield at the next interruption point and block on resume.
28
+ */
29
+ OpControlSignal[OpControlSignal["OP_CONTROL_SIGNAL_PAUSE"] = 1] = "OP_CONTROL_SIGNAL_PAUSE";
30
+ /** OP_CONTROL_SIGNAL_RESUME - Operator resumed the op via POST /api/v1/ops/{id}/resume. SDK unblocks. */
31
+ OpControlSignal[OpControlSignal["OP_CONTROL_SIGNAL_RESUME"] = 2] = "OP_CONTROL_SIGNAL_RESUME";
32
+ /**
33
+ * OP_CONTROL_SIGNAL_TERMINATE - Operator (or policy deny) terminated the op. SDK fast-fails the in-flight
34
+ * action with an OpTerminatedError.
35
+ */
36
+ OpControlSignal[OpControlSignal["OP_CONTROL_SIGNAL_TERMINATE"] = 3] = "OP_CONTROL_SIGNAL_TERMINATE";
37
+ OpControlSignal[OpControlSignal["UNRECOGNIZED"] = -1] = "UNRECOGNIZED";
38
+ })(OpControlSignal || (exports.OpControlSignal = OpControlSignal = {}));
39
+ function opControlSignalFromJSON(object) {
40
+ switch (object) {
41
+ case 0:
42
+ case "OP_CONTROL_SIGNAL_UNSPECIFIED":
43
+ return OpControlSignal.OP_CONTROL_SIGNAL_UNSPECIFIED;
44
+ case 1:
45
+ case "OP_CONTROL_SIGNAL_PAUSE":
46
+ return OpControlSignal.OP_CONTROL_SIGNAL_PAUSE;
47
+ case 2:
48
+ case "OP_CONTROL_SIGNAL_RESUME":
49
+ return OpControlSignal.OP_CONTROL_SIGNAL_RESUME;
50
+ case 3:
51
+ case "OP_CONTROL_SIGNAL_TERMINATE":
52
+ return OpControlSignal.OP_CONTROL_SIGNAL_TERMINATE;
53
+ case -1:
54
+ case "UNRECOGNIZED":
55
+ default:
56
+ return OpControlSignal.UNRECOGNIZED;
57
+ }
58
+ }
59
+ function opControlSignalToJSON(object) {
60
+ switch (object) {
61
+ case OpControlSignal.OP_CONTROL_SIGNAL_UNSPECIFIED:
62
+ return "OP_CONTROL_SIGNAL_UNSPECIFIED";
63
+ case OpControlSignal.OP_CONTROL_SIGNAL_PAUSE:
64
+ return "OP_CONTROL_SIGNAL_PAUSE";
65
+ case OpControlSignal.OP_CONTROL_SIGNAL_RESUME:
66
+ return "OP_CONTROL_SIGNAL_RESUME";
67
+ case OpControlSignal.OP_CONTROL_SIGNAL_TERMINATE:
68
+ return "OP_CONTROL_SIGNAL_TERMINATE";
69
+ case OpControlSignal.UNRECOGNIZED:
70
+ default:
71
+ return "UNRECOGNIZED";
72
+ }
73
+ }
74
+ function createBaseCheckActionRequest() {
75
+ return { agentId: undefined, credentialToken: "", traceId: "", spanId: "", actionType: 0, context: undefined };
76
+ }
77
+ exports.CheckActionRequest = {
78
+ encode(message, writer = new wire_1.BinaryWriter()) {
79
+ if (message.agentId !== undefined) {
80
+ common_js_1.AgentId.encode(message.agentId, writer.uint32(10).fork()).join();
81
+ }
82
+ if (message.credentialToken !== "") {
83
+ writer.uint32(18).string(message.credentialToken);
84
+ }
85
+ if (message.traceId !== "") {
86
+ writer.uint32(26).string(message.traceId);
87
+ }
88
+ if (message.spanId !== "") {
89
+ writer.uint32(34).string(message.spanId);
90
+ }
91
+ if (message.actionType !== 0) {
92
+ writer.uint32(40).int32(message.actionType);
93
+ }
94
+ if (message.context !== undefined) {
95
+ exports.ActionContext.encode(message.context, writer.uint32(50).fork()).join();
96
+ }
97
+ return writer;
98
+ },
99
+ decode(input, length) {
100
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
101
+ const end = length === undefined ? reader.len : reader.pos + length;
102
+ const message = createBaseCheckActionRequest();
103
+ while (reader.pos < end) {
104
+ const tag = reader.uint32();
105
+ switch (tag >>> 3) {
106
+ case 1: {
107
+ if (tag !== 10) {
108
+ break;
109
+ }
110
+ message.agentId = common_js_1.AgentId.decode(reader, reader.uint32());
111
+ continue;
112
+ }
113
+ case 2: {
114
+ if (tag !== 18) {
115
+ break;
116
+ }
117
+ message.credentialToken = reader.string();
118
+ continue;
119
+ }
120
+ case 3: {
121
+ if (tag !== 26) {
122
+ break;
123
+ }
124
+ message.traceId = reader.string();
125
+ continue;
126
+ }
127
+ case 4: {
128
+ if (tag !== 34) {
129
+ break;
130
+ }
131
+ message.spanId = reader.string();
132
+ continue;
133
+ }
134
+ case 5: {
135
+ if (tag !== 40) {
136
+ break;
137
+ }
138
+ message.actionType = reader.int32();
139
+ continue;
140
+ }
141
+ case 6: {
142
+ if (tag !== 50) {
143
+ break;
144
+ }
145
+ message.context = exports.ActionContext.decode(reader, reader.uint32());
146
+ continue;
147
+ }
148
+ }
149
+ if ((tag & 7) === 4 || tag === 0) {
150
+ break;
151
+ }
152
+ reader.skip(tag & 7);
153
+ }
154
+ return message;
155
+ },
156
+ fromJSON(object) {
157
+ return {
158
+ agentId: isSet(object.agentId)
159
+ ? common_js_1.AgentId.fromJSON(object.agentId)
160
+ : isSet(object.agent_id)
161
+ ? common_js_1.AgentId.fromJSON(object.agent_id)
162
+ : undefined,
163
+ credentialToken: isSet(object.credentialToken)
164
+ ? globalThis.String(object.credentialToken)
165
+ : isSet(object.credential_token)
166
+ ? globalThis.String(object.credential_token)
167
+ : "",
168
+ traceId: isSet(object.traceId)
169
+ ? globalThis.String(object.traceId)
170
+ : isSet(object.trace_id)
171
+ ? globalThis.String(object.trace_id)
172
+ : "",
173
+ spanId: isSet(object.spanId)
174
+ ? globalThis.String(object.spanId)
175
+ : isSet(object.span_id)
176
+ ? globalThis.String(object.span_id)
177
+ : "",
178
+ actionType: isSet(object.actionType)
179
+ ? (0, common_js_1.actionTypeFromJSON)(object.actionType)
180
+ : isSet(object.action_type)
181
+ ? (0, common_js_1.actionTypeFromJSON)(object.action_type)
182
+ : 0,
183
+ context: isSet(object.context) ? exports.ActionContext.fromJSON(object.context) : undefined,
184
+ };
185
+ },
186
+ toJSON(message) {
187
+ const obj = {};
188
+ if (message.agentId !== undefined) {
189
+ obj.agentId = common_js_1.AgentId.toJSON(message.agentId);
190
+ }
191
+ if (message.credentialToken !== "") {
192
+ obj.credentialToken = message.credentialToken;
193
+ }
194
+ if (message.traceId !== "") {
195
+ obj.traceId = message.traceId;
196
+ }
197
+ if (message.spanId !== "") {
198
+ obj.spanId = message.spanId;
199
+ }
200
+ if (message.actionType !== 0) {
201
+ obj.actionType = (0, common_js_1.actionTypeToJSON)(message.actionType);
202
+ }
203
+ if (message.context !== undefined) {
204
+ obj.context = exports.ActionContext.toJSON(message.context);
205
+ }
206
+ return obj;
207
+ },
208
+ create(base) {
209
+ return exports.CheckActionRequest.fromPartial(base ?? {});
210
+ },
211
+ fromPartial(object) {
212
+ const message = createBaseCheckActionRequest();
213
+ message.agentId = (object.agentId !== undefined && object.agentId !== null)
214
+ ? common_js_1.AgentId.fromPartial(object.agentId)
215
+ : undefined;
216
+ message.credentialToken = object.credentialToken ?? "";
217
+ message.traceId = object.traceId ?? "";
218
+ message.spanId = object.spanId ?? "";
219
+ message.actionType = object.actionType ?? 0;
220
+ message.context = (object.context !== undefined && object.context !== null)
221
+ ? exports.ActionContext.fromPartial(object.context)
222
+ : undefined;
223
+ return message;
224
+ },
225
+ };
226
+ function createBaseActionContext() {
227
+ return { llmCall: undefined, toolCall: undefined, fileOp: undefined, networkCall: undefined, processExec: undefined };
228
+ }
229
+ exports.ActionContext = {
230
+ encode(message, writer = new wire_1.BinaryWriter()) {
231
+ if (message.llmCall !== undefined) {
232
+ exports.LLMCallContext.encode(message.llmCall, writer.uint32(10).fork()).join();
233
+ }
234
+ if (message.toolCall !== undefined) {
235
+ exports.ToolCallContext.encode(message.toolCall, writer.uint32(18).fork()).join();
236
+ }
237
+ if (message.fileOp !== undefined) {
238
+ exports.FileOpContext.encode(message.fileOp, writer.uint32(26).fork()).join();
239
+ }
240
+ if (message.networkCall !== undefined) {
241
+ exports.NetworkCallContext.encode(message.networkCall, writer.uint32(34).fork()).join();
242
+ }
243
+ if (message.processExec !== undefined) {
244
+ exports.ProcessExecContext.encode(message.processExec, writer.uint32(42).fork()).join();
245
+ }
246
+ return writer;
247
+ },
248
+ decode(input, length) {
249
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
250
+ const end = length === undefined ? reader.len : reader.pos + length;
251
+ const message = createBaseActionContext();
252
+ while (reader.pos < end) {
253
+ const tag = reader.uint32();
254
+ switch (tag >>> 3) {
255
+ case 1: {
256
+ if (tag !== 10) {
257
+ break;
258
+ }
259
+ message.llmCall = exports.LLMCallContext.decode(reader, reader.uint32());
260
+ continue;
261
+ }
262
+ case 2: {
263
+ if (tag !== 18) {
264
+ break;
265
+ }
266
+ message.toolCall = exports.ToolCallContext.decode(reader, reader.uint32());
267
+ continue;
268
+ }
269
+ case 3: {
270
+ if (tag !== 26) {
271
+ break;
272
+ }
273
+ message.fileOp = exports.FileOpContext.decode(reader, reader.uint32());
274
+ continue;
275
+ }
276
+ case 4: {
277
+ if (tag !== 34) {
278
+ break;
279
+ }
280
+ message.networkCall = exports.NetworkCallContext.decode(reader, reader.uint32());
281
+ continue;
282
+ }
283
+ case 5: {
284
+ if (tag !== 42) {
285
+ break;
286
+ }
287
+ message.processExec = exports.ProcessExecContext.decode(reader, reader.uint32());
288
+ continue;
289
+ }
290
+ }
291
+ if ((tag & 7) === 4 || tag === 0) {
292
+ break;
293
+ }
294
+ reader.skip(tag & 7);
295
+ }
296
+ return message;
297
+ },
298
+ fromJSON(object) {
299
+ return {
300
+ llmCall: isSet(object.llmCall)
301
+ ? exports.LLMCallContext.fromJSON(object.llmCall)
302
+ : isSet(object.llm_call)
303
+ ? exports.LLMCallContext.fromJSON(object.llm_call)
304
+ : undefined,
305
+ toolCall: isSet(object.toolCall)
306
+ ? exports.ToolCallContext.fromJSON(object.toolCall)
307
+ : isSet(object.tool_call)
308
+ ? exports.ToolCallContext.fromJSON(object.tool_call)
309
+ : undefined,
310
+ fileOp: isSet(object.fileOp)
311
+ ? exports.FileOpContext.fromJSON(object.fileOp)
312
+ : isSet(object.file_op)
313
+ ? exports.FileOpContext.fromJSON(object.file_op)
314
+ : undefined,
315
+ networkCall: isSet(object.networkCall)
316
+ ? exports.NetworkCallContext.fromJSON(object.networkCall)
317
+ : isSet(object.network_call)
318
+ ? exports.NetworkCallContext.fromJSON(object.network_call)
319
+ : undefined,
320
+ processExec: isSet(object.processExec)
321
+ ? exports.ProcessExecContext.fromJSON(object.processExec)
322
+ : isSet(object.process_exec)
323
+ ? exports.ProcessExecContext.fromJSON(object.process_exec)
324
+ : undefined,
325
+ };
326
+ },
327
+ toJSON(message) {
328
+ const obj = {};
329
+ if (message.llmCall !== undefined) {
330
+ obj.llmCall = exports.LLMCallContext.toJSON(message.llmCall);
331
+ }
332
+ if (message.toolCall !== undefined) {
333
+ obj.toolCall = exports.ToolCallContext.toJSON(message.toolCall);
334
+ }
335
+ if (message.fileOp !== undefined) {
336
+ obj.fileOp = exports.FileOpContext.toJSON(message.fileOp);
337
+ }
338
+ if (message.networkCall !== undefined) {
339
+ obj.networkCall = exports.NetworkCallContext.toJSON(message.networkCall);
340
+ }
341
+ if (message.processExec !== undefined) {
342
+ obj.processExec = exports.ProcessExecContext.toJSON(message.processExec);
343
+ }
344
+ return obj;
345
+ },
346
+ create(base) {
347
+ return exports.ActionContext.fromPartial(base ?? {});
348
+ },
349
+ fromPartial(object) {
350
+ const message = createBaseActionContext();
351
+ message.llmCall = (object.llmCall !== undefined && object.llmCall !== null)
352
+ ? exports.LLMCallContext.fromPartial(object.llmCall)
353
+ : undefined;
354
+ message.toolCall = (object.toolCall !== undefined && object.toolCall !== null)
355
+ ? exports.ToolCallContext.fromPartial(object.toolCall)
356
+ : undefined;
357
+ message.fileOp = (object.fileOp !== undefined && object.fileOp !== null)
358
+ ? exports.FileOpContext.fromPartial(object.fileOp)
359
+ : undefined;
360
+ message.networkCall = (object.networkCall !== undefined && object.networkCall !== null)
361
+ ? exports.NetworkCallContext.fromPartial(object.networkCall)
362
+ : undefined;
363
+ message.processExec = (object.processExec !== undefined && object.processExec !== null)
364
+ ? exports.ProcessExecContext.fromPartial(object.processExec)
365
+ : undefined;
366
+ return message;
367
+ },
368
+ };
369
+ function createBaseLLMCallContext() {
370
+ return { model: "", promptTokens: 0, containsPii: false };
371
+ }
372
+ exports.LLMCallContext = {
373
+ encode(message, writer = new wire_1.BinaryWriter()) {
374
+ if (message.model !== "") {
375
+ writer.uint32(10).string(message.model);
376
+ }
377
+ if (message.promptTokens !== 0) {
378
+ writer.uint32(16).int32(message.promptTokens);
379
+ }
380
+ if (message.containsPii !== false) {
381
+ writer.uint32(24).bool(message.containsPii);
382
+ }
383
+ return writer;
384
+ },
385
+ decode(input, length) {
386
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
387
+ const end = length === undefined ? reader.len : reader.pos + length;
388
+ const message = createBaseLLMCallContext();
389
+ while (reader.pos < end) {
390
+ const tag = reader.uint32();
391
+ switch (tag >>> 3) {
392
+ case 1: {
393
+ if (tag !== 10) {
394
+ break;
395
+ }
396
+ message.model = reader.string();
397
+ continue;
398
+ }
399
+ case 2: {
400
+ if (tag !== 16) {
401
+ break;
402
+ }
403
+ message.promptTokens = reader.int32();
404
+ continue;
405
+ }
406
+ case 3: {
407
+ if (tag !== 24) {
408
+ break;
409
+ }
410
+ message.containsPii = reader.bool();
411
+ continue;
412
+ }
413
+ }
414
+ if ((tag & 7) === 4 || tag === 0) {
415
+ break;
416
+ }
417
+ reader.skip(tag & 7);
418
+ }
419
+ return message;
420
+ },
421
+ fromJSON(object) {
422
+ return {
423
+ model: isSet(object.model) ? globalThis.String(object.model) : "",
424
+ promptTokens: isSet(object.promptTokens)
425
+ ? globalThis.Number(object.promptTokens)
426
+ : isSet(object.prompt_tokens)
427
+ ? globalThis.Number(object.prompt_tokens)
428
+ : 0,
429
+ containsPii: isSet(object.containsPii)
430
+ ? globalThis.Boolean(object.containsPii)
431
+ : isSet(object.contains_pii)
432
+ ? globalThis.Boolean(object.contains_pii)
433
+ : false,
434
+ };
435
+ },
436
+ toJSON(message) {
437
+ const obj = {};
438
+ if (message.model !== "") {
439
+ obj.model = message.model;
440
+ }
441
+ if (message.promptTokens !== 0) {
442
+ obj.promptTokens = Math.round(message.promptTokens);
443
+ }
444
+ if (message.containsPii !== false) {
445
+ obj.containsPii = message.containsPii;
446
+ }
447
+ return obj;
448
+ },
449
+ create(base) {
450
+ return exports.LLMCallContext.fromPartial(base ?? {});
451
+ },
452
+ fromPartial(object) {
453
+ const message = createBaseLLMCallContext();
454
+ message.model = object.model ?? "";
455
+ message.promptTokens = object.promptTokens ?? 0;
456
+ message.containsPii = object.containsPii ?? false;
457
+ return message;
458
+ },
459
+ };
460
+ function createBaseToolCallContext() {
461
+ return { toolName: "", toolSource: "", argsJson: Buffer.alloc(0), targetUrl: "" };
462
+ }
463
+ exports.ToolCallContext = {
464
+ encode(message, writer = new wire_1.BinaryWriter()) {
465
+ if (message.toolName !== "") {
466
+ writer.uint32(10).string(message.toolName);
467
+ }
468
+ if (message.toolSource !== "") {
469
+ writer.uint32(18).string(message.toolSource);
470
+ }
471
+ if (message.argsJson.length !== 0) {
472
+ writer.uint32(26).bytes(message.argsJson);
473
+ }
474
+ if (message.targetUrl !== "") {
475
+ writer.uint32(34).string(message.targetUrl);
476
+ }
477
+ return writer;
478
+ },
479
+ decode(input, length) {
480
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
481
+ const end = length === undefined ? reader.len : reader.pos + length;
482
+ const message = createBaseToolCallContext();
483
+ while (reader.pos < end) {
484
+ const tag = reader.uint32();
485
+ switch (tag >>> 3) {
486
+ case 1: {
487
+ if (tag !== 10) {
488
+ break;
489
+ }
490
+ message.toolName = reader.string();
491
+ continue;
492
+ }
493
+ case 2: {
494
+ if (tag !== 18) {
495
+ break;
496
+ }
497
+ message.toolSource = reader.string();
498
+ continue;
499
+ }
500
+ case 3: {
501
+ if (tag !== 26) {
502
+ break;
503
+ }
504
+ message.argsJson = Buffer.from(reader.bytes());
505
+ continue;
506
+ }
507
+ case 4: {
508
+ if (tag !== 34) {
509
+ break;
510
+ }
511
+ message.targetUrl = reader.string();
512
+ continue;
513
+ }
514
+ }
515
+ if ((tag & 7) === 4 || tag === 0) {
516
+ break;
517
+ }
518
+ reader.skip(tag & 7);
519
+ }
520
+ return message;
521
+ },
522
+ fromJSON(object) {
523
+ return {
524
+ toolName: isSet(object.toolName)
525
+ ? globalThis.String(object.toolName)
526
+ : isSet(object.tool_name)
527
+ ? globalThis.String(object.tool_name)
528
+ : "",
529
+ toolSource: isSet(object.toolSource)
530
+ ? globalThis.String(object.toolSource)
531
+ : isSet(object.tool_source)
532
+ ? globalThis.String(object.tool_source)
533
+ : "",
534
+ argsJson: isSet(object.argsJson)
535
+ ? Buffer.from(bytesFromBase64(object.argsJson))
536
+ : isSet(object.args_json)
537
+ ? Buffer.from(bytesFromBase64(object.args_json))
538
+ : Buffer.alloc(0),
539
+ targetUrl: isSet(object.targetUrl)
540
+ ? globalThis.String(object.targetUrl)
541
+ : isSet(object.target_url)
542
+ ? globalThis.String(object.target_url)
543
+ : "",
544
+ };
545
+ },
546
+ toJSON(message) {
547
+ const obj = {};
548
+ if (message.toolName !== "") {
549
+ obj.toolName = message.toolName;
550
+ }
551
+ if (message.toolSource !== "") {
552
+ obj.toolSource = message.toolSource;
553
+ }
554
+ if (message.argsJson.length !== 0) {
555
+ obj.argsJson = base64FromBytes(message.argsJson);
556
+ }
557
+ if (message.targetUrl !== "") {
558
+ obj.targetUrl = message.targetUrl;
559
+ }
560
+ return obj;
561
+ },
562
+ create(base) {
563
+ return exports.ToolCallContext.fromPartial(base ?? {});
564
+ },
565
+ fromPartial(object) {
566
+ const message = createBaseToolCallContext();
567
+ message.toolName = object.toolName ?? "";
568
+ message.toolSource = object.toolSource ?? "";
569
+ message.argsJson = object.argsJson ?? Buffer.alloc(0);
570
+ message.targetUrl = object.targetUrl ?? "";
571
+ return message;
572
+ },
573
+ };
574
+ function createBaseFileOpContext() {
575
+ return { operation: "", path: "", isSensitivePath: false };
576
+ }
577
+ exports.FileOpContext = {
578
+ encode(message, writer = new wire_1.BinaryWriter()) {
579
+ if (message.operation !== "") {
580
+ writer.uint32(10).string(message.operation);
581
+ }
582
+ if (message.path !== "") {
583
+ writer.uint32(18).string(message.path);
584
+ }
585
+ if (message.isSensitivePath !== false) {
586
+ writer.uint32(24).bool(message.isSensitivePath);
587
+ }
588
+ return writer;
589
+ },
590
+ decode(input, length) {
591
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
592
+ const end = length === undefined ? reader.len : reader.pos + length;
593
+ const message = createBaseFileOpContext();
594
+ while (reader.pos < end) {
595
+ const tag = reader.uint32();
596
+ switch (tag >>> 3) {
597
+ case 1: {
598
+ if (tag !== 10) {
599
+ break;
600
+ }
601
+ message.operation = reader.string();
602
+ continue;
603
+ }
604
+ case 2: {
605
+ if (tag !== 18) {
606
+ break;
607
+ }
608
+ message.path = reader.string();
609
+ continue;
610
+ }
611
+ case 3: {
612
+ if (tag !== 24) {
613
+ break;
614
+ }
615
+ message.isSensitivePath = reader.bool();
616
+ continue;
617
+ }
618
+ }
619
+ if ((tag & 7) === 4 || tag === 0) {
620
+ break;
621
+ }
622
+ reader.skip(tag & 7);
623
+ }
624
+ return message;
625
+ },
626
+ fromJSON(object) {
627
+ return {
628
+ operation: isSet(object.operation) ? globalThis.String(object.operation) : "",
629
+ path: isSet(object.path) ? globalThis.String(object.path) : "",
630
+ isSensitivePath: isSet(object.isSensitivePath)
631
+ ? globalThis.Boolean(object.isSensitivePath)
632
+ : isSet(object.is_sensitive_path)
633
+ ? globalThis.Boolean(object.is_sensitive_path)
634
+ : false,
635
+ };
636
+ },
637
+ toJSON(message) {
638
+ const obj = {};
639
+ if (message.operation !== "") {
640
+ obj.operation = message.operation;
641
+ }
642
+ if (message.path !== "") {
643
+ obj.path = message.path;
644
+ }
645
+ if (message.isSensitivePath !== false) {
646
+ obj.isSensitivePath = message.isSensitivePath;
647
+ }
648
+ return obj;
649
+ },
650
+ create(base) {
651
+ return exports.FileOpContext.fromPartial(base ?? {});
652
+ },
653
+ fromPartial(object) {
654
+ const message = createBaseFileOpContext();
655
+ message.operation = object.operation ?? "";
656
+ message.path = object.path ?? "";
657
+ message.isSensitivePath = object.isSensitivePath ?? false;
658
+ return message;
659
+ },
660
+ };
661
+ function createBaseNetworkCallContext() {
662
+ return { host: "", port: 0, protocol: "", inAllowlist: false };
663
+ }
664
+ exports.NetworkCallContext = {
665
+ encode(message, writer = new wire_1.BinaryWriter()) {
666
+ if (message.host !== "") {
667
+ writer.uint32(10).string(message.host);
668
+ }
669
+ if (message.port !== 0) {
670
+ writer.uint32(16).int32(message.port);
671
+ }
672
+ if (message.protocol !== "") {
673
+ writer.uint32(26).string(message.protocol);
674
+ }
675
+ if (message.inAllowlist !== false) {
676
+ writer.uint32(32).bool(message.inAllowlist);
677
+ }
678
+ return writer;
679
+ },
680
+ decode(input, length) {
681
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
682
+ const end = length === undefined ? reader.len : reader.pos + length;
683
+ const message = createBaseNetworkCallContext();
684
+ while (reader.pos < end) {
685
+ const tag = reader.uint32();
686
+ switch (tag >>> 3) {
687
+ case 1: {
688
+ if (tag !== 10) {
689
+ break;
690
+ }
691
+ message.host = reader.string();
692
+ continue;
693
+ }
694
+ case 2: {
695
+ if (tag !== 16) {
696
+ break;
697
+ }
698
+ message.port = reader.int32();
699
+ continue;
700
+ }
701
+ case 3: {
702
+ if (tag !== 26) {
703
+ break;
704
+ }
705
+ message.protocol = reader.string();
706
+ continue;
707
+ }
708
+ case 4: {
709
+ if (tag !== 32) {
710
+ break;
711
+ }
712
+ message.inAllowlist = reader.bool();
713
+ continue;
714
+ }
715
+ }
716
+ if ((tag & 7) === 4 || tag === 0) {
717
+ break;
718
+ }
719
+ reader.skip(tag & 7);
720
+ }
721
+ return message;
722
+ },
723
+ fromJSON(object) {
724
+ return {
725
+ host: isSet(object.host) ? globalThis.String(object.host) : "",
726
+ port: isSet(object.port) ? globalThis.Number(object.port) : 0,
727
+ protocol: isSet(object.protocol) ? globalThis.String(object.protocol) : "",
728
+ inAllowlist: isSet(object.inAllowlist)
729
+ ? globalThis.Boolean(object.inAllowlist)
730
+ : isSet(object.in_allowlist)
731
+ ? globalThis.Boolean(object.in_allowlist)
732
+ : false,
733
+ };
734
+ },
735
+ toJSON(message) {
736
+ const obj = {};
737
+ if (message.host !== "") {
738
+ obj.host = message.host;
739
+ }
740
+ if (message.port !== 0) {
741
+ obj.port = Math.round(message.port);
742
+ }
743
+ if (message.protocol !== "") {
744
+ obj.protocol = message.protocol;
745
+ }
746
+ if (message.inAllowlist !== false) {
747
+ obj.inAllowlist = message.inAllowlist;
748
+ }
749
+ return obj;
750
+ },
751
+ create(base) {
752
+ return exports.NetworkCallContext.fromPartial(base ?? {});
753
+ },
754
+ fromPartial(object) {
755
+ const message = createBaseNetworkCallContext();
756
+ message.host = object.host ?? "";
757
+ message.port = object.port ?? 0;
758
+ message.protocol = object.protocol ?? "";
759
+ message.inAllowlist = object.inAllowlist ?? false;
760
+ return message;
761
+ },
762
+ };
763
+ function createBaseProcessExecContext() {
764
+ return { command: "", args: [] };
765
+ }
766
+ exports.ProcessExecContext = {
767
+ encode(message, writer = new wire_1.BinaryWriter()) {
768
+ if (message.command !== "") {
769
+ writer.uint32(10).string(message.command);
770
+ }
771
+ for (const v of message.args) {
772
+ writer.uint32(18).string(v);
773
+ }
774
+ return writer;
775
+ },
776
+ decode(input, length) {
777
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
778
+ const end = length === undefined ? reader.len : reader.pos + length;
779
+ const message = createBaseProcessExecContext();
780
+ while (reader.pos < end) {
781
+ const tag = reader.uint32();
782
+ switch (tag >>> 3) {
783
+ case 1: {
784
+ if (tag !== 10) {
785
+ break;
786
+ }
787
+ message.command = reader.string();
788
+ continue;
789
+ }
790
+ case 2: {
791
+ if (tag !== 18) {
792
+ break;
793
+ }
794
+ message.args.push(reader.string());
795
+ continue;
796
+ }
797
+ }
798
+ if ((tag & 7) === 4 || tag === 0) {
799
+ break;
800
+ }
801
+ reader.skip(tag & 7);
802
+ }
803
+ return message;
804
+ },
805
+ fromJSON(object) {
806
+ return {
807
+ command: isSet(object.command) ? globalThis.String(object.command) : "",
808
+ args: globalThis.Array.isArray(object?.args) ? object.args.map((e) => globalThis.String(e)) : [],
809
+ };
810
+ },
811
+ toJSON(message) {
812
+ const obj = {};
813
+ if (message.command !== "") {
814
+ obj.command = message.command;
815
+ }
816
+ if (message.args?.length) {
817
+ obj.args = message.args;
818
+ }
819
+ return obj;
820
+ },
821
+ create(base) {
822
+ return exports.ProcessExecContext.fromPartial(base ?? {});
823
+ },
824
+ fromPartial(object) {
825
+ const message = createBaseProcessExecContext();
826
+ message.command = object.command ?? "";
827
+ message.args = object.args?.map((e) => e) || [];
828
+ return message;
829
+ },
830
+ };
831
+ function createBaseCheckActionResponse() {
832
+ return { decision: 0, reason: "", policyRule: "", approvalId: "", redact: undefined, decisionLatencyUs: 0 };
833
+ }
834
+ exports.CheckActionResponse = {
835
+ encode(message, writer = new wire_1.BinaryWriter()) {
836
+ if (message.decision !== 0) {
837
+ writer.uint32(8).int32(message.decision);
838
+ }
839
+ if (message.reason !== "") {
840
+ writer.uint32(18).string(message.reason);
841
+ }
842
+ if (message.policyRule !== "") {
843
+ writer.uint32(26).string(message.policyRule);
844
+ }
845
+ if (message.approvalId !== "") {
846
+ writer.uint32(34).string(message.approvalId);
847
+ }
848
+ if (message.redact !== undefined) {
849
+ exports.RedactInstructions.encode(message.redact, writer.uint32(42).fork()).join();
850
+ }
851
+ if (message.decisionLatencyUs !== 0) {
852
+ writer.uint32(48).int64(message.decisionLatencyUs);
853
+ }
854
+ return writer;
855
+ },
856
+ decode(input, length) {
857
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
858
+ const end = length === undefined ? reader.len : reader.pos + length;
859
+ const message = createBaseCheckActionResponse();
860
+ while (reader.pos < end) {
861
+ const tag = reader.uint32();
862
+ switch (tag >>> 3) {
863
+ case 1: {
864
+ if (tag !== 8) {
865
+ break;
866
+ }
867
+ message.decision = reader.int32();
868
+ continue;
869
+ }
870
+ case 2: {
871
+ if (tag !== 18) {
872
+ break;
873
+ }
874
+ message.reason = reader.string();
875
+ continue;
876
+ }
877
+ case 3: {
878
+ if (tag !== 26) {
879
+ break;
880
+ }
881
+ message.policyRule = reader.string();
882
+ continue;
883
+ }
884
+ case 4: {
885
+ if (tag !== 34) {
886
+ break;
887
+ }
888
+ message.approvalId = reader.string();
889
+ continue;
890
+ }
891
+ case 5: {
892
+ if (tag !== 42) {
893
+ break;
894
+ }
895
+ message.redact = exports.RedactInstructions.decode(reader, reader.uint32());
896
+ continue;
897
+ }
898
+ case 6: {
899
+ if (tag !== 48) {
900
+ break;
901
+ }
902
+ message.decisionLatencyUs = longToNumber(reader.int64());
903
+ continue;
904
+ }
905
+ }
906
+ if ((tag & 7) === 4 || tag === 0) {
907
+ break;
908
+ }
909
+ reader.skip(tag & 7);
910
+ }
911
+ return message;
912
+ },
913
+ fromJSON(object) {
914
+ return {
915
+ decision: isSet(object.decision) ? (0, common_js_1.decisionFromJSON)(object.decision) : 0,
916
+ reason: isSet(object.reason) ? globalThis.String(object.reason) : "",
917
+ policyRule: isSet(object.policyRule)
918
+ ? globalThis.String(object.policyRule)
919
+ : isSet(object.policy_rule)
920
+ ? globalThis.String(object.policy_rule)
921
+ : "",
922
+ approvalId: isSet(object.approvalId)
923
+ ? globalThis.String(object.approvalId)
924
+ : isSet(object.approval_id)
925
+ ? globalThis.String(object.approval_id)
926
+ : "",
927
+ redact: isSet(object.redact) ? exports.RedactInstructions.fromJSON(object.redact) : undefined,
928
+ decisionLatencyUs: isSet(object.decisionLatencyUs)
929
+ ? globalThis.Number(object.decisionLatencyUs)
930
+ : isSet(object.decision_latency_us)
931
+ ? globalThis.Number(object.decision_latency_us)
932
+ : 0,
933
+ };
934
+ },
935
+ toJSON(message) {
936
+ const obj = {};
937
+ if (message.decision !== 0) {
938
+ obj.decision = (0, common_js_1.decisionToJSON)(message.decision);
939
+ }
940
+ if (message.reason !== "") {
941
+ obj.reason = message.reason;
942
+ }
943
+ if (message.policyRule !== "") {
944
+ obj.policyRule = message.policyRule;
945
+ }
946
+ if (message.approvalId !== "") {
947
+ obj.approvalId = message.approvalId;
948
+ }
949
+ if (message.redact !== undefined) {
950
+ obj.redact = exports.RedactInstructions.toJSON(message.redact);
951
+ }
952
+ if (message.decisionLatencyUs !== 0) {
953
+ obj.decisionLatencyUs = Math.round(message.decisionLatencyUs);
954
+ }
955
+ return obj;
956
+ },
957
+ create(base) {
958
+ return exports.CheckActionResponse.fromPartial(base ?? {});
959
+ },
960
+ fromPartial(object) {
961
+ const message = createBaseCheckActionResponse();
962
+ message.decision = object.decision ?? 0;
963
+ message.reason = object.reason ?? "";
964
+ message.policyRule = object.policyRule ?? "";
965
+ message.approvalId = object.approvalId ?? "";
966
+ message.redact = (object.redact !== undefined && object.redact !== null)
967
+ ? exports.RedactInstructions.fromPartial(object.redact)
968
+ : undefined;
969
+ message.decisionLatencyUs = object.decisionLatencyUs ?? 0;
970
+ return message;
971
+ },
972
+ };
973
+ function createBaseRedactInstructions() {
974
+ return { rules: [] };
975
+ }
976
+ exports.RedactInstructions = {
977
+ encode(message, writer = new wire_1.BinaryWriter()) {
978
+ for (const v of message.rules) {
979
+ exports.RedactRule.encode(v, writer.uint32(10).fork()).join();
980
+ }
981
+ return writer;
982
+ },
983
+ decode(input, length) {
984
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
985
+ const end = length === undefined ? reader.len : reader.pos + length;
986
+ const message = createBaseRedactInstructions();
987
+ while (reader.pos < end) {
988
+ const tag = reader.uint32();
989
+ switch (tag >>> 3) {
990
+ case 1: {
991
+ if (tag !== 10) {
992
+ break;
993
+ }
994
+ message.rules.push(exports.RedactRule.decode(reader, reader.uint32()));
995
+ continue;
996
+ }
997
+ }
998
+ if ((tag & 7) === 4 || tag === 0) {
999
+ break;
1000
+ }
1001
+ reader.skip(tag & 7);
1002
+ }
1003
+ return message;
1004
+ },
1005
+ fromJSON(object) {
1006
+ return {
1007
+ rules: globalThis.Array.isArray(object?.rules) ? object.rules.map((e) => exports.RedactRule.fromJSON(e)) : [],
1008
+ };
1009
+ },
1010
+ toJSON(message) {
1011
+ const obj = {};
1012
+ if (message.rules?.length) {
1013
+ obj.rules = message.rules.map((e) => exports.RedactRule.toJSON(e));
1014
+ }
1015
+ return obj;
1016
+ },
1017
+ create(base) {
1018
+ return exports.RedactInstructions.fromPartial(base ?? {});
1019
+ },
1020
+ fromPartial(object) {
1021
+ const message = createBaseRedactInstructions();
1022
+ message.rules = object.rules?.map((e) => exports.RedactRule.fromPartial(e)) || [];
1023
+ return message;
1024
+ },
1025
+ };
1026
+ function createBaseRedactRule() {
1027
+ return { fieldPath: "", replacement: "" };
1028
+ }
1029
+ exports.RedactRule = {
1030
+ encode(message, writer = new wire_1.BinaryWriter()) {
1031
+ if (message.fieldPath !== "") {
1032
+ writer.uint32(10).string(message.fieldPath);
1033
+ }
1034
+ if (message.replacement !== "") {
1035
+ writer.uint32(18).string(message.replacement);
1036
+ }
1037
+ return writer;
1038
+ },
1039
+ decode(input, length) {
1040
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
1041
+ const end = length === undefined ? reader.len : reader.pos + length;
1042
+ const message = createBaseRedactRule();
1043
+ while (reader.pos < end) {
1044
+ const tag = reader.uint32();
1045
+ switch (tag >>> 3) {
1046
+ case 1: {
1047
+ if (tag !== 10) {
1048
+ break;
1049
+ }
1050
+ message.fieldPath = reader.string();
1051
+ continue;
1052
+ }
1053
+ case 2: {
1054
+ if (tag !== 18) {
1055
+ break;
1056
+ }
1057
+ message.replacement = reader.string();
1058
+ continue;
1059
+ }
1060
+ }
1061
+ if ((tag & 7) === 4 || tag === 0) {
1062
+ break;
1063
+ }
1064
+ reader.skip(tag & 7);
1065
+ }
1066
+ return message;
1067
+ },
1068
+ fromJSON(object) {
1069
+ return {
1070
+ fieldPath: isSet(object.fieldPath)
1071
+ ? globalThis.String(object.fieldPath)
1072
+ : isSet(object.field_path)
1073
+ ? globalThis.String(object.field_path)
1074
+ : "",
1075
+ replacement: isSet(object.replacement) ? globalThis.String(object.replacement) : "",
1076
+ };
1077
+ },
1078
+ toJSON(message) {
1079
+ const obj = {};
1080
+ if (message.fieldPath !== "") {
1081
+ obj.fieldPath = message.fieldPath;
1082
+ }
1083
+ if (message.replacement !== "") {
1084
+ obj.replacement = message.replacement;
1085
+ }
1086
+ return obj;
1087
+ },
1088
+ create(base) {
1089
+ return exports.RedactRule.fromPartial(base ?? {});
1090
+ },
1091
+ fromPartial(object) {
1092
+ const message = createBaseRedactRule();
1093
+ message.fieldPath = object.fieldPath ?? "";
1094
+ message.replacement = object.replacement ?? "";
1095
+ return message;
1096
+ },
1097
+ };
1098
+ function createBaseBatchCheckRequest() {
1099
+ return { requests: [] };
1100
+ }
1101
+ exports.BatchCheckRequest = {
1102
+ encode(message, writer = new wire_1.BinaryWriter()) {
1103
+ for (const v of message.requests) {
1104
+ exports.CheckActionRequest.encode(v, writer.uint32(10).fork()).join();
1105
+ }
1106
+ return writer;
1107
+ },
1108
+ decode(input, length) {
1109
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
1110
+ const end = length === undefined ? reader.len : reader.pos + length;
1111
+ const message = createBaseBatchCheckRequest();
1112
+ while (reader.pos < end) {
1113
+ const tag = reader.uint32();
1114
+ switch (tag >>> 3) {
1115
+ case 1: {
1116
+ if (tag !== 10) {
1117
+ break;
1118
+ }
1119
+ message.requests.push(exports.CheckActionRequest.decode(reader, reader.uint32()));
1120
+ continue;
1121
+ }
1122
+ }
1123
+ if ((tag & 7) === 4 || tag === 0) {
1124
+ break;
1125
+ }
1126
+ reader.skip(tag & 7);
1127
+ }
1128
+ return message;
1129
+ },
1130
+ fromJSON(object) {
1131
+ return {
1132
+ requests: globalThis.Array.isArray(object?.requests)
1133
+ ? object.requests.map((e) => exports.CheckActionRequest.fromJSON(e))
1134
+ : [],
1135
+ };
1136
+ },
1137
+ toJSON(message) {
1138
+ const obj = {};
1139
+ if (message.requests?.length) {
1140
+ obj.requests = message.requests.map((e) => exports.CheckActionRequest.toJSON(e));
1141
+ }
1142
+ return obj;
1143
+ },
1144
+ create(base) {
1145
+ return exports.BatchCheckRequest.fromPartial(base ?? {});
1146
+ },
1147
+ fromPartial(object) {
1148
+ const message = createBaseBatchCheckRequest();
1149
+ message.requests = object.requests?.map((e) => exports.CheckActionRequest.fromPartial(e)) || [];
1150
+ return message;
1151
+ },
1152
+ };
1153
+ function createBaseBatchCheckResponse() {
1154
+ return { responses: [] };
1155
+ }
1156
+ exports.BatchCheckResponse = {
1157
+ encode(message, writer = new wire_1.BinaryWriter()) {
1158
+ for (const v of message.responses) {
1159
+ exports.CheckActionResponse.encode(v, writer.uint32(10).fork()).join();
1160
+ }
1161
+ return writer;
1162
+ },
1163
+ decode(input, length) {
1164
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
1165
+ const end = length === undefined ? reader.len : reader.pos + length;
1166
+ const message = createBaseBatchCheckResponse();
1167
+ while (reader.pos < end) {
1168
+ const tag = reader.uint32();
1169
+ switch (tag >>> 3) {
1170
+ case 1: {
1171
+ if (tag !== 10) {
1172
+ break;
1173
+ }
1174
+ message.responses.push(exports.CheckActionResponse.decode(reader, reader.uint32()));
1175
+ continue;
1176
+ }
1177
+ }
1178
+ if ((tag & 7) === 4 || tag === 0) {
1179
+ break;
1180
+ }
1181
+ reader.skip(tag & 7);
1182
+ }
1183
+ return message;
1184
+ },
1185
+ fromJSON(object) {
1186
+ return {
1187
+ responses: globalThis.Array.isArray(object?.responses)
1188
+ ? object.responses.map((e) => exports.CheckActionResponse.fromJSON(e))
1189
+ : [],
1190
+ };
1191
+ },
1192
+ toJSON(message) {
1193
+ const obj = {};
1194
+ if (message.responses?.length) {
1195
+ obj.responses = message.responses.map((e) => exports.CheckActionResponse.toJSON(e));
1196
+ }
1197
+ return obj;
1198
+ },
1199
+ create(base) {
1200
+ return exports.BatchCheckResponse.fromPartial(base ?? {});
1201
+ },
1202
+ fromPartial(object) {
1203
+ const message = createBaseBatchCheckResponse();
1204
+ message.responses = object.responses?.map((e) => exports.CheckActionResponse.fromPartial(e)) || [];
1205
+ return message;
1206
+ },
1207
+ };
1208
+ function createBaseOpControlSubscribeRequest() {
1209
+ return { agentId: undefined };
1210
+ }
1211
+ exports.OpControlSubscribeRequest = {
1212
+ encode(message, writer = new wire_1.BinaryWriter()) {
1213
+ if (message.agentId !== undefined) {
1214
+ common_js_1.AgentId.encode(message.agentId, writer.uint32(10).fork()).join();
1215
+ }
1216
+ return writer;
1217
+ },
1218
+ decode(input, length) {
1219
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
1220
+ const end = length === undefined ? reader.len : reader.pos + length;
1221
+ const message = createBaseOpControlSubscribeRequest();
1222
+ while (reader.pos < end) {
1223
+ const tag = reader.uint32();
1224
+ switch (tag >>> 3) {
1225
+ case 1: {
1226
+ if (tag !== 10) {
1227
+ break;
1228
+ }
1229
+ message.agentId = common_js_1.AgentId.decode(reader, reader.uint32());
1230
+ continue;
1231
+ }
1232
+ }
1233
+ if ((tag & 7) === 4 || tag === 0) {
1234
+ break;
1235
+ }
1236
+ reader.skip(tag & 7);
1237
+ }
1238
+ return message;
1239
+ },
1240
+ fromJSON(object) {
1241
+ return {
1242
+ agentId: isSet(object.agentId)
1243
+ ? common_js_1.AgentId.fromJSON(object.agentId)
1244
+ : isSet(object.agent_id)
1245
+ ? common_js_1.AgentId.fromJSON(object.agent_id)
1246
+ : undefined,
1247
+ };
1248
+ },
1249
+ toJSON(message) {
1250
+ const obj = {};
1251
+ if (message.agentId !== undefined) {
1252
+ obj.agentId = common_js_1.AgentId.toJSON(message.agentId);
1253
+ }
1254
+ return obj;
1255
+ },
1256
+ create(base) {
1257
+ return exports.OpControlSubscribeRequest.fromPartial(base ?? {});
1258
+ },
1259
+ fromPartial(object) {
1260
+ const message = createBaseOpControlSubscribeRequest();
1261
+ message.agentId = (object.agentId !== undefined && object.agentId !== null)
1262
+ ? common_js_1.AgentId.fromPartial(object.agentId)
1263
+ : undefined;
1264
+ return message;
1265
+ },
1266
+ };
1267
+ function createBaseOpControlMessage() {
1268
+ return { opId: "", signal: 0, sequence: 0 };
1269
+ }
1270
+ exports.OpControlMessage = {
1271
+ encode(message, writer = new wire_1.BinaryWriter()) {
1272
+ if (message.opId !== "") {
1273
+ writer.uint32(10).string(message.opId);
1274
+ }
1275
+ if (message.signal !== 0) {
1276
+ writer.uint32(16).int32(message.signal);
1277
+ }
1278
+ if (message.sequence !== 0) {
1279
+ writer.uint32(24).uint64(message.sequence);
1280
+ }
1281
+ return writer;
1282
+ },
1283
+ decode(input, length) {
1284
+ const reader = input instanceof wire_1.BinaryReader ? input : new wire_1.BinaryReader(input);
1285
+ const end = length === undefined ? reader.len : reader.pos + length;
1286
+ const message = createBaseOpControlMessage();
1287
+ while (reader.pos < end) {
1288
+ const tag = reader.uint32();
1289
+ switch (tag >>> 3) {
1290
+ case 1: {
1291
+ if (tag !== 10) {
1292
+ break;
1293
+ }
1294
+ message.opId = reader.string();
1295
+ continue;
1296
+ }
1297
+ case 2: {
1298
+ if (tag !== 16) {
1299
+ break;
1300
+ }
1301
+ message.signal = reader.int32();
1302
+ continue;
1303
+ }
1304
+ case 3: {
1305
+ if (tag !== 24) {
1306
+ break;
1307
+ }
1308
+ message.sequence = longToNumber(reader.uint64());
1309
+ continue;
1310
+ }
1311
+ }
1312
+ if ((tag & 7) === 4 || tag === 0) {
1313
+ break;
1314
+ }
1315
+ reader.skip(tag & 7);
1316
+ }
1317
+ return message;
1318
+ },
1319
+ fromJSON(object) {
1320
+ return {
1321
+ opId: isSet(object.opId)
1322
+ ? globalThis.String(object.opId)
1323
+ : isSet(object.op_id)
1324
+ ? globalThis.String(object.op_id)
1325
+ : "",
1326
+ signal: isSet(object.signal) ? opControlSignalFromJSON(object.signal) : 0,
1327
+ sequence: isSet(object.sequence) ? globalThis.Number(object.sequence) : 0,
1328
+ };
1329
+ },
1330
+ toJSON(message) {
1331
+ const obj = {};
1332
+ if (message.opId !== "") {
1333
+ obj.opId = message.opId;
1334
+ }
1335
+ if (message.signal !== 0) {
1336
+ obj.signal = opControlSignalToJSON(message.signal);
1337
+ }
1338
+ if (message.sequence !== 0) {
1339
+ obj.sequence = Math.round(message.sequence);
1340
+ }
1341
+ return obj;
1342
+ },
1343
+ create(base) {
1344
+ return exports.OpControlMessage.fromPartial(base ?? {});
1345
+ },
1346
+ fromPartial(object) {
1347
+ const message = createBaseOpControlMessage();
1348
+ message.opId = object.opId ?? "";
1349
+ message.signal = object.signal ?? 0;
1350
+ message.sequence = object.sequence ?? 0;
1351
+ return message;
1352
+ },
1353
+ };
1354
+ exports.PolicyServiceService = {
1355
+ /**
1356
+ * CheckAction evaluates a single action before the agent dispatches it.
1357
+ * Called on every intercepted action — must be as fast as possible.
1358
+ */
1359
+ checkAction: {
1360
+ path: "/assembly.policy.v1.PolicyService/CheckAction",
1361
+ requestStream: false,
1362
+ responseStream: false,
1363
+ requestSerialize: (value) => Buffer.from(exports.CheckActionRequest.encode(value).finish()),
1364
+ requestDeserialize: (value) => exports.CheckActionRequest.decode(value),
1365
+ responseSerialize: (value) => Buffer.from(exports.CheckActionResponse.encode(value).finish()),
1366
+ responseDeserialize: (value) => exports.CheckActionResponse.decode(value),
1367
+ },
1368
+ /**
1369
+ * BatchCheck pre-warms the policy cache for a set of anticipated actions.
1370
+ * Called at agent startup or when entering a new task context.
1371
+ */
1372
+ batchCheck: {
1373
+ path: "/assembly.policy.v1.PolicyService/BatchCheck",
1374
+ requestStream: false,
1375
+ responseStream: false,
1376
+ requestSerialize: (value) => Buffer.from(exports.BatchCheckRequest.encode(value).finish()),
1377
+ requestDeserialize: (value) => exports.BatchCheckRequest.decode(value),
1378
+ responseSerialize: (value) => Buffer.from(exports.BatchCheckResponse.encode(value).finish()),
1379
+ responseDeserialize: (value) => exports.BatchCheckResponse.decode(value),
1380
+ },
1381
+ /**
1382
+ * OpControlStream is the gateway → SDK push channel for op-lifecycle
1383
+ * signals (pause / resume / terminate). The SDK opens the stream once
1384
+ * per agent process at startup; the gateway pushes one OpControlMessage
1385
+ * per OpsRegistry transition matching the subscriber's agent_id. See
1386
+ * AAASM-1653 (PR-D of AAASM-1422); SDK-side consumers ship in PR-E
1387
+ * (Python), PR-F (Node), and PR-G (Go).
1388
+ */
1389
+ opControlStream: {
1390
+ path: "/assembly.policy.v1.PolicyService/OpControlStream",
1391
+ requestStream: false,
1392
+ responseStream: true,
1393
+ requestSerialize: (value) => Buffer.from(exports.OpControlSubscribeRequest.encode(value).finish()),
1394
+ requestDeserialize: (value) => exports.OpControlSubscribeRequest.decode(value),
1395
+ responseSerialize: (value) => Buffer.from(exports.OpControlMessage.encode(value).finish()),
1396
+ responseDeserialize: (value) => exports.OpControlMessage.decode(value),
1397
+ },
1398
+ };
1399
+ exports.PolicyServiceClient = (0, grpc_js_1.makeGenericClientConstructor)(exports.PolicyServiceService, "assembly.policy.v1.PolicyService");
1400
+ function bytesFromBase64(b64) {
1401
+ return Uint8Array.from(globalThis.Buffer.from(b64, "base64"));
1402
+ }
1403
+ function base64FromBytes(arr) {
1404
+ return globalThis.Buffer.from(arr).toString("base64");
1405
+ }
1406
+ function longToNumber(int64) {
1407
+ const num = globalThis.Number(int64.toString());
1408
+ if (num > globalThis.Number.MAX_SAFE_INTEGER) {
1409
+ throw new globalThis.Error("Value is larger than Number.MAX_SAFE_INTEGER");
1410
+ }
1411
+ if (num < globalThis.Number.MIN_SAFE_INTEGER) {
1412
+ throw new globalThis.Error("Value is smaller than Number.MIN_SAFE_INTEGER");
1413
+ }
1414
+ return num;
1415
+ }
1416
+ function isSet(value) {
1417
+ return value !== null && value !== undefined;
1418
+ }