mitra-interactions-sdk 1.0.56 → 1.0.58-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,540 +1,558 @@
1
- # Mitra Interactions SDK
2
-
3
- SDK para interações com a plataforma Mitra via endpoints `/interactions/`.
4
-
5
- ## Instalação
6
-
7
- ```bash
8
- npm install mitra-interactions-sdk
9
- # ou
10
- yarn add mitra-interactions-sdk
11
- # ou
12
- pnpm add mitra-interactions-sdk
13
- ```
14
-
15
- ## Configuração
16
-
17
- Antes de usar qualquer função, configure o SDK. O `token` é **opcional** — Server Functions públicas podem ser chamadas sem autenticação.
18
-
19
- > **Importante:** Quando usado, o token é um JWT de autenticação da plataforma Mitra. **Nunca deixe o token estático no código.** Utilize variáveis de ambiente para armazená-lo de forma segura.
20
-
21
- ```typescript
22
- import { configureSdkMitra } from 'mitra-interactions-sdk';
23
-
24
- // Configuração completa (com autenticação)
25
- const instance = configureSdkMitra({
26
- baseURL: process.env.MITRA_BASE_URL || 'https://api.mitra.com',
27
- token: process.env.MITRA_TOKEN!, // Opcional — necessário apenas para endpoints autenticados
28
- authUrl: 'https://coder.mitralab.io/sdk-auth/', // Opcional — necessário para login e token refresh
29
- projectId: 123, // Opcional — se informado, torna projectId opcional em TODOS os métodos
30
- integrationURL: 'https://api0.mitraecp.com:1003', // Opcional — necessário para integrações
31
- onTokenRefresh: (session) => { // Opcional chamado quando o token é renovado automaticamente
32
- localStorage.setItem('mitra_session', JSON.stringify(session));
33
- }
34
- });
35
-
36
- // Configuração mínima (sem token — apenas para Server Functions públicas)
37
- const instance = configureSdkMitra({
38
- baseURL: 'https://api.mitra.com',
39
- projectId: 123
40
- });
41
- await instance.executeServerFunction({ serverFunctionId: 42 }); // OK sem token
42
- ```
43
-
44
- > **`projectId` global:** Se você passar `projectId` no `configureSdkMitra`, ele será usado como fallback em **todos** os métodos do SDK. Assim, não é necessário passar `projectId` em cada chamada individual — basta configurar uma vez.
45
-
46
- `configureSdkMitra` retorna uma `MitraInstance` que também pode ser usada diretamente:
47
-
48
- ```typescript
49
- await instance.executeServerFunction({ serverFunctionId: 42 }); // projectId já vem do configureSdkMitra
50
- ```
51
-
52
- ## Autenticação (Login)
53
-
54
- Login via popup ou redirect seguro hospedado no domínio Mitra. Credenciais nunca passam pelo código do desenvolvedor. O SDK é **auto-configurado** após o login.
55
-
56
- > **Nota:** `authUrl` e `projectId` são **obrigatórios** para login. Porém, se já foram passados no `configureSdkMitra()`, não é necessário repeti-los — o SDK usa os valores configurados como fallback.
57
-
58
- ### Login via Popup (padrão)
59
-
60
- ```typescript
61
- import { loginMitra } from 'mitra-interactions-sdk';
62
-
63
- // Métodos disponíveis: 'email', 'google', 'microsoft', 'mitra'
64
- // Primeira vez — sem configureSdkMitra: authUrl e projectId são obrigatórios
65
- const result = await loginMitra('email', {
66
- authUrl: 'https://coder.mitralab.io/sdk-auth/',
67
- projectId: 123
68
- });
69
-
70
- // Sechamou configureSdkMitra({ authUrl, projectId }), basta:
71
- const result = await loginMitra('google');
72
- const result = await loginMitra('microsoft');
73
-
74
- // result: { token, baseURL, integrationURL? }
75
- ```
76
-
77
- ### Login Completo (method 'mitra')
78
-
79
- Abre uma tela com todas as opções (Google, Microsoft, Email) e toggle entre Login/Cadastro.
80
-
81
- ```typescript
82
- await loginMitra('mitra', {
83
- authUrl: 'https://coder.mitralab.io/sdk-auth/',
84
- projectId: 123,
85
- title: 'Meu App' // Opcional — título exibido na tela de login (default: "Mitra")
86
- });
87
- ```
88
-
89
- ### Login via Redirect
90
-
91
- Navega o usuário para a página de auth. Após o login, redireciona de volta com token nos query params.
92
-
93
- ```typescript
94
- import { loginMitra } from 'mitra-interactions-sdk';
95
-
96
- // Iniciar login — o navegador navega para fora da página
97
- await loginMitra('google', {
98
- mode: 'redirect',
99
- returnTo: '/dashboard' // Opcional — URL de retorno após login (default: página atual). Só funciona com mode 'redirect'.
100
- });
101
- ```
102
-
103
- ### Fluxo de Criar Conta
104
-
105
- ```typescript
106
- // create funciona tanto em popup quanto redirect
107
- await loginMitra('email', { create: true });
108
-
109
- await loginMitra('mitra', {
110
- mode: 'redirect',
111
- create: true, // Abre direto no modo cadastro
112
- returnTo: '/onboarding',
113
- title: 'Meu App'
114
- });
115
- ```
116
-
117
- ### Token Refresh Automático
118
-
119
- Quando qualquer requisição retorna **403**, o SDK tenta renovar o token automaticamente via iframe invisível (usa o cookie de sessão do provider). Se o refresh funcionar, a requisição é retentada com o novo token — transparente para o desenvolvedor.
120
-
121
- O callback `onTokenRefresh` é chamado após renovação bem-sucedida:
122
-
123
- ```typescript
124
- configureSdkMitra({
125
- baseURL: '...',
126
- token: '...',
127
- authUrl: 'https://coder.mitralab.io/sdk-auth/',
128
- projectId: 123,
129
- onTokenRefresh: (session) => {
130
- // Atualiza o token salvo (ex: localStorage, store, etc.)
131
- localStorage.setItem('mitra_token', session.token);
132
- }
133
- });
134
- ```
135
-
136
- ### Login por Email (iframe silencioso)
137
-
138
- Para quem precisa montar sua **própria tela de login** (sem popup/redirect), o SDK oferece funções que fazem a autenticação via iframe invisível. As credenciais são enviadas ao HTML de auth via `postMessage` — sem CORS, sem expor a API.
139
-
140
- #### emailSignupMitra
141
-
142
- Cria conta. Após sucesso, o usuário recebe um código de verificação por email.
143
-
144
- ```typescript
145
- import { emailSignupMitra } from 'mitra-interactions-sdk';
146
-
147
- await emailSignupMitra({
148
- name: 'João Silva',
149
- email: 'joao@email.com',
150
- password: 'minhasenha123'
151
- });
152
- // Não retorna token o próximo passo é verificar o código
153
- ```
154
-
155
- #### emailVerifyCodeMitra
156
-
157
- Verifica o código de 6 dígitos e faz login automático. Retorna `LoginResponse` e auto-configura o SDK.
158
-
159
- ```typescript
160
- import { emailVerifyCodeMitra } from 'mitra-interactions-sdk';
161
-
162
- const session = await emailVerifyCodeMitra({
163
- email: 'joao@email.com',
164
- code: '123456',
165
- password: 'minhasenha123' // Necessário para login automático após verificação
166
- });
167
- // session: { token, baseURL, integrationURL? }
168
- ```
169
-
170
- #### emailResendCodeMitra
171
-
172
- Reenvia o código de verificação para o email.
173
-
174
- ```typescript
175
- import { emailResendCodeMitra } from 'mitra-interactions-sdk';
176
-
177
- await emailResendCodeMitra({ email: 'joao@email.com' });
178
- ```
179
-
180
- #### emailLoginMitra
181
-
182
- Login direto com email e senha. Retorna `LoginResponse` e auto-configura o SDK.
183
-
184
- ```typescript
185
- import { emailLoginMitra } from 'mitra-interactions-sdk';
186
-
187
- const session = await emailLoginMitra({
188
- email: 'joao@email.com',
189
- password: 'minhasenha123'
190
- });
191
- // session: { token, baseURL, integrationURL? }
192
- ```
193
-
194
- #### Fluxo completo de signup com email
195
-
196
- ```typescript
197
- // 1. Criar conta
198
- await emailSignupMitra({ name: 'João', email, password });
199
-
200
- // 2. Usuário recebe código por email e digita na tela
201
- const session = await emailVerifyCodeMitra({ email, code: '123456', password });
202
-
203
- // 3. SDK já está configurado — pode chamar qualquer método
204
- await executeDbActionMitra({ dbActionId: 1 });
205
- ```
206
-
207
- > **Nota:** `authUrl` e `projectId` são opcionais em todas as funções de email se já foram configurados via `configureSdkMitra()`.
208
-
209
- ### Reset de Senha (esqueci minha senha)
210
-
211
- Endpoints públicos (sem token) para o fluxo de "esqueci minha senha":
212
-
213
- ```typescript
214
- import {
215
- sendPasswordResetCodeMitra,
216
- validatePasswordResetCodeMitra,
217
- resetPasswordMitra,
218
- emailLoginMitra
219
- } from 'mitra-interactions-sdk';
220
-
221
- // 1. Envia código de 6 dígitos por email
222
- await sendPasswordResetCodeMitra({ email });
223
-
224
- // 2. (opcional) Valida o código antes de pedir a senha nova
225
- await validatePasswordResetCodeMitra({ email, code: '123456' });
226
-
227
- // 3. Troca a senha
228
- await resetPasswordMitra({ email, code: '123456', newPassword: 'novaSenha' });
229
-
230
- // 4. Login com a nova senha
231
- await emailLoginMitra({ email, password: 'novaSenha' });
232
- ```
233
-
234
- > **Nota:** `projectId` é opcional se já configurado via `configureSdkMitra()`.
235
-
236
- ## Métodos Disponíveis
237
-
238
- ### executeServerFunctionMitra
239
-
240
- Executa uma Server Function de forma **síncrona** (timeout de 60s no backend). Retorna o resultado diretamente.
241
-
242
- ```typescript
243
- import { executeServerFunctionMitra } from 'mitra-interactions-sdk';
244
-
245
- const result = await executeServerFunctionMitra({
246
- projectId: 123,
247
- serverFunctionId: 101,
248
- input: { // Opcional - objeto de entrada para a função
249
- arg1: 'valor1'
250
- }
251
- });
252
- // result: { status, result: { executionId, executionStatus, output, logs, error, durationMs } }
253
- ```
254
-
255
- ### executeServerFunctionAsyncMitra
256
-
257
- Executa uma Server Function de forma **assíncrona**. Retorna um `executionId` imediatamente. Use `stopServerFunctionExecutionMitra` para parar ou `getServerFunctionExecutionMitra` (mitra-sdk) para consultar o resultado.
258
-
259
- ```typescript
260
- import { executeServerFunctionAsyncMitra } from 'mitra-interactions-sdk';
261
-
262
- const result = await executeServerFunctionAsyncMitra({
263
- projectId: 123,
264
- serverFunctionId: 101,
265
- input: { // Opcional - objeto de entrada para a função
266
- arg1: 'valor1'
267
- }
268
- });
269
- // result: { status, result: { executionId, executionStatus } }
270
- ```
271
-
272
- ### stopServerFunctionExecutionMitra
273
-
274
- Para a execução de uma Server Function em andamento.
275
-
276
- ```typescript
277
- import { stopServerFunctionExecutionMitra } from 'mitra-interactions-sdk';
278
-
279
- const result = await stopServerFunctionExecutionMitra({
280
- projectId: 123,
281
- executionId: 'exec-uuid-aqui'
282
- });
283
- // result: { status, result: { executionId, executionStatus: "CANCELLED" | "ALREADY_FINISHED" } }
284
- ```
285
-
286
- ### Public Server Functions (sem autenticação)
287
-
288
- Para Server Functions com `publicExecution = true`. Não requerem token.
289
-
290
- ```typescript
291
- import {
292
- executePublicServerFunctionMitra,
293
- executePublicServerFunctionAsyncMitra,
294
- getPublicServerFunctionExecutionMitra
295
- } from 'mitra-interactions-sdk';
296
-
297
- // Sync retorna resultado inline (timeout 5min)
298
- const result = await executePublicServerFunctionMitra({
299
- projectId: 123,
300
- serverFunctionId: 49,
301
- input: { param1: 'value' }
302
- });
303
- // result: { executionId, status, output, logs, error, durationMs }
304
-
305
- // Async — retorna executionId imediatamente
306
- const { executionId } = await executePublicServerFunctionAsyncMitra({
307
- projectId: 123,
308
- serverFunctionId: 50,
309
- input: { heavyParam: true }
310
- });
311
-
312
- // Polling consulta status/resultado
313
- const execution = await getPublicServerFunctionExecutionMitra({
314
- projectId: 123,
315
- executionId
316
- });
317
- // execution: { executionId, status, output, logs, error, durationMs }
318
- ```
319
-
320
- ### executeDataLoaderMitra
321
-
322
- Executa um Data Loader cadastrado no projeto.
323
-
324
- ```typescript
325
- import { executeDataLoaderMitra } from 'mitra-interactions-sdk';
326
-
327
- const result = await executeDataLoaderMitra({
328
- projectId: 123,
329
- dataLoaderId: 5,
330
- input: { mes: 1, ano: 2025 } // Opcional — parâmetros {{var}} da query
331
- });
332
- // result: { status, result: { dataLoaderId, executionLog: { timestamp, rowCount, query, status, fileSize?, duration? }, message } }
333
- ```
334
-
335
- ### uploadFilePublicMitra / uploadFileLoadableMitra
336
-
337
- Faz upload de um arquivo diretamente para a pasta PUBLIC ou LOADABLE do projeto. Usa `multipart/form-data`.
338
-
339
- ```typescript
340
- import { uploadFilePublicMitra, uploadFileLoadableMitra } from 'mitra-interactions-sdk';
341
-
342
- // Upload para PUBLIC (arquivo fica acessível publicamente via URL)
343
- const result = await uploadFilePublicMitra({
344
- projectId: 123,
345
- file: fileInput.files[0] // File ou Blob
346
- });
347
- // result: { status, result: { fileName, currentPath, publicUrl, message } }
348
-
349
- // Upload para LOADABLE (arquivo disponível para carga via Spark/ETL)
350
- const result2 = await uploadFileLoadableMitra({
351
- projectId: 123,
352
- file: myBlob
353
- });
354
- // result2: { status, result: { fileName, currentPath, publicUrl: null, message } }
355
- ```
356
-
357
- ### Dynamic Schema CRUD
358
-
359
- CRUD completo em tabelas do projeto via Dynamic Schema (usa header `X-TenantID`).
360
-
361
- Todos os endpoints suportam o parâmetro opcional `jdbcConnectionConfigId` para operar em datasources adicionais (PostgreSQL, Oracle, SQL Server, etc.) ao invés do banco principal do tenant.
362
-
363
- - `listRecordsMitra(...)` `ListRecordsResponse` `{ content, page, size, totalElements, totalPages }` - Lista registros com paginação
364
- - `getRecordMitra(...)` `Record<string, any>` - Busca registro por ID
365
- - `createRecordMitra(...)` → `Record<string, any>` - Cria registro (201)
366
- - `updateRecordMitra(...)` → `Record<string, any>` - Atualiza registro (PUT)
367
- - `patchRecordMitra(...)` → `Record<string, any>` - Atualiza parcialmente (PATCH)
368
- - `deleteRecordMitra(...)` `void` - Remove registro (204 No Content)
369
- - `createRecordsBatchMitra(...)` → `Record<string, any>[]` - Cria múltiplos registros (201)
370
-
371
- ```typescript
372
- import { listRecordsMitra, createRecordMitra, updateRecordMitra, deleteRecordMitra } from 'mitra-interactions-sdk';
373
-
374
- // Listar registros
375
- const result = await listRecordsMitra({
376
- projectId: 123,
377
- tableName: 'produtos',
378
- page: 0,
379
- size: 20
380
- });
381
-
382
- // Criar registro
383
- await createRecordMitra({
384
- projectId: 123,
385
- tableName: 'produtos',
386
- data: { nome: 'Produto A', preco: 99.90 }
387
- });
388
-
389
- // Atualizar registro
390
- await updateRecordMitra({
391
- projectId: 123,
392
- tableName: 'produtos',
393
- id: 1,
394
- data: { nome: 'Produto A Atualizado', preco: 89.90, version: 0 }
395
- });
396
-
397
- // Deletar registro
398
- await deleteRecordMitra({ projectId: 123, tableName: 'produtos', id: 1 });
399
-
400
- // Usando datasource adicional (jdbcConnectionConfigId)
401
- const result2 = await listRecordsMitra({
402
- projectId: 123,
403
- tableName: 'clientes',
404
- jdbcConnectionConfigId: 5
405
- });
406
- ```
407
-
408
- ### Profile Management
409
-
410
- Gerenciamento de perfis de acesso. Permite gestão de quem pode acessar quais recursos no projeto.
411
-
412
- #### CRUD de Perfis
413
-
414
- - `listProfilesMitra({ projectId? })` `ListProfilesResponse` - Lista todos os perfis do projeto
415
- - `getProfileDetailsMitra({ projectId?, profileId })` → `GetProfileDetailsResponse` - Detalhes de um perfil (usuários, tabelas, actions, screens, server functions)
416
- - `createProfileMitra({ projectId?, name, color?, homeScreenId? })` → `CreateProfileResponse` - Cria um novo perfil
417
- - `updateProfileMitra({ projectId?, profileId, name?, color?, homeScreenId? })` → `UpdateProfileResponse` - Atualiza um perfil existente
418
- - `deleteProfileMitra({ projectId?, profileId })` → `DeleteProfileResponse` - Deleta um perfil
419
-
420
- ```typescript
421
- import { listProfilesMitra, createProfileMitra, getProfileDetailsMitra } from 'mitra-interactions-sdk';
422
-
423
- // Listar perfis
424
- const profiles = await listProfilesMitra({ projectId: 123 });
425
- // { status, projectId, result: [{ id, name, color, homeScreenId }] }
426
-
427
- // Criar perfil
428
- const created = await createProfileMitra({ projectId: 123, name: 'Vendedores', color: '#FF5733' });
429
- // { status, result: { id, name, message } }
430
-
431
- // Detalhes do perfil
432
- const details = await getProfileDetailsMitra({ projectId: 123, profileId: 1 });
433
- // { status, projectId, result: { id, name, users, selectTables, dmlTables, actions, screens, serverFunctions } }
434
- ```
435
-
436
- #### Permissões de Perfil
437
-
438
- Define quais recursos cada perfil pode acessar. Todas substituem a lista atual (não fazem append).
439
-
440
- - `setProfileUsersMitra({ projectId?, profileId, userIds })` - Define os usuários do perfil
441
- - `setProfileSelectTablesMitra({ projectId?, profileId, jdbcConnectionConfigId?, tables })` - Define tabelas SELECT permitidas
442
- - `setProfileDmlTablesMitra({ projectId?, profileId, jdbcConnectionConfigId?, tables })` - Define tabelas DML permitidas
443
- - `setProfileActionsMitra({ projectId?, profileId, actionIds })` - Define actions permitidas
444
- - `setProfileScreensMitra({ projectId?, profileId, screenIds })` - Define screens permitidas
445
- - `setProfileServerFunctionsMitra({ projectId?, profileId, serverFunctionIds })` - Define server functions permitidas
446
-
447
- ```typescript
448
- import { setProfileUsersMitra, setProfileSelectTablesMitra, setProfileServerFunctionsMitra } from 'mitra-interactions-sdk';
449
-
450
- // Definir usuários do perfil
451
- await setProfileUsersMitra({ projectId: 123, profileId: 1, userIds: [10, 20, 30] });
452
-
453
- // Definir tabelas SELECT
454
- await setProfileSelectTablesMitra({
455
- projectId: 123,
456
- profileId: 1,
457
- jdbcConnectionConfigId: 1, // Opcional — ID da conexão JDBC (default: banco principal)
458
- tables: [
459
- { tableName: 'clientes' },
460
- { tableName: 'pedidos' }
461
- ]
462
- });
463
-
464
- // Definir server functions
465
- await setProfileServerFunctionsMitra({ projectId: 123, profileId: 1, serverFunctionIds: [5, 8, 12] });
466
- ```
467
-
468
- ## Tipos TypeScript
469
-
470
- Todos os tipos estão incluídos:
471
-
472
- ```typescript
473
- import type {
474
- MitraConfig,
475
- // Login
476
- LoginOptions,
477
- LoginResponse,
478
- // Email Auth
479
- EmailSignupOptions,
480
- EmailLoginOptions,
481
- EmailVerifyCodeOptions,
482
- EmailResendCodeOptions,
483
- // Options
484
- ExecuteServerFunctionOptions,
485
- ExecuteServerFunctionAsyncOptions,
486
- UploadFileOptions,
487
- StopServerFunctionExecutionOptions,
488
- ListRecordsOptions,
489
- GetRecordOptions,
490
- CreateRecordOptions,
491
- UpdateRecordOptions,
492
- PatchRecordOptions,
493
- DeleteRecordOptions,
494
- CreateRecordsBatchOptions,
495
- // Responses
496
- ExecuteServerFunctionResponse,
497
- ExecuteServerFunctionAsyncResponse,
498
- UploadFileResponse,
499
- StopServerFunctionExecutionResponse,
500
- ListRecordsResponse,
501
- // Profile Management
502
- ListProfilesOptions,
503
- ListProfilesResponse,
504
- GetProfileDetailsOptions,
505
- GetProfileDetailsResponse,
506
- CreateProfileOptions,
507
- CreateProfileResponse,
508
- UpdateProfileOptions,
509
- UpdateProfileResponse,
510
- DeleteProfileOptions,
511
- DeleteProfileResponse,
512
- SetProfileUsersOptions,
513
- SetProfileSelectTablesOptions,
514
- SetProfileDmlTablesOptions,
515
- SetProfileActionsOptions,
516
- SetProfileScreensOptions,
517
- SetProfileServerFunctionsOptions,
518
- ProfileTableRef,
519
- SetProfilePermissionResponse
520
- } from 'mitra-interactions-sdk';
521
- ```
522
-
523
- ## Tratamento de Erros
524
-
525
- ```typescript
526
- try {
527
- const result = await executeDbActionMitra({
528
- projectId: 123,
529
- dbActionId: 456
530
- });
531
- } catch (error) {
532
- console.log('Erro:', error.message);
533
- console.log('Status:', error.status);
534
- console.log('Detalhes:', error.details);
535
- }
536
- ```
537
-
538
- ## Licença
539
-
540
- MIT
1
+ # Mitra Interactions SDK
2
+
3
+ SDK para interações com a plataforma Mitra via endpoints `/interactions/`.
4
+
5
+ ## Permissões: `dev` vs `business`
6
+
7
+ `userType` no token de login:
8
+ - `dev` — chama tudo
9
+ - `business` — chama apenas execução (SF, Data Loader, upload), auth e chat. Outras chamadas retornam **403**.
10
+
11
+ > Não confundir com o pacote `mitra-business-sdk` (SDK separado, usado pelo agente IA).
12
+
13
+ **Bloqueado para `business`:** CRUD REST (`*RecordMitra`), Profile Management (`*ProfileMitra`, `setProfile*Mitra`), `listProjectUsersMitra`, `manageUserAccessMitra`.
14
+
15
+ > SF tipo JAVASCRIPT herda o `userType` do caller — se chamar funções bloqueadas, retorna 403 para business.
16
+
17
+ ---
18
+
19
+ ## Instalação
20
+
21
+ ```bash
22
+ npm install mitra-interactions-sdk
23
+ # ou
24
+ yarn add mitra-interactions-sdk
25
+ # ou
26
+ pnpm add mitra-interactions-sdk
27
+ ```
28
+
29
+ ## Configuração
30
+
31
+ Antes de usar qualquer função, configure o SDK. O `token` é **opcional** — Server Functions públicas podem ser chamadas sem autenticação.
32
+
33
+ > **Importante:** Quando usado, o token é um JWT de autenticação da plataforma Mitra. **Nunca deixe o token estático no código.** Utilize variáveis de ambiente para armazená-lo de forma segura.
34
+
35
+ ```typescript
36
+ import { configureSdkMitra } from 'mitra-interactions-sdk';
37
+
38
+ // Configuração completa (com autenticação)
39
+ const instance = configureSdkMitra({
40
+ baseURL: process.env.MITRA_BASE_URL || 'https://api.mitra.com',
41
+ token: process.env.MITRA_TOKEN!, // Opcional necessário apenas para endpoints autenticados
42
+ authUrl: 'https://coder.mitralab.io/sdk-auth/', // Opcional — necessário para login e token refresh
43
+ projectId: 123, // Opcional — se informado, torna projectId opcional em TODOS os métodos
44
+ integrationURL: 'https://api0.mitraecp.com:1003', // Opcional necessário para integrações
45
+ onTokenRefresh: (session) => { // Opcional — chamado quando o token é renovado automaticamente
46
+ localStorage.setItem('mitra_session', JSON.stringify(session));
47
+ }
48
+ });
49
+
50
+ // Configuração mínima (sem token — apenas para Server Functions públicas)
51
+ const instance = configureSdkMitra({
52
+ baseURL: 'https://api.mitra.com',
53
+ projectId: 123
54
+ });
55
+ await instance.executeServerFunction({ serverFunctionId: 42 }); // OK — sem token
56
+ ```
57
+
58
+ > **`projectId` global:** Se você passar `projectId` no `configureSdkMitra`, ele será usado como fallback em **todos** os métodos do SDK. Assim, não é necessário passar `projectId` em cada chamada individual — basta configurar uma vez.
59
+
60
+ `configureSdkMitra` retorna uma `MitraInstance` que também pode ser usada diretamente:
61
+
62
+ ```typescript
63
+ await instance.executeServerFunction({ serverFunctionId: 42 }); // projectId já vem do configureSdkMitra
64
+ ```
65
+
66
+ ## Autenticação (Login)
67
+
68
+ Login via popup ou redirect seguro hospedado no domínio Mitra. Credenciais nunca passam pelo código do desenvolvedor. O SDK é **auto-configurado** após o login.
69
+
70
+ > **Nota:** `authUrl` e `projectId` são **obrigatórios** para login. Porém, se foram passados no `configureSdkMitra()`, não é necessário repeti-los — o SDK usa os valores configurados como fallback.
71
+
72
+ ### Login via Popup (padrão)
73
+
74
+ ```typescript
75
+ import { loginMitra } from 'mitra-interactions-sdk';
76
+
77
+ // Métodos disponíveis: 'email', 'google', 'microsoft', 'mitra'
78
+ // Primeira vez — sem configureSdkMitra: authUrl e projectId são obrigatórios
79
+ const result = await loginMitra('email', {
80
+ authUrl: 'https://coder.mitralab.io/sdk-auth/',
81
+ projectId: 123
82
+ });
83
+
84
+ // Se já chamou configureSdkMitra({ authUrl, projectId }), basta:
85
+ const result = await loginMitra('google');
86
+ const result = await loginMitra('microsoft');
87
+
88
+ // result: { token, baseURL, integrationURL? }
89
+ ```
90
+
91
+ ### Login Completo (method 'mitra')
92
+
93
+ Abre uma tela com todas as opções (Google, Microsoft, Email) e toggle entre Login/Cadastro.
94
+
95
+ ```typescript
96
+ await loginMitra('mitra', {
97
+ authUrl: 'https://coder.mitralab.io/sdk-auth/',
98
+ projectId: 123,
99
+ title: 'Meu App' // Opcional — título exibido na tela de login (default: "Mitra")
100
+ });
101
+ ```
102
+
103
+ ### Login via Redirect
104
+
105
+ Navega o usuário para a página de auth. Após o login, redireciona de volta com token nos query params.
106
+
107
+ ```typescript
108
+ import { loginMitra } from 'mitra-interactions-sdk';
109
+
110
+ // Iniciar login — o navegador navega para fora da página
111
+ await loginMitra('google', {
112
+ mode: 'redirect',
113
+ returnTo: '/dashboard' // Opcional — URL de retorno após login (default: página atual). Só funciona com mode 'redirect'.
114
+ });
115
+ ```
116
+
117
+ ### Fluxo de Criar Conta
118
+
119
+ ```typescript
120
+ // create funciona tanto em popup quanto redirect
121
+ await loginMitra('email', { create: true });
122
+
123
+ await loginMitra('mitra', {
124
+ mode: 'redirect',
125
+ create: true, // Abre direto no modo cadastro
126
+ returnTo: '/onboarding',
127
+ title: 'Meu App'
128
+ });
129
+ ```
130
+
131
+ ### Token Refresh Automático
132
+
133
+ Quando qualquer requisição retorna **403**, o SDK tenta renovar o token automaticamente via iframe invisível (usa o cookie de sessão do provider). Se o refresh funcionar, a requisição é retentada com o novo token — transparente para o desenvolvedor.
134
+
135
+ O callback `onTokenRefresh` é chamado após renovação bem-sucedida:
136
+
137
+ ```typescript
138
+ configureSdkMitra({
139
+ baseURL: '...',
140
+ token: '...',
141
+ authUrl: 'https://coder.mitralab.io/sdk-auth/',
142
+ projectId: 123,
143
+ onTokenRefresh: (session) => {
144
+ // Atualiza o token salvo (ex: localStorage, store, etc.)
145
+ localStorage.setItem('mitra_token', session.token);
146
+ }
147
+ });
148
+ ```
149
+
150
+ ### Login por Email (iframe silencioso)
151
+
152
+ Para quem precisa montar sua **própria tela de login** (sem popup/redirect), o SDK oferece funções que fazem a autenticação via iframe invisível. As credenciais são enviadas ao HTML de auth via `postMessage` — sem CORS, sem expor a API.
153
+
154
+ #### emailSignupMitra
155
+
156
+ Cria conta. Após sucesso, o usuário recebe um código de verificação por email.
157
+
158
+ ```typescript
159
+ import { emailSignupMitra } from 'mitra-interactions-sdk';
160
+
161
+ await emailSignupMitra({
162
+ name: 'João Silva',
163
+ email: 'joao@email.com',
164
+ password: 'minhasenha123'
165
+ });
166
+ // Não retorna token — o próximo passo é verificar o código
167
+ ```
168
+
169
+ #### emailVerifyCodeMitra
170
+
171
+ Verifica o código de 6 dígitos e faz login automático. Retorna `LoginResponse` e auto-configura o SDK.
172
+
173
+ ```typescript
174
+ import { emailVerifyCodeMitra } from 'mitra-interactions-sdk';
175
+
176
+ const session = await emailVerifyCodeMitra({
177
+ email: 'joao@email.com',
178
+ code: '123456',
179
+ password: 'minhasenha123' // Necessário para login automático após verificação
180
+ });
181
+ // session: { token, baseURL, integrationURL? }
182
+ ```
183
+
184
+ #### emailResendCodeMitra
185
+
186
+ Reenvia o código de verificação para o email.
187
+
188
+ ```typescript
189
+ import { emailResendCodeMitra } from 'mitra-interactions-sdk';
190
+
191
+ await emailResendCodeMitra({ email: 'joao@email.com' });
192
+ ```
193
+
194
+ #### emailLoginMitra
195
+
196
+ Login direto com email e senha. Retorna `LoginResponse` e auto-configura o SDK.
197
+
198
+ ```typescript
199
+ import { emailLoginMitra } from 'mitra-interactions-sdk';
200
+
201
+ const session = await emailLoginMitra({
202
+ email: 'joao@email.com',
203
+ password: 'minhasenha123'
204
+ });
205
+ // session: { token, baseURL, integrationURL? }
206
+ ```
207
+
208
+ #### Fluxo completo de signup com email
209
+
210
+ ```typescript
211
+ // 1. Criar conta
212
+ await emailSignupMitra({ name: 'João', email, password });
213
+
214
+ // 2. Usuário recebe código por email e digita na tela
215
+ const session = await emailVerifyCodeMitra({ email, code: '123456', password });
216
+
217
+ // 3. SDK já está configurado — pode chamar qualquer método
218
+ await executeDbActionMitra({ dbActionId: 1 });
219
+ ```
220
+
221
+ > **Nota:** `authUrl` e `projectId` são opcionais em todas as funções de email se foram configurados via `configureSdkMitra()`.
222
+
223
+ ### Reset de Senha (esqueci minha senha)
224
+
225
+ Endpoints públicos (sem token) para o fluxo de "esqueci minha senha":
226
+
227
+ ```typescript
228
+ import {
229
+ sendPasswordResetCodeMitra,
230
+ validatePasswordResetCodeMitra,
231
+ resetPasswordMitra,
232
+ emailLoginMitra
233
+ } from 'mitra-interactions-sdk';
234
+
235
+ // 1. Envia código de 6 dígitos por email
236
+ await sendPasswordResetCodeMitra({ email });
237
+
238
+ // 2. (opcional) Valida o código antes de pedir a senha nova
239
+ await validatePasswordResetCodeMitra({ email, code: '123456' });
240
+
241
+ // 3. Troca a senha
242
+ await resetPasswordMitra({ email, code: '123456', newPassword: 'novaSenha' });
243
+
244
+ // 4. Login com a nova senha
245
+ await emailLoginMitra({ email, password: 'novaSenha' });
246
+ ```
247
+
248
+ > **Nota:** `projectId` é opcional se configurado via `configureSdkMitra()`.
249
+
250
+ ## Métodos Disponíveis
251
+
252
+ ### executeServerFunctionMitra
253
+
254
+ Executa uma Server Function de forma **síncrona** (timeout de 60s no backend). Retorna o resultado diretamente.
255
+
256
+ ```typescript
257
+ import { executeServerFunctionMitra } from 'mitra-interactions-sdk';
258
+
259
+ const result = await executeServerFunctionMitra({
260
+ projectId: 123,
261
+ serverFunctionId: 101,
262
+ input: { // Opcional - objeto de entrada para a função
263
+ arg1: 'valor1'
264
+ }
265
+ });
266
+ // result: { status, result: { executionId, executionStatus, output, logs, error, durationMs } }
267
+ ```
268
+
269
+ ### executeServerFunctionAsyncMitra
270
+
271
+ Executa uma Server Function de forma **assíncrona**. Retorna um `executionId` imediatamente. Use `stopServerFunctionExecutionMitra` para parar ou `getServerFunctionExecutionMitra` (mitra-sdk) para consultar o resultado.
272
+
273
+ ```typescript
274
+ import { executeServerFunctionAsyncMitra } from 'mitra-interactions-sdk';
275
+
276
+ const result = await executeServerFunctionAsyncMitra({
277
+ projectId: 123,
278
+ serverFunctionId: 101,
279
+ input: { // Opcional - objeto de entrada para a função
280
+ arg1: 'valor1'
281
+ }
282
+ });
283
+ // result: { status, result: { executionId, executionStatus } }
284
+ ```
285
+
286
+ ### stopServerFunctionExecutionMitra
287
+
288
+ Para a execução de uma Server Function em andamento.
289
+
290
+ ```typescript
291
+ import { stopServerFunctionExecutionMitra } from 'mitra-interactions-sdk';
292
+
293
+ const result = await stopServerFunctionExecutionMitra({
294
+ projectId: 123,
295
+ executionId: 'exec-uuid-aqui'
296
+ });
297
+ // result: { status, result: { executionId, executionStatus: "CANCELLED" | "ALREADY_FINISHED" } }
298
+ ```
299
+
300
+ ### Public Server Functions (sem autenticação)
301
+
302
+ Para Server Functions com `publicExecution = true`. Não requerem token.
303
+
304
+ ```typescript
305
+ import {
306
+ executePublicServerFunctionMitra,
307
+ executePublicServerFunctionAsyncMitra,
308
+ getPublicServerFunctionExecutionMitra
309
+ } from 'mitra-interactions-sdk';
310
+
311
+ // Sync — retorna resultado inline (timeout 5min)
312
+ const result = await executePublicServerFunctionMitra({
313
+ projectId: 123,
314
+ serverFunctionId: 49,
315
+ input: { param1: 'value' }
316
+ });
317
+ // result: { executionId, status, output, logs, error, durationMs }
318
+
319
+ // Async — retorna executionId imediatamente
320
+ const { executionId } = await executePublicServerFunctionAsyncMitra({
321
+ projectId: 123,
322
+ serverFunctionId: 50,
323
+ input: { heavyParam: true }
324
+ });
325
+
326
+ // Polling — consulta status/resultado
327
+ const execution = await getPublicServerFunctionExecutionMitra({
328
+ projectId: 123,
329
+ executionId
330
+ });
331
+ // execution: { executionId, status, output, logs, error, durationMs }
332
+ ```
333
+
334
+ ### executeDataLoaderMitra
335
+
336
+ Executa um Data Loader cadastrado no projeto.
337
+
338
+ ```typescript
339
+ import { executeDataLoaderMitra } from 'mitra-interactions-sdk';
340
+
341
+ const result = await executeDataLoaderMitra({
342
+ projectId: 123,
343
+ dataLoaderId: 5,
344
+ input: { mes: 1, ano: 2025 } // Opcional — parâmetros {{var}} da query
345
+ });
346
+ // result: { status, result: { dataLoaderId, executionLog: { timestamp, rowCount, query, status, fileSize?, duration? }, message } }
347
+ ```
348
+
349
+ ### uploadFilePublicMitra / uploadFileLoadableMitra
350
+
351
+ Faz upload de um arquivo diretamente para a pasta PUBLIC ou LOADABLE do projeto. Usa `multipart/form-data`.
352
+
353
+ ```typescript
354
+ import { uploadFilePublicMitra, uploadFileLoadableMitra } from 'mitra-interactions-sdk';
355
+
356
+ // Upload para PUBLIC (arquivo fica acessível publicamente via URL)
357
+ const result = await uploadFilePublicMitra({
358
+ projectId: 123,
359
+ file: fileInput.files[0] // File ou Blob
360
+ });
361
+ // result: { status, result: { fileName, currentPath, publicUrl, message } }
362
+
363
+ // Upload para LOADABLE (arquivo disponível para carga via Spark/ETL)
364
+ const result2 = await uploadFileLoadableMitra({
365
+ projectId: 123,
366
+ file: myBlob
367
+ });
368
+ // result2: { status, result: { fileName, currentPath, publicUrl: null, message } }
369
+ ```
370
+
371
+ ### Dynamic Schema CRUD
372
+
373
+ > 🔒 `userType=dev` only. Falha 403 para business. Em telas com business, envelopar em SF tipo SQL.
374
+
375
+ CRUD completo em tabelas do projeto via Dynamic Schema (usa header `X-TenantID`).
376
+
377
+ Todos os endpoints suportam o parâmetro opcional `jdbcConnectionConfigId` para operar em datasources adicionais (PostgreSQL, Oracle, SQL Server, etc.) ao invés do banco principal do tenant.
378
+
379
+ - `listRecordsMitra(...)` → `ListRecordsResponse` `{ content, page, size, totalElements, totalPages }` - Lista registros com paginação
380
+ - `getRecordMitra(...)` → `Record<string, any>` - Busca registro por ID
381
+ - `createRecordMitra(...)` → `Record<string, any>` - Cria registro (201)
382
+ - `updateRecordMitra(...)` → `Record<string, any>` - Atualiza registro (PUT)
383
+ - `patchRecordMitra(...)` → `Record<string, any>` - Atualiza parcialmente (PATCH)
384
+ - `deleteRecordMitra(...)` → `void` - Remove registro (204 No Content)
385
+ - `createRecordsBatchMitra(...)` → `Record<string, any>[]` - Cria múltiplos registros (201)
386
+
387
+ ```typescript
388
+ import { listRecordsMitra, createRecordMitra, updateRecordMitra, deleteRecordMitra } from 'mitra-interactions-sdk';
389
+
390
+ // Listar registros
391
+ const result = await listRecordsMitra({
392
+ projectId: 123,
393
+ tableName: 'produtos',
394
+ page: 0,
395
+ size: 20
396
+ });
397
+
398
+ // Criar registro
399
+ await createRecordMitra({
400
+ projectId: 123,
401
+ tableName: 'produtos',
402
+ data: { nome: 'Produto A', preco: 99.90 }
403
+ });
404
+
405
+ // Atualizar registro
406
+ await updateRecordMitra({
407
+ projectId: 123,
408
+ tableName: 'produtos',
409
+ id: 1,
410
+ data: { nome: 'Produto A Atualizado', preco: 89.90, version: 0 }
411
+ });
412
+
413
+ // Deletar registro
414
+ await deleteRecordMitra({ projectId: 123, tableName: 'produtos', id: 1 });
415
+
416
+ // Usando datasource adicional (jdbcConnectionConfigId)
417
+ const result2 = await listRecordsMitra({
418
+ projectId: 123,
419
+ tableName: 'clientes',
420
+ jdbcConnectionConfigId: 5
421
+ });
422
+ ```
423
+
424
+ ### Profile Management
425
+
426
+ > 🔒 `userType=dev` only. Falha 403 para business. Telas de perfis exigem guard de `userType`.
427
+
428
+ Gerenciamento de perfis de acesso. Permite gestão de quem pode acessar quais recursos no projeto.
429
+
430
+ #### CRUD de Perfis
431
+
432
+ - `listProfilesMitra({ projectId? })` `ListProfilesResponse` - Lista todos os perfis do projeto
433
+ - `getProfileDetailsMitra({ projectId?, profileId })` `GetProfileDetailsResponse` - Detalhes de um perfil (usuários, tabelas, actions, screens, server functions)
434
+ - `createProfileMitra({ projectId?, name, color?, homeScreenId? })` → `CreateProfileResponse` - Cria um novo perfil
435
+ - `updateProfileMitra({ projectId?, profileId, name?, color?, homeScreenId? })` → `UpdateProfileResponse` - Atualiza um perfil existente
436
+ - `deleteProfileMitra({ projectId?, profileId })` → `DeleteProfileResponse` - Deleta um perfil
437
+
438
+ ```typescript
439
+ import { listProfilesMitra, createProfileMitra, getProfileDetailsMitra } from 'mitra-interactions-sdk';
440
+
441
+ // Listar perfis
442
+ const profiles = await listProfilesMitra({ projectId: 123 });
443
+ // { status, projectId, result: [{ id, name, color, homeScreenId }] }
444
+
445
+ // Criar perfil
446
+ const created = await createProfileMitra({ projectId: 123, name: 'Vendedores', color: '#FF5733' });
447
+ // { status, result: { id, name, message } }
448
+
449
+ // Detalhes do perfil
450
+ const details = await getProfileDetailsMitra({ projectId: 123, profileId: 1 });
451
+ // { status, projectId, result: { id, name, users, selectTables, dmlTables, actions, screens, serverFunctions } }
452
+ ```
453
+
454
+ #### Permissões de Perfil
455
+
456
+ Define quais recursos cada perfil pode acessar. Todas substituem a lista atual (não fazem append).
457
+
458
+ - `setProfileUsersMitra({ projectId?, profileId, userIds })` - Define os usuários do perfil
459
+ - `setProfileSelectTablesMitra({ projectId?, profileId, jdbcConnectionConfigId?, tables })` - Define tabelas SELECT permitidas
460
+ - `setProfileDmlTablesMitra({ projectId?, profileId, jdbcConnectionConfigId?, tables })` - Define tabelas DML permitidas
461
+ - `setProfileActionsMitra({ projectId?, profileId, actionIds })` - Define actions permitidas
462
+ - `setProfileScreensMitra({ projectId?, profileId, screenIds })` - Define screens permitidas
463
+ - `setProfileServerFunctionsMitra({ projectId?, profileId, serverFunctionIds })` - Define server functions permitidas
464
+
465
+ ```typescript
466
+ import { setProfileUsersMitra, setProfileSelectTablesMitra, setProfileServerFunctionsMitra } from 'mitra-interactions-sdk';
467
+
468
+ // Definir usuários do perfil
469
+ await setProfileUsersMitra({ projectId: 123, profileId: 1, userIds: [10, 20, 30] });
470
+
471
+ // Definir tabelas SELECT
472
+ await setProfileSelectTablesMitra({
473
+ projectId: 123,
474
+ profileId: 1,
475
+ jdbcConnectionConfigId: 1, // Opcional — ID da conexão JDBC (default: banco principal)
476
+ tables: [
477
+ { tableName: 'clientes' },
478
+ { tableName: 'pedidos' }
479
+ ]
480
+ });
481
+
482
+ // Definir server functions
483
+ await setProfileServerFunctionsMitra({ projectId: 123, profileId: 1, serverFunctionIds: [5, 8, 12] });
484
+ ```
485
+
486
+ ## Tipos TypeScript
487
+
488
+ Todos os tipos estão incluídos:
489
+
490
+ ```typescript
491
+ import type {
492
+ MitraConfig,
493
+ // Login
494
+ LoginOptions,
495
+ LoginResponse,
496
+ // Email Auth
497
+ EmailSignupOptions,
498
+ EmailLoginOptions,
499
+ EmailVerifyCodeOptions,
500
+ EmailResendCodeOptions,
501
+ // Options
502
+ ExecuteServerFunctionOptions,
503
+ ExecuteServerFunctionAsyncOptions,
504
+ UploadFileOptions,
505
+ StopServerFunctionExecutionOptions,
506
+ ListRecordsOptions,
507
+ GetRecordOptions,
508
+ CreateRecordOptions,
509
+ UpdateRecordOptions,
510
+ PatchRecordOptions,
511
+ DeleteRecordOptions,
512
+ CreateRecordsBatchOptions,
513
+ // Responses
514
+ ExecuteServerFunctionResponse,
515
+ ExecuteServerFunctionAsyncResponse,
516
+ UploadFileResponse,
517
+ StopServerFunctionExecutionResponse,
518
+ ListRecordsResponse,
519
+ // Profile Management
520
+ ListProfilesOptions,
521
+ ListProfilesResponse,
522
+ GetProfileDetailsOptions,
523
+ GetProfileDetailsResponse,
524
+ CreateProfileOptions,
525
+ CreateProfileResponse,
526
+ UpdateProfileOptions,
527
+ UpdateProfileResponse,
528
+ DeleteProfileOptions,
529
+ DeleteProfileResponse,
530
+ SetProfileUsersOptions,
531
+ SetProfileSelectTablesOptions,
532
+ SetProfileDmlTablesOptions,
533
+ SetProfileActionsOptions,
534
+ SetProfileScreensOptions,
535
+ SetProfileServerFunctionsOptions,
536
+ ProfileTableRef,
537
+ SetProfilePermissionResponse
538
+ } from 'mitra-interactions-sdk';
539
+ ```
540
+
541
+ ## Tratamento de Erros
542
+
543
+ ```typescript
544
+ try {
545
+ const result = await executeDbActionMitra({
546
+ projectId: 123,
547
+ dbActionId: 456
548
+ });
549
+ } catch (error) {
550
+ console.log('Erro:', error.message);
551
+ console.log('Status:', error.status);
552
+ console.log('Detalhes:', error.details);
553
+ }
554
+ ```
555
+
556
+ ## Licença
557
+
558
+ MIT