@mochabug/adapt-core 1.0.1-rc.2 → 1.0.1-rc.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,108 +1,173 @@
1
1
  # @mochabug/adapt-core
2
2
 
3
- Low-level client for Adapt. REST API + WebSocket subscriptions.
3
+ Headless client for Adapt automations. No UI just the automation lifecycle.
4
4
 
5
5
  ```bash
6
6
  npm install @mochabug/adapt-core
7
7
  ```
8
8
 
9
- ## Start a session
9
+ **CDN** (UMD from `@mochabug/adapt-web`):
10
10
 
11
- ```typescript
12
- import { startSession, stopSession } from '@mochabug/adapt-core';
11
+ ```html
12
+ <script src="https://cdn.mochabug.com/adapt/web/__VERSION__/adapt-core.min.js"></script>
13
+ ```
13
14
 
14
- const { token } = await startSession({ id: 'auto-123' }, authToken);
15
+ ## Quick start
15
16
 
16
- // later
17
- await stopSession('auto-123', token);
18
- ```
17
+ ### Browser
19
18
 
20
- ## Start with specific transmitter and signals
19
+ ```typescript
20
+ import { createConnectClient } from "@mochabug/adapt-core/connect";
21
+ import { createAdaptClient } from "@mochabug/adapt-core";
22
+
23
+ const client = createAdaptClient(
24
+ createConnectClient({ id: "my-automation" }),
25
+ "my-automation",
26
+ );
27
+
28
+ const { sessionToken } = await client.run({
29
+ onSession: (session) => console.log("Status:", session.status),
30
+ onOutput: (output) => console.log("Output:", output.data),
31
+ onUrl: (url) => console.log("URL:", url.url),
32
+ onError: (error) => console.error("Error:", error),
33
+ });
34
+ ```
21
35
 
22
- For automations with multiple transmitters or when you need to pass initial data:
36
+ ### Node.js
23
37
 
24
38
  ```typescript
25
- import { startSession, type SignalDataJson } from '@mochabug/adapt-core';
26
-
27
- // Start from a specific transmitter
28
- const { token } = await startSession({
29
- id: 'auto-123',
30
- transmitter: 'my-transmitter'
31
- }, authToken);
32
-
33
- // Start with initial signals
34
- const signals: { [key: string]: SignalDataJson } = {
35
- 'input': {
36
- mimeType: 'text/plain',
37
- data: btoa('Hello World') // base64 encoded
38
- },
39
- 'file': {
40
- mimeType: 'application/pdf',
41
- filename: 'document.pdf',
42
- data: base64FileContent
43
- }
44
- };
39
+ import { createGrpcClient } from "@mochabug/adapt-core/grpc";
40
+ import { createAdaptClient } from "@mochabug/adapt-core";
45
41
 
46
- const { token } = await startSession({
47
- id: 'auto-123',
48
- transmitter: 'file-processor',
49
- signals
50
- }, authToken);
42
+ const client = createAdaptClient(
43
+ createGrpcClient(),
44
+ "my-automation",
45
+ );
51
46
  ```
52
47
 
53
- ## Inherit existing session
48
+ ## Configuration
54
49
 
55
50
  ```typescript
56
- import { inheritSession } from '@mochabug/adapt-core';
51
+ import { configure } from "@mochabug/adapt-core";
57
52
 
58
- const { token } = await inheritSession('auto-123', inheritToken);
53
+ configure({
54
+ webUrl: "https://adapt.mochabugapis.com/v1/automations", // default
55
+ grpcUrl: "https://adapt-grpc.mochabugapis.com", // default
56
+ });
59
57
  ```
60
58
 
61
- ## Real-time updates
59
+ ## Run an automation
60
+
61
+ `run()` starts a session and subscribes to real-time updates in a single RPC call.
62
62
 
63
63
  ```typescript
64
- import { PubsubClient } from '@mochabug/adapt-core';
64
+ const { sessionToken, expiresAt } = await client.run({
65
+ challengeToken, // proof-of-work token (if required)
66
+ transmitter: "start", // optional starting transmitter
67
+ signals: { // optional input signals
68
+ query: "hello",
69
+ file: { mimeType: "application/pdf", data: pdfBytes, filename: "doc.pdf" },
70
+ },
71
+ authToken, // for protected automations
72
+ onSession: (s) => { /* { status, fork? } */ },
73
+ onOutput: (o) => { /* { vertex, fork, data, created } */ },
74
+ onUrl: (u) => { /* { url, vertex, done, stopped, created, token, fork } */ },
75
+ onError: (e) => { /* non-retriable stream error */ },
76
+ });
77
+ ```
65
78
 
66
- const pubsub = new PubsubClient();
79
+ ## Inherit a session
67
80
 
68
- await pubsub.subscribe({
69
- id: 'auto-123',
70
- sessionToken: token,
71
- onUrl: (url) => console.log('url:', url),
72
- onSession: (session) => console.log('status:', session.status),
73
- onOutput: (output) => console.log('output:', output)
81
+ ```typescript
82
+ const { sessionToken } = await client.runInherit(parentToken, {
83
+ onSession: (s) => {},
84
+ onOutput: (o) => {},
85
+ });
86
+ ```
87
+
88
+ ## Start without subscribing
89
+
90
+ ```typescript
91
+ const { sessionToken, expiresAt } = await client.start({
92
+ challengeToken,
93
+ transmitter: "start",
94
+ signals: { input: "data" },
95
+ });
96
+
97
+ await client.subscribe(sessionToken, {
98
+ onSession: (s) => {},
99
+ onOutput: (o) => {},
74
100
  });
75
101
 
76
- await pubsub.unsubscribe();
102
+ await client.stop(sessionToken);
103
+ await client.unsubscribe();
77
104
  ```
78
105
 
79
- ## Other API calls
106
+ ## Read data
80
107
 
81
108
  ```typescript
82
- import { getSession, readOutput, readUrls } from '@mochabug/adapt-core';
109
+ const session = await client.getSession(sessionToken);
83
110
 
84
- const session = await getSession('auto-123', token);
85
- const output = await readOutput('auto-123', token, { pageSize: 100 });
86
- const urls = await readUrls('auto-123', token);
111
+ const { outputs, nextPageCursor } = await client.readOutput(sessionToken, {
112
+ pageSize: 100,
113
+ vertex: "output-vertex",
114
+ newerThan: new Date("2025-01-01"),
115
+ });
116
+
117
+ const { urls } = await client.readUrls(sessionToken, {
118
+ pageSize: 50,
119
+ });
120
+ ```
121
+
122
+ ## Headless + Cap (UMD)
123
+
124
+ Load the headless client and Cap widget together for proof-of-work in non-UI scenarios:
125
+
126
+ ```html
127
+ <script src="https://cdn.mochabug.com/adapt/web/__VERSION__/adapt-core.min.js"></script>
128
+ <script src="https://cdn.mochabug.com/adapt/web/__VERSION__/adapt-web.cap.min.js"></script>
129
+ <script>
130
+ // Both scripts merge into MbAdapt
131
+ var client = MbAdapt.createAdaptClient(
132
+ MbAdapt.createConnectClient({ id: "my-automation" }),
133
+ "my-automation"
134
+ );
135
+
136
+ // Show Cap widget, then run with the token
137
+ var cap = new MbAdapt.Cap({
138
+ container: "cap-container",
139
+ automationId: "my-automation",
140
+ client: MbAdapt.createConnectClient({ id: "my-automation" }),
141
+ onSolve: function (token) {
142
+ client.run({ challengeToken: token });
143
+ },
144
+ });
145
+ </script>
87
146
  ```
88
147
 
89
148
  ## Error handling
90
149
 
91
150
  ```typescript
92
- import { RestClientError } from '@mochabug/adapt-core';
151
+ import { ConnectError, Code } from "@mochabug/adapt-core";
93
152
 
94
153
  try {
95
- await startSession({ id: 'auto-123' });
154
+ await client.run();
96
155
  } catch (e) {
97
- if (e instanceof RestClientError) {
98
- console.error(e.status, e.statusText);
156
+ if (e instanceof ConnectError) {
157
+ console.error(e.code, e.message); // e.g. Code.NotFound
99
158
  }
100
159
  }
101
160
  ```
102
161
 
103
- ## Retry behavior
162
+ Retriable errors (network failures, server overload) are retried automatically with exponential backoff. Non-retriable errors (`NotFound`, `PermissionDenied`, `Unauthenticated`, `InvalidArgument`, `FailedPrecondition`, `ResourceExhausted`) are thrown immediately.
163
+
164
+ ## Entry points
104
165
 
105
- All REST calls retry automatically on 429, 502, 503, 504. Max 5 attempts, exponential backoff.
166
+ | Export | Description |
167
+ |--------|-------------|
168
+ | `@mochabug/adapt-core` | Client, types, configuration |
169
+ | `@mochabug/adapt-core/connect` | `createConnectClient` — browser transport |
170
+ | `@mochabug/adapt-core/grpc` | `createGrpcClient` — Node.js transport |
106
171
 
107
172
  ## License
108
173
 
@@ -20,7 +20,7 @@ import { file_mochabugapis_adapt_graph_signal_data } from "../../graph/signal_da
20
20
  /**
21
21
  * Describes the file mochabugapis/adapt/automations/v1/automations.proto.
22
22
  */
23
- export const file_mochabugapis_adapt_automations_v1_automations = /*@__PURE__*/ fileDesc("CjNtb2NoYWJ1Z2FwaXMvYWRhcHQvYXV0b21hdGlvbnMvdjEvYXV0b21hdGlvbnMucHJvdG8SIW1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MSIwChZDcmVhdGVDaGFsbGVuZ2VSZXF1ZXN0EhYKAmlkGAEgASgJQgq6SAdyBRABGPQDIqIBChdDcmVhdGVDaGFsbGVuZ2VSZXNwb25zZRINCgVjb3VudBgBIAEoDRIMCgRzaXplGAIgASgNEhIKCmRpZmZpY3VsdHkYAyABKA0SKwoHZXhwaXJlcxgEIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXASDQoFdG9rZW4YBSABKAkSGgoSdmVyaWZpY2F0aW9uX3Rva2VuGAYgASgJIngKFlJlZGVlbUNoYWxsZW5nZVJlcXVlc3QSFgoCaWQYASABKAlCCrpIB3IFEAEY9AMSJgoSdmVyaWZpY2F0aW9uX3Rva2VuGAIgASgJQgq6SAdyBRABGNAPEh4KCXNvbHV0aW9ucxgDIAMoA0ILukgIkgEFCAEQ6AciVQoXUmVkZWVtQ2hhbGxlbmdlUmVzcG9uc2USDQoFdG9rZW4YASABKAkSKwoHZXhwaXJlcxgCIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXAiLwoVSW5oZXJpdFNlc3Npb25SZXF1ZXN0EhYKAmlkGAEgASgJQgq6SAdyBRABGPQDImUKFkluaGVyaXRTZXNzaW9uUmVzcG9uc2USDQoFdG9rZW4YASABKAkSMAoHZXhwaXJlcxgCIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXBIAIgBAUIKCghfZXhwaXJlcyKvAQoRUmVhZE91dHB1dFJlcXVlc3QSFgoCaWQYASABKAlCCrpIB3IFEAEY9AMSGgoJcGFnZV9zaXplGAIgASgNQge6SAQqAhhkEikKBnZlcnRleBgDIAEoCUIUukgRcg8yDV5bMC05YS16XXs0fSRIAIgBARIhCgpuZXdlcl90aGFuGAQgASgJQgi6SAVyA7ABAUgBiAEBQgkKB192ZXJ0ZXhCDQoLX25ld2VyX3RoYW4iywEKElJlYWRPdXRwdXRSZXNwb25zZRI7CgdzZXNzaW9uGAEgASgLMioubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlNlc3Npb24SOgoHb3V0cHV0cxgCIAMoCzIpLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5PdXRwdXQSJwoQbmV4dF9wYWdlX2N1cnNvchgDIAEoCUIIukgFcgOwAQFIAIgBAUITChFfbmV4dF9wYWdlX2N1cnNvciJ3Cg9SZWFkVXJsc1JlcXVlc3QSFgoCaWQYASABKAlCCrpIB3IFEAEY9AMSGgoJcGFnZV9zaXplGAIgASgNQge6SAQqAhhkEiEKCm5ld2VyX3RoYW4YAyABKAlCCLpIBXIDsAEBSACIAQFCDQoLX25ld2VyX3RoYW4iwwEKEFJlYWRVcmxzUmVzcG9uc2USOwoHc2Vzc2lvbhgBIAEoCzIqLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5TZXNzaW9uEjQKBHVybHMYAiADKAsyJi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuVXJsEicKEG5leHRfcGFnZV9jdXJzb3IYAyABKAlCCLpIBXIDsAEBSACIAQFCEwoRX25leHRfcGFnZV9jdXJzb3IikQMKE1N0YXJ0U2Vzc2lvblJlcXVlc3QSFgoCaWQYASABKAlCCrpIB3IFEAEY9AMSOwoLdHJhbnNtaXR0ZXIYAiABKAlCIbpIHnIcEAEYZDIWXlthLXpBLVowLTlfLV17MSwxMDB9JEgAiAEBEoABCgdzaWduYWxzGAMgAygLMkMubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlN0YXJ0U2Vzc2lvblJlcXVlc3QuU2lnbmFsc0VudHJ5Qiq6SCeaASQiInIgEAEYZDIaXltfJGEtekEtWl1bXyRhLXpBLVowLTldKiQSKAoPY2hhbGxlbmdlX3Rva2VuGAQgASgJQgq6SAdyBRABGPQDSAGIAQEaVAoMU2lnbmFsc0VudHJ5EgsKA2tleRgBIAEoCRIzCgV2YWx1ZRgCIAEoCzIkLm1vY2hhYnVnYXBpcy5hZGFwdC5ncmFwaC5TaWduYWxEYXRhOgI4AUIOCgxfdHJhbnNtaXR0ZXJCEgoQX2NoYWxsZW5nZV90b2tlbiJjChRTdGFydFNlc3Npb25SZXNwb25zZRINCgV0b2tlbhgBIAEoCRIwCgdleHBpcmVzGAIgASgLMhouZ29vZ2xlLnByb3RvYnVmLlRpbWVzdGFtcEgAiAEBQgoKCF9leHBpcmVzIlIKElN0b3BTZXNzaW9uUmVxdWVzdBIWCgJpZBgBIAEoCUIKukgHcgUQARj0AxIbCgRmb3JrGAIgASgJQgi6SAVyAxjoB0gAiAEBQgcKBV9mb3JrIhUKE1N0b3BTZXNzaW9uUmVzcG9uc2UiKwoRR2V0U2Vzc2lvblJlcXVlc3QSFgoCaWQYASABKAlCCrpIB3IFEAEY9AMiWQoSR2V0U2Vzc2lvblJlc3BvbnNlEkMKB3Nlc3Npb24YASABKAsyKi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuU2Vzc2lvbkIGukgDyAEBIukBCgZPdXRwdXQSDgoGdmVydGV4GAEgASgJEgwKBGZvcmsYAiABKAkSQQoEZGF0YRgDIAMoCzIzLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5PdXRwdXQuRGF0YUVudHJ5EisKB2NyZWF0ZWQYBCABKAsyGi5nb29nbGUucHJvdG9idWYuVGltZXN0YW1wGlEKCURhdGFFbnRyeRILCgNrZXkYASABKAkSMwoFdmFsdWUYAiABKAsyJC5tb2NoYWJ1Z2FwaXMuYWRhcHQuZ3JhcGguU2lnbmFsRGF0YToCOAEiiwEKA1VybBILCgN1cmwYASABKAkSDAoEZm9yaxgCIAEoCRIOCgZ2ZXJ0ZXgYAyABKAkSDAoEZG9uZRgEIAEoCBIrCgdjcmVhdGVkGAUgASgLMhouZ29vZ2xlLnByb3RvYnVmLlRpbWVzdGFtcBINCgV0b2tlbhgGIAEoCRIPCgdzdG9wcGVkGAcgASgIIlIKB1Nlc3Npb24SDAoEZm9yaxgBIAEoCRI5CgZzdGF0dXMYAiABKA4yKS5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuU3RhdHVzIi4KFFN0cmVhbVNlc3Npb25SZXF1ZXN0EhYKAmlkGAEgASgJQgq6SAdyBRABGPQDIkkKEUFja01lc3NhZ2VSZXF1ZXN0EhYKAmlkGAEgASgJQgq6SAdyBRABGPQDEhwKCm1lc3NhZ2VfaWQYAiABKAlCCLpIBXIDsAEBIhQKEkFja01lc3NhZ2VSZXNwb25zZSLrAQoVU3RyZWFtU2Vzc2lvblJlc3BvbnNlEhQKAmlkGAEgASgJQgi6SAVyA7ABARI7CgZvdXRwdXQYAiABKAsyKS5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuT3V0cHV0SAASNQoDdXJsGAMgASgLMiYubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlVybEgAEj0KB3Nlc3Npb24YBCABKAsyKi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuU2Vzc2lvbkgAQgkKB21lc3NhZ2UijAMKEVJ1blNlc3Npb25SZXF1ZXN0EhYKAmlkGAEgASgJQgq6SAdyBRABGPQDEjsKC3RyYW5zbWl0dGVyGAIgASgJQiG6SB5yHBABGGQyFl5bYS16QS1aMC05Xy1dezEsMTAwfSRIAIgBARJ+CgdzaWduYWxzGAMgAygLMkEubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlJ1blNlc3Npb25SZXF1ZXN0LlNpZ25hbHNFbnRyeUIqukgnmgEkIiJyIBABGGQyGl5bXyRhLXpBLVpdW18kYS16QS1aMC05XSokEigKD2NoYWxsZW5nZV90b2tlbhgEIAEoCUIKukgHcgUQARj0A0gBiAEBGlQKDFNpZ25hbHNFbnRyeRILCgNrZXkYASABKAkSMwoFdmFsdWUYAiABKAsyJC5tb2NoYWJ1Z2FwaXMuYWRhcHQuZ3JhcGguU2lnbmFsRGF0YToCOAFCDgoMX3RyYW5zbWl0dGVyQhIKEF9jaGFsbGVuZ2VfdG9rZW4isQIKElJ1blNlc3Npb25SZXNwb25zZRIUCgJpZBgBIAEoCUIIukgFcgOwAQESRwoHc3RhcnRlZBgCIAEoCzI0Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SdW5TZXNzaW9uU3RhcnRlZEgAEjsKBm91dHB1dBgDIAEoCzIpLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5PdXRwdXRIABI1CgN1cmwYBCABKAsyJi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuVXJsSAASPQoHc2Vzc2lvbhgFIAEoCzIqLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5TZXNzaW9uSABCCQoHbWVzc2FnZSJgChFSdW5TZXNzaW9uU3RhcnRlZBINCgV0b2tlbhgBIAEoCRIwCgdleHBpcmVzGAIgASgLMhouZ29vZ2xlLnByb3RvYnVmLlRpbWVzdGFtcEgAiAEBQgoKCF9leHBpcmVzIisKEVJ1bkluaGVyaXRSZXF1ZXN0EhYKAmlkGAEgASgJQgq6SAdyBRABGPQDIrMCChJSdW5Jbmhlcml0UmVzcG9uc2USFAoCaWQYASABKAlCCLpIBXIDsAEBEkkKCWluaGVyaXRlZBgCIAEoCzI0Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SdW5Jbmhlcml0U3RhcnRlZEgAEjsKBm91dHB1dBgDIAEoCzIpLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5PdXRwdXRIABI1CgN1cmwYBCABKAsyJi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuVXJsSAASPQoHc2Vzc2lvbhgFIAEoCzIqLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5TZXNzaW9uSABCCQoHbWVzc2FnZSJgChFSdW5Jbmhlcml0U3RhcnRlZBINCgV0b2tlbhgBIAEoCRIwCgdleHBpcmVzGAIgASgLMhouZ29vZ2xlLnByb3RvYnVmLlRpbWVzdGFtcEgAiAEBQgoKCF9leHBpcmVzKsgBCgZTdGF0dXMSFgoSU1RBVFVTX1VOU1BFQ0lGSUVEEAASEgoOU1RBVFVTX1JVTk5JTkcQARISCg5TVEFUVVNfU1RPUFBFRBACEhMKD1NUQVRVU19TVE9QUElORxADEhQKEFNUQVRVU19DT01QTEVURUQQBBISCg5TVEFUVVNfRVhQSVJFRBAFEhIKDlNUQVRVU19FUlJPUkVEEAYSFQoRU1RBVFVTX0RFTEVHQVRJTkcQBxIUChBTVEFUVVNfREVMRUdBVEVEEAgyyBEKEUF1dG9tYXRpb25TZXJ2aWNlErMBCg9DcmVhdGVDaGFsbGVuZ2USOS5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuQ3JlYXRlQ2hhbGxlbmdlUmVxdWVzdBo6Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5DcmVhdGVDaGFsbGVuZ2VSZXNwb25zZSIpgtPkkwIjOgEqIh4vdjEvYXV0b21hdGlvbnMve2lkfS9jaGFsbGVuZ2USugEKD1JlZGVlbUNoYWxsZW5nZRI5Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SZWRlZW1DaGFsbGVuZ2VSZXF1ZXN0GjoubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlJlZGVlbUNoYWxsZW5nZVJlc3BvbnNlIjCC0+STAio6ASoiJS92MS9hdXRvbWF0aW9ucy97aWR9L2NoYWxsZW5nZS9yZWRlZW0SrgEKDFN0YXJ0U2Vzc2lvbhI2Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5TdGFydFNlc3Npb25SZXF1ZXN0GjcubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlN0YXJ0U2Vzc2lvblJlc3BvbnNlIi2C0+STAic6ASoiIi92MS9hdXRvbWF0aW9ucy97aWR9L3Nlc3Npb24vc3RhcnQSogEKC1N0b3BTZXNzaW9uEjUubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlN0b3BTZXNzaW9uUmVxdWVzdBo2Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5TdG9wU2Vzc2lvblJlc3BvbnNlIiSC0+STAh4qHC92MS9hdXRvbWF0aW9ucy97aWR9L3Nlc3Npb24StgEKDkluaGVyaXRTZXNzaW9uEjgubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLkluaGVyaXRTZXNzaW9uUmVxdWVzdBo5Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5Jbmhlcml0U2Vzc2lvblJlc3BvbnNlIi+C0+STAik6ASoiJC92MS9hdXRvbWF0aW9ucy97aWR9L3Nlc3Npb24vaW5oZXJpdBKfAQoKR2V0U2Vzc2lvbhI0Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5HZXRTZXNzaW9uUmVxdWVzdBo1Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5HZXRTZXNzaW9uUmVzcG9uc2UiJILT5JMCHhIcL3YxL2F1dG9tYXRpb25zL3tpZH0vc2Vzc2lvbhKmAQoKUmVhZE91dHB1dBI0Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SZWFkT3V0cHV0UmVxdWVzdBo1Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SZWFkT3V0cHV0UmVzcG9uc2UiK4LT5JMCJRIjL3YxL2F1dG9tYXRpb25zL3tpZH0vc2Vzc2lvbi9vdXRwdXQSngEKCFJlYWRVcmxzEjIubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlJlYWRVcmxzUmVxdWVzdBozLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SZWFkVXJsc1Jlc3BvbnNlIimC0+STAiMSIS92MS9hdXRvbWF0aW9ucy97aWR9L3Nlc3Npb24vdXJscxKxAQoNU3RyZWFtU2Vzc2lvbhI3Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5TdHJlYW1TZXNzaW9uUmVxdWVzdBo4Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5TdHJlYW1TZXNzaW9uUmVzcG9uc2UiK4LT5JMCJRIjL3YxL2F1dG9tYXRpb25zL3tpZH0vc2Vzc2lvbi9zdHJlYW0wARKmAQoKQWNrTWVzc2FnZRI0Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5BY2tNZXNzYWdlUmVxdWVzdBo1Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5BY2tNZXNzYWdlUmVzcG9uc2UiK4LT5JMCJToBKiIgL3YxL2F1dG9tYXRpb25zL3tpZH0vc2Vzc2lvbi9hY2sSqAEKClJ1blNlc3Npb24SNC5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuUnVuU2Vzc2lvblJlcXVlc3QaNS5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuUnVuU2Vzc2lvblJlc3BvbnNlIiuC0+STAiU6ASoiIC92MS9hdXRvbWF0aW9ucy97aWR9L3Nlc3Npb24vcnVuMAESsAEKClJ1bkluaGVyaXQSNC5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuUnVuSW5oZXJpdFJlcXVlc3QaNS5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuUnVuSW5oZXJpdFJlc3BvbnNlIjOC0+STAi06ASoiKC92MS9hdXRvbWF0aW9ucy97aWR9L3Nlc3Npb24vcnVuLWluaGVyaXQwARqJAcpBFmFkYXB0Lm1vY2hhYnVnYXBpcy5jb23SQW1odHRwczovL3d3dy5tb2NoYWJ1Z2FwaXMuY29tL2F1dGgvYWRhcHQuYXV0b21hdGlvbnMsaHR0cHM6Ly93d3cubW9jaGFidWdhcGlzLmNvbS9hdXRoL2FkYXB0LmF1dG9tYXRpb25zLnN0YXJ0YgZwcm90bzM", [file_buf_validate_validate, file_google_api_annotations, file_google_api_client, file_google_protobuf_timestamp, file_mochabugapis_adapt_graph_signal_data]);
23
+ export const file_mochabugapis_adapt_automations_v1_automations = /*@__PURE__*/ fileDesc("CjNtb2NoYWJ1Z2FwaXMvYWRhcHQvYXV0b21hdGlvbnMvdjEvYXV0b21hdGlvbnMucHJvdG8SIW1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MSIwChZDcmVhdGVDaGFsbGVuZ2VSZXF1ZXN0EhYKAmlkGAEgASgJQgq6SAdyBRABGPQDIqIBChdDcmVhdGVDaGFsbGVuZ2VSZXNwb25zZRINCgVjb3VudBgBIAEoDRIMCgRzaXplGAIgASgNEhIKCmRpZmZpY3VsdHkYAyABKA0SKwoHZXhwaXJlcxgEIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXASDQoFdG9rZW4YBSABKAkSGgoSdmVyaWZpY2F0aW9uX3Rva2VuGAYgASgJIngKFlJlZGVlbUNoYWxsZW5nZVJlcXVlc3QSFgoCaWQYASABKAlCCrpIB3IFEAEY9AMSJgoSdmVyaWZpY2F0aW9uX3Rva2VuGAIgASgJQgq6SAdyBRABGNAPEh4KCXNvbHV0aW9ucxgDIAMoA0ILukgIkgEFCAEQ6AciVQoXUmVkZWVtQ2hhbGxlbmdlUmVzcG9uc2USDQoFdG9rZW4YASABKAkSKwoHZXhwaXJlcxgCIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXAiLwoVSW5oZXJpdFNlc3Npb25SZXF1ZXN0EhYKAmlkGAEgASgJQgq6SAdyBRABGPQDImUKFkluaGVyaXRTZXNzaW9uUmVzcG9uc2USDQoFdG9rZW4YASABKAkSMAoHZXhwaXJlcxgCIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXBIAIgBAUIKCghfZXhwaXJlcyKvAQoRUmVhZE91dHB1dFJlcXVlc3QSFgoCaWQYASABKAlCCrpIB3IFEAEY9AMSGgoJcGFnZV9zaXplGAIgASgNQge6SAQqAhhkEikKBnZlcnRleBgDIAEoCUIUukgRcg8yDV5bMC05YS16XXs0fSRIAIgBARIhCgpuZXdlcl90aGFuGAQgASgJQgi6SAVyA7ABAUgBiAEBQgkKB192ZXJ0ZXhCDQoLX25ld2VyX3RoYW4iywEKElJlYWRPdXRwdXRSZXNwb25zZRI7CgdzZXNzaW9uGAEgASgLMioubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlNlc3Npb24SOgoHb3V0cHV0cxgCIAMoCzIpLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5PdXRwdXQSJwoQbmV4dF9wYWdlX2N1cnNvchgDIAEoCUIIukgFcgOwAQFIAIgBAUITChFfbmV4dF9wYWdlX2N1cnNvciJ3Cg9SZWFkVXJsc1JlcXVlc3QSFgoCaWQYASABKAlCCrpIB3IFEAEY9AMSGgoJcGFnZV9zaXplGAIgASgNQge6SAQqAhhkEiEKCm5ld2VyX3RoYW4YAyABKAlCCLpIBXIDsAEBSACIAQFCDQoLX25ld2VyX3RoYW4iwwEKEFJlYWRVcmxzUmVzcG9uc2USOwoHc2Vzc2lvbhgBIAEoCzIqLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5TZXNzaW9uEjQKBHVybHMYAiADKAsyJi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuVXJsEicKEG5leHRfcGFnZV9jdXJzb3IYAyABKAlCCLpIBXIDsAEBSACIAQFCEwoRX25leHRfcGFnZV9jdXJzb3IikQMKE1N0YXJ0U2Vzc2lvblJlcXVlc3QSFgoCaWQYASABKAlCCrpIB3IFEAEY9AMSOwoLdHJhbnNtaXR0ZXIYAiABKAlCIbpIHnIcEAEYZDIWXlthLXpBLVowLTlfLV17MSwxMDB9JEgAiAEBEoABCgdzaWduYWxzGAMgAygLMkMubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlN0YXJ0U2Vzc2lvblJlcXVlc3QuU2lnbmFsc0VudHJ5Qiq6SCeaASQiInIgEAEYZDIaXltfJGEtekEtWl1bXyRhLXpBLVowLTldKiQSKAoPY2hhbGxlbmdlX3Rva2VuGAQgASgJQgq6SAdyBRABGPQDSAGIAQEaVAoMU2lnbmFsc0VudHJ5EgsKA2tleRgBIAEoCRIzCgV2YWx1ZRgCIAEoCzIkLm1vY2hhYnVnYXBpcy5hZGFwdC5ncmFwaC5TaWduYWxEYXRhOgI4AUIOCgxfdHJhbnNtaXR0ZXJCEgoQX2NoYWxsZW5nZV90b2tlbiJjChRTdGFydFNlc3Npb25SZXNwb25zZRINCgV0b2tlbhgBIAEoCRIwCgdleHBpcmVzGAIgASgLMhouZ29vZ2xlLnByb3RvYnVmLlRpbWVzdGFtcEgAiAEBQgoKCF9leHBpcmVzIlIKElN0b3BTZXNzaW9uUmVxdWVzdBIWCgJpZBgBIAEoCUIKukgHcgUQARj0AxIbCgRmb3JrGAIgASgJQgi6SAVyAxjoB0gAiAEBQgcKBV9mb3JrIhUKE1N0b3BTZXNzaW9uUmVzcG9uc2UiKwoRR2V0U2Vzc2lvblJlcXVlc3QSFgoCaWQYASABKAlCCrpIB3IFEAEY9AMiWQoSR2V0U2Vzc2lvblJlc3BvbnNlEkMKB3Nlc3Npb24YASABKAsyKi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuU2Vzc2lvbkIGukgDyAEBIukBCgZPdXRwdXQSDgoGdmVydGV4GAEgASgJEgwKBGZvcmsYAiABKAkSQQoEZGF0YRgDIAMoCzIzLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5PdXRwdXQuRGF0YUVudHJ5EisKB2NyZWF0ZWQYBCABKAsyGi5nb29nbGUucHJvdG9idWYuVGltZXN0YW1wGlEKCURhdGFFbnRyeRILCgNrZXkYASABKAkSMwoFdmFsdWUYAiABKAsyJC5tb2NoYWJ1Z2FwaXMuYWRhcHQuZ3JhcGguU2lnbmFsRGF0YToCOAEiCwoJVXJsUmV0YWluIjwKCFVybENsb3NlEhwKD3RpbWVvdXRfc2Vjb25kcxgBIAEoBUgAiAEBQhIKEF90aW1lb3V0X3NlY29uZHMiDAoKVXJsUmVjeWNsZSLvAgoDVXJsEgsKA3VybBgBIAEoCRIMCgRmb3JrGAIgASgJEg4KBnZlcnRleBgDIAEoCRIMCgRkb25lGAQgASgIEisKB2NyZWF0ZWQYBSABKAsyGi5nb29nbGUucHJvdG9idWYuVGltZXN0YW1wEg0KBXRva2VuGAYgASgJEg8KB3N0b3BwZWQYByABKAgSDgoGc291cmNlGAggASgJEj4KBnJldGFpbhgJIAEoCzIsLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5VcmxSZXRhaW5IABI8CgVjbG9zZRgKIAEoCzIrLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5VcmxDbG9zZUgAEkAKB3JlY3ljbGUYCyABKAsyLS5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuVXJsUmVjeWNsZUgAQhIKEHJldGVudGlvbl9wb2xpY3kiUgoHU2Vzc2lvbhIMCgRmb3JrGAEgASgJEjkKBnN0YXR1cxgCIAEoDjIpLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5TdGF0dXMiLgoUU3RyZWFtU2Vzc2lvblJlcXVlc3QSFgoCaWQYASABKAlCCrpIB3IFEAEY9AMiSQoRQWNrTWVzc2FnZVJlcXVlc3QSFgoCaWQYASABKAlCCrpIB3IFEAEY9AMSHAoKbWVzc2FnZV9pZBgCIAEoCUIIukgFcgOwAQEiFAoSQWNrTWVzc2FnZVJlc3BvbnNlIhIKEFJlY29ubmVjdE1lc3NhZ2Ui6wEKFVN0cmVhbVNlc3Npb25SZXNwb25zZRIUCgJpZBgBIAEoCUIIukgFcgOwAQESOwoGb3V0cHV0GAIgASgLMikubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLk91dHB1dEgAEjUKA3VybBgDIAEoCzImLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5VcmxIABI9CgdzZXNzaW9uGAQgASgLMioubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlNlc3Npb25IAEIJCgdtZXNzYWdlIowDChFSdW5TZXNzaW9uUmVxdWVzdBIWCgJpZBgBIAEoCUIKukgHcgUQARj0AxI7Cgt0cmFuc21pdHRlchgCIAEoCUIhukgechwQARhkMhZeW2EtekEtWjAtOV8tXXsxLDEwMH0kSACIAQESfgoHc2lnbmFscxgDIAMoCzJBLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SdW5TZXNzaW9uUmVxdWVzdC5TaWduYWxzRW50cnlCKrpIJ5oBJCIiciAQARhkMhpeW18kYS16QS1aXVtfJGEtekEtWjAtOV0qJBIoCg9jaGFsbGVuZ2VfdG9rZW4YBCABKAlCCrpIB3IFEAEY9ANIAYgBARpUCgxTaWduYWxzRW50cnkSCwoDa2V5GAEgASgJEjMKBXZhbHVlGAIgASgLMiQubW9jaGFidWdhcGlzLmFkYXB0LmdyYXBoLlNpZ25hbERhdGE6AjgBQg4KDF90cmFuc21pdHRlckISChBfY2hhbGxlbmdlX3Rva2VuIrECChJSdW5TZXNzaW9uUmVzcG9uc2USFAoCaWQYASABKAlCCLpIBXIDsAEBEkcKB3N0YXJ0ZWQYAiABKAsyNC5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuUnVuU2Vzc2lvblN0YXJ0ZWRIABI7CgZvdXRwdXQYAyABKAsyKS5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuT3V0cHV0SAASNQoDdXJsGAQgASgLMiYubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlVybEgAEj0KB3Nlc3Npb24YBSABKAsyKi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuU2Vzc2lvbkgAQgkKB21lc3NhZ2UiYAoRUnVuU2Vzc2lvblN0YXJ0ZWQSDQoFdG9rZW4YASABKAkSMAoHZXhwaXJlcxgCIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXBIAIgBAUIKCghfZXhwaXJlcyIrChFSdW5Jbmhlcml0UmVxdWVzdBIWCgJpZBgBIAEoCUIKukgHcgUQARj0AyKzAgoSUnVuSW5oZXJpdFJlc3BvbnNlEhQKAmlkGAEgASgJQgi6SAVyA7ABARJJCglpbmhlcml0ZWQYAiABKAsyNC5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuUnVuSW5oZXJpdFN0YXJ0ZWRIABI7CgZvdXRwdXQYAyABKAsyKS5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuT3V0cHV0SAASNQoDdXJsGAQgASgLMiYubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlVybEgAEj0KB3Nlc3Npb24YBSABKAsyKi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuU2Vzc2lvbkgAQgkKB21lc3NhZ2UiYAoRUnVuSW5oZXJpdFN0YXJ0ZWQSDQoFdG9rZW4YASABKAkSMAoHZXhwaXJlcxgCIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXBIAIgBAUIKCghfZXhwaXJlcyItChNXYXRjaFNlc3Npb25SZXF1ZXN0EhYKAmlkGAEgASgJQgq6SAdyBRABGPQDIrQCChRXYXRjaFNlc3Npb25SZXNwb25zZRIUCgJpZBgBIAEoCUIIukgFcgOwAQESOwoGb3V0cHV0GAIgASgLMikubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLk91dHB1dEgAEjUKA3VybBgDIAEoCzImLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5VcmxIABI9CgdzZXNzaW9uGAQgASgLMioubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlNlc3Npb25IABJICglyZWNvbm5lY3QYBSABKAsyMy5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuUmVjb25uZWN0TWVzc2FnZUgAQgkKB21lc3NhZ2UiiAMKD1dhdGNoUnVuUmVxdWVzdBIWCgJpZBgBIAEoCUIKukgHcgUQARj0AxI7Cgt0cmFuc21pdHRlchgCIAEoCUIhukgechwQARhkMhZeW2EtekEtWjAtOV8tXXsxLDEwMH0kSACIAQESfAoHc2lnbmFscxgDIAMoCzI/Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5XYXRjaFJ1blJlcXVlc3QuU2lnbmFsc0VudHJ5Qiq6SCeaASQiInIgEAEYZDIaXltfJGEtekEtWl1bXyRhLXpBLVowLTldKiQSKAoPY2hhbGxlbmdlX3Rva2VuGAQgASgJQgq6SAdyBRABGPQDSAGIAQEaVAoMU2lnbmFsc0VudHJ5EgsKA2tleRgBIAEoCRIzCgV2YWx1ZRgCIAEoCzIkLm1vY2hhYnVnYXBpcy5hZGFwdC5ncmFwaC5TaWduYWxEYXRhOgI4AUIOCgxfdHJhbnNtaXR0ZXJCEgoQX2NoYWxsZW5nZV90b2tlbiL3AgoQV2F0Y2hSdW5SZXNwb25zZRIUCgJpZBgBIAEoCUIIukgFcgOwAQESRQoHc3RhcnRlZBgCIAEoCzIyLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5XYXRjaFJ1blN0YXJ0ZWRIABI7CgZvdXRwdXQYAyABKAsyKS5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuT3V0cHV0SAASNQoDdXJsGAQgASgLMiYubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlVybEgAEj0KB3Nlc3Npb24YBSABKAsyKi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuU2Vzc2lvbkgAEkgKCXJlY29ubmVjdBgGIAEoCzIzLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SZWNvbm5lY3RNZXNzYWdlSABCCQoHbWVzc2FnZSJeCg9XYXRjaFJ1blN0YXJ0ZWQSDQoFdG9rZW4YASABKAkSMAoHZXhwaXJlcxgCIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXBIAIgBAUIKCghfZXhwaXJlcyItChNXYXRjaEluaGVyaXRSZXF1ZXN0EhYKAmlkGAEgASgJQgq6SAdyBRABGPQDIoEDChRXYXRjaEluaGVyaXRSZXNwb25zZRIUCgJpZBgBIAEoCUIIukgFcgOwAQESSwoJaW5oZXJpdGVkGAIgASgLMjYubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLldhdGNoSW5oZXJpdFN0YXJ0ZWRIABI7CgZvdXRwdXQYAyABKAsyKS5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuT3V0cHV0SAASNQoDdXJsGAQgASgLMiYubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlVybEgAEj0KB3Nlc3Npb24YBSABKAsyKi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuU2Vzc2lvbkgAEkgKCXJlY29ubmVjdBgGIAEoCzIzLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SZWNvbm5lY3RNZXNzYWdlSABCCQoHbWVzc2FnZSJiChNXYXRjaEluaGVyaXRTdGFydGVkEg0KBXRva2VuGAEgASgJEjAKB2V4cGlyZXMYAiABKAsyGi5nb29nbGUucHJvdG9idWYuVGltZXN0YW1wSACIAQFCCgoIX2V4cGlyZXMqyAEKBlN0YXR1cxIWChJTVEFUVVNfVU5TUEVDSUZJRUQQABISCg5TVEFUVVNfUlVOTklORxABEhIKDlNUQVRVU19TVE9QUEVEEAISEwoPU1RBVFVTX1NUT1BQSU5HEAMSFAoQU1RBVFVTX0NPTVBMRVRFRBAEEhIKDlNUQVRVU19FWFBJUkVEEAUSEgoOU1RBVFVTX0VSUk9SRUQQBhIVChFTVEFUVVNfREVMRUdBVElORxAHEhQKEFNUQVRVU19ERUxFR0FURUQQCDLJFQoRQXV0b21hdGlvblNlcnZpY2USswEKD0NyZWF0ZUNoYWxsZW5nZRI5Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5DcmVhdGVDaGFsbGVuZ2VSZXF1ZXN0GjoubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLkNyZWF0ZUNoYWxsZW5nZVJlc3BvbnNlIimC0+STAiM6ASoiHi92MS9hdXRvbWF0aW9ucy97aWR9L2NoYWxsZW5nZRK6AQoPUmVkZWVtQ2hhbGxlbmdlEjkubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlJlZGVlbUNoYWxsZW5nZVJlcXVlc3QaOi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuUmVkZWVtQ2hhbGxlbmdlUmVzcG9uc2UiMILT5JMCKjoBKiIlL3YxL2F1dG9tYXRpb25zL3tpZH0vY2hhbGxlbmdlL3JlZGVlbRKuAQoMU3RhcnRTZXNzaW9uEjYubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlN0YXJ0U2Vzc2lvblJlcXVlc3QaNy5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuU3RhcnRTZXNzaW9uUmVzcG9uc2UiLYLT5JMCJzoBKiIiL3YxL2F1dG9tYXRpb25zL3tpZH0vc2Vzc2lvbi9zdGFydBKiAQoLU3RvcFNlc3Npb24SNS5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuU3RvcFNlc3Npb25SZXF1ZXN0GjYubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlN0b3BTZXNzaW9uUmVzcG9uc2UiJILT5JMCHiocL3YxL2F1dG9tYXRpb25zL3tpZH0vc2Vzc2lvbhK2AQoOSW5oZXJpdFNlc3Npb24SOC5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuSW5oZXJpdFNlc3Npb25SZXF1ZXN0GjkubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLkluaGVyaXRTZXNzaW9uUmVzcG9uc2UiL4LT5JMCKToBKiIkL3YxL2F1dG9tYXRpb25zL3tpZH0vc2Vzc2lvbi9pbmhlcml0Ep8BCgpHZXRTZXNzaW9uEjQubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLkdldFNlc3Npb25SZXF1ZXN0GjUubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLkdldFNlc3Npb25SZXNwb25zZSIkgtPkkwIeEhwvdjEvYXV0b21hdGlvbnMve2lkfS9zZXNzaW9uEqYBCgpSZWFkT3V0cHV0EjQubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlJlYWRPdXRwdXRSZXF1ZXN0GjUubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlJlYWRPdXRwdXRSZXNwb25zZSIrgtPkkwIlEiMvdjEvYXV0b21hdGlvbnMve2lkfS9zZXNzaW9uL291dHB1dBKeAQoIUmVhZFVybHMSMi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuUmVhZFVybHNSZXF1ZXN0GjMubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlJlYWRVcmxzUmVzcG9uc2UiKYLT5JMCIxIhL3YxL2F1dG9tYXRpb25zL3tpZH0vc2Vzc2lvbi91cmxzErEBCg1TdHJlYW1TZXNzaW9uEjcubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlN0cmVhbVNlc3Npb25SZXF1ZXN0GjgubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLlN0cmVhbVNlc3Npb25SZXNwb25zZSIrgtPkkwIlEiMvdjEvYXV0b21hdGlvbnMve2lkfS9zZXNzaW9uL3N0cmVhbTABEqYBCgpBY2tNZXNzYWdlEjQubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLkFja01lc3NhZ2VSZXF1ZXN0GjUubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLkFja01lc3NhZ2VSZXNwb25zZSIrgtPkkwIlOgEqIiAvdjEvYXV0b21hdGlvbnMve2lkfS9zZXNzaW9uL2FjaxKoAQoKUnVuU2Vzc2lvbhI0Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SdW5TZXNzaW9uUmVxdWVzdBo1Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SdW5TZXNzaW9uUmVzcG9uc2UiK4LT5JMCJToBKiIgL3YxL2F1dG9tYXRpb25zL3tpZH0vc2Vzc2lvbi9ydW4wARKwAQoKUnVuSW5oZXJpdBI0Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SdW5Jbmhlcml0UmVxdWVzdBo1Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5SdW5Jbmhlcml0UmVzcG9uc2UiM4LT5JMCLToBKiIoL3YxL2F1dG9tYXRpb25zL3tpZH0vc2Vzc2lvbi9ydW4taW5oZXJpdDABEqgBCgxXYXRjaFNlc3Npb24SNi5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuV2F0Y2hTZXNzaW9uUmVxdWVzdBo3Lm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5XYXRjaFNlc3Npb25SZXNwb25zZSIlgtPkkwIfOgEqIhovdjEvYXV0b21hdGlvbnMve2lkfS93YXRjaDABEqABCghXYXRjaFJ1bhIyLm1vY2hhYnVnYXBpcy5hZGFwdC5hdXRvbWF0aW9ucy52MS5XYXRjaFJ1blJlcXVlc3QaMy5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuV2F0Y2hSdW5SZXNwb25zZSIpgtPkkwIjOgEqIh4vdjEvYXV0b21hdGlvbnMve2lkfS93YXRjaC1ydW4wARKwAQoMV2F0Y2hJbmhlcml0EjYubW9jaGFidWdhcGlzLmFkYXB0LmF1dG9tYXRpb25zLnYxLldhdGNoSW5oZXJpdFJlcXVlc3QaNy5tb2NoYWJ1Z2FwaXMuYWRhcHQuYXV0b21hdGlvbnMudjEuV2F0Y2hJbmhlcml0UmVzcG9uc2UiLYLT5JMCJzoBKiIiL3YxL2F1dG9tYXRpb25zL3tpZH0vd2F0Y2gtaW5oZXJpdDABGokBykEWYWRhcHQubW9jaGFidWdhcGlzLmNvbdJBbWh0dHBzOi8vd3d3Lm1vY2hhYnVnYXBpcy5jb20vYXV0aC9hZGFwdC5hdXRvbWF0aW9ucyxodHRwczovL3d3dy5tb2NoYWJ1Z2FwaXMuY29tL2F1dGgvYWRhcHQuYXV0b21hdGlvbnMuc3RhcnRiBnByb3RvMw", [file_buf_validate_validate, file_google_api_annotations, file_google_api_client, file_google_protobuf_timestamp, file_mochabugapis_adapt_graph_signal_data]);
24
24
  /**
25
25
  * Describes the message mochabugapis.adapt.automations.v1.CreateChallengeRequest.
26
26
  * Use `create(CreateChallengeRequestSchema)` to create a new message.
@@ -106,66 +106,126 @@ export const GetSessionResponseSchema = /*@__PURE__*/ messageDesc(file_mochabuga
106
106
  * Use `create(OutputSchema)` to create a new message.
107
107
  */
108
108
  export const OutputSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 16);
109
+ /**
110
+ * Describes the message mochabugapis.adapt.automations.v1.UrlRetain.
111
+ * Use `create(UrlRetainSchema)` to create a new message.
112
+ */
113
+ export const UrlRetainSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 17);
114
+ /**
115
+ * Describes the message mochabugapis.adapt.automations.v1.UrlClose.
116
+ * Use `create(UrlCloseSchema)` to create a new message.
117
+ */
118
+ export const UrlCloseSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 18);
119
+ /**
120
+ * Describes the message mochabugapis.adapt.automations.v1.UrlRecycle.
121
+ * Use `create(UrlRecycleSchema)` to create a new message.
122
+ */
123
+ export const UrlRecycleSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 19);
109
124
  /**
110
125
  * Describes the message mochabugapis.adapt.automations.v1.Url.
111
126
  * Use `create(UrlSchema)` to create a new message.
112
127
  */
113
- export const UrlSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 17);
128
+ export const UrlSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 20);
114
129
  /**
115
130
  * Describes the message mochabugapis.adapt.automations.v1.Session.
116
131
  * Use `create(SessionSchema)` to create a new message.
117
132
  */
118
- export const SessionSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 18);
133
+ export const SessionSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 21);
119
134
  /**
120
135
  * Describes the message mochabugapis.adapt.automations.v1.StreamSessionRequest.
121
136
  * Use `create(StreamSessionRequestSchema)` to create a new message.
122
137
  */
123
- export const StreamSessionRequestSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 19);
138
+ export const StreamSessionRequestSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 22);
124
139
  /**
125
140
  * Describes the message mochabugapis.adapt.automations.v1.AckMessageRequest.
126
141
  * Use `create(AckMessageRequestSchema)` to create a new message.
127
142
  */
128
- export const AckMessageRequestSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 20);
143
+ export const AckMessageRequestSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 23);
129
144
  /**
130
145
  * Describes the message mochabugapis.adapt.automations.v1.AckMessageResponse.
131
146
  * Use `create(AckMessageResponseSchema)` to create a new message.
132
147
  */
133
- export const AckMessageResponseSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 21);
148
+ export const AckMessageResponseSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 24);
149
+ /**
150
+ * Describes the message mochabugapis.adapt.automations.v1.ReconnectMessage.
151
+ * Use `create(ReconnectMessageSchema)` to create a new message.
152
+ */
153
+ export const ReconnectMessageSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 25);
134
154
  /**
135
155
  * Describes the message mochabugapis.adapt.automations.v1.StreamSessionResponse.
136
156
  * Use `create(StreamSessionResponseSchema)` to create a new message.
137
157
  */
138
- export const StreamSessionResponseSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 22);
158
+ export const StreamSessionResponseSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 26);
139
159
  /**
140
160
  * Describes the message mochabugapis.adapt.automations.v1.RunSessionRequest.
141
161
  * Use `create(RunSessionRequestSchema)` to create a new message.
142
162
  */
143
- export const RunSessionRequestSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 23);
163
+ export const RunSessionRequestSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 27);
144
164
  /**
145
165
  * Describes the message mochabugapis.adapt.automations.v1.RunSessionResponse.
146
166
  * Use `create(RunSessionResponseSchema)` to create a new message.
147
167
  */
148
- export const RunSessionResponseSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 24);
168
+ export const RunSessionResponseSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 28);
149
169
  /**
150
170
  * Describes the message mochabugapis.adapt.automations.v1.RunSessionStarted.
151
171
  * Use `create(RunSessionStartedSchema)` to create a new message.
152
172
  */
153
- export const RunSessionStartedSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 25);
173
+ export const RunSessionStartedSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 29);
154
174
  /**
155
175
  * Describes the message mochabugapis.adapt.automations.v1.RunInheritRequest.
156
176
  * Use `create(RunInheritRequestSchema)` to create a new message.
157
177
  */
158
- export const RunInheritRequestSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 26);
178
+ export const RunInheritRequestSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 30);
159
179
  /**
160
180
  * Describes the message mochabugapis.adapt.automations.v1.RunInheritResponse.
161
181
  * Use `create(RunInheritResponseSchema)` to create a new message.
162
182
  */
163
- export const RunInheritResponseSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 27);
183
+ export const RunInheritResponseSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 31);
164
184
  /**
165
185
  * Describes the message mochabugapis.adapt.automations.v1.RunInheritStarted.
166
186
  * Use `create(RunInheritStartedSchema)` to create a new message.
167
187
  */
168
- export const RunInheritStartedSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 28);
188
+ export const RunInheritStartedSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 32);
189
+ /**
190
+ * Describes the message mochabugapis.adapt.automations.v1.WatchSessionRequest.
191
+ * Use `create(WatchSessionRequestSchema)` to create a new message.
192
+ */
193
+ export const WatchSessionRequestSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 33);
194
+ /**
195
+ * Describes the message mochabugapis.adapt.automations.v1.WatchSessionResponse.
196
+ * Use `create(WatchSessionResponseSchema)` to create a new message.
197
+ */
198
+ export const WatchSessionResponseSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 34);
199
+ /**
200
+ * Describes the message mochabugapis.adapt.automations.v1.WatchRunRequest.
201
+ * Use `create(WatchRunRequestSchema)` to create a new message.
202
+ */
203
+ export const WatchRunRequestSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 35);
204
+ /**
205
+ * Describes the message mochabugapis.adapt.automations.v1.WatchRunResponse.
206
+ * Use `create(WatchRunResponseSchema)` to create a new message.
207
+ */
208
+ export const WatchRunResponseSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 36);
209
+ /**
210
+ * Describes the message mochabugapis.adapt.automations.v1.WatchRunStarted.
211
+ * Use `create(WatchRunStartedSchema)` to create a new message.
212
+ */
213
+ export const WatchRunStartedSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 37);
214
+ /**
215
+ * Describes the message mochabugapis.adapt.automations.v1.WatchInheritRequest.
216
+ * Use `create(WatchInheritRequestSchema)` to create a new message.
217
+ */
218
+ export const WatchInheritRequestSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 38);
219
+ /**
220
+ * Describes the message mochabugapis.adapt.automations.v1.WatchInheritResponse.
221
+ * Use `create(WatchInheritResponseSchema)` to create a new message.
222
+ */
223
+ export const WatchInheritResponseSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 39);
224
+ /**
225
+ * Describes the message mochabugapis.adapt.automations.v1.WatchInheritStarted.
226
+ * Use `create(WatchInheritStartedSchema)` to create a new message.
227
+ */
228
+ export const WatchInheritStartedSchema = /*@__PURE__*/ messageDesc(file_mochabugapis_adapt_automations_v1_automations, 40);
169
229
  /**
170
230
  * The session enum status
171
231
  *