@semacode/cli 1.5.18 → 1.5.19
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/AGENTS.md +268 -260
- package/LICENSE +22 -22
- package/README.md +144 -104
- package/SEMA_BRIEF.curto.txt +7 -5
- package/SEMA_BRIEF.md +60 -4
- package/SEMA_BRIEF.micro.txt +6 -4
- package/SEMA_INDEX.json +917 -41
- package/dist/controleComercialSupabase.d.ts +326 -0
- package/dist/controleComercialSupabase.js +310 -0
- package/dist/controleComercialSupabase.js.map +1 -0
- package/dist/docs.js +48 -20
- package/dist/docs.js.map +1 -1
- package/dist/drift.d.ts +5 -3
- package/dist/drift.js +123 -14
- package/dist/drift.js.map +1 -1
- package/dist/index.js +1889 -38
- package/dist/index.js.map +1 -1
- package/dist/mcpRemoto.d.ts +32 -0
- package/dist/mcpRemoto.js +61 -0
- package/dist/mcpRemoto.js.map +1 -0
- package/dist/projeto.js +3 -1
- package/dist/projeto.js.map +1 -1
- package/docs/AGENT_STARTER.md +103 -97
- package/docs/cli.md +175 -106
- package/docs/como-ensinar-a-sema-para-ia.md +41 -35
- package/docs/deploy.md +231 -43
- package/docs/documentacao.md +61 -36
- package/docs/env.md +105 -56
- package/docs/extensao-vscode.md +12 -4
- package/docs/fluxo-pratico-ia-sema.md +182 -176
- package/docs/instalacao-e-primeiro-uso.md +52 -30
- package/docs/integracao-com-ia.md +108 -101
- package/docs/mcp.md +292 -51
- package/docs/pagamento-ponta-a-ponta.md +34 -28
- package/docs/persistencia-vendor-first.md +11 -5
- package/docs/prompt-base-ia-sema.md +13 -7
- package/docs/rollback.md +17 -15
- package/docs/sintaxe.md +180 -174
- package/exemplos/agendamento.sema +105 -105
- package/exemplos/assinatura.sema +133 -133
- package/exemplos/auditoria.sema +89 -89
- package/exemplos/autenticacao.sema +125 -125
- package/exemplos/author_obra_comum.sema +294 -0
- package/exemplos/author_tema_sensivel.sema +264 -0
- package/exemplos/automacao.sema +107 -107
- package/exemplos/cadastro_usuario.sema +54 -54
- package/exemplos/calculadora.sema +78 -78
- package/exemplos/crud_simples.sema +89 -89
- package/exemplos/estoque.sema +127 -127
- package/exemplos/exportacao.sema +94 -94
- package/exemplos/fila.sema +130 -130
- package/exemplos/integracao_externa.sema +94 -94
- package/exemplos/multi_tenant.sema +140 -140
- package/exemplos/notificacao.sema +149 -149
- package/exemplos/operacao_estrategia.sema +633 -633
- package/exemplos/pagamento.sema +434 -434
- package/exemplos/pagamento_dominio.sema +35 -35
- package/exemplos/pedido.sema +255 -255
- package/exemplos/permissao.sema +121 -121
- package/exemplos/persistencia_vendor_first.sema +86 -86
- package/exemplos/profile_game.sema +114 -0
- package/exemplos/profile_legal.sema +105 -0
- package/exemplos/profile_ops.sema +110 -0
- package/exemplos/profile_research.sema +104 -0
- package/exemplos/profile_software.sema +123 -0
- package/exemplos/profile_workflow_n8n.sema +99 -0
- package/exemplos/relatorio.sema +93 -93
- package/exemplos/replica_analitica_erp.sema +160 -160
- package/exemplos/testes_embutidos.sema +45 -45
- package/exemplos/tratamento_erro.sema +157 -157
- package/exemplos/upload_arquivo.sema +93 -93
- package/exemplos/webhook.sema +94 -94
- package/llms-full.txt +34 -34
- package/llms.txt +17 -17
- package/node_modules/@sema/gerador-css/dist/index.js +563 -563
- package/node_modules/@sema/gerador-css/package.json +1 -1
- package/node_modules/@sema/gerador-dart/package.json +1 -1
- package/node_modules/@sema/gerador-html/dist/index.js +90 -90
- package/node_modules/@sema/gerador-html/package.json +1 -1
- package/node_modules/@sema/gerador-javascript/dist/index.js +92 -92
- package/node_modules/@sema/gerador-javascript/package.json +1 -1
- package/node_modules/@sema/gerador-lua/dist/index.js +53 -53
- package/node_modules/@sema/gerador-lua/package.json +1 -1
- package/node_modules/@sema/gerador-python/dist/index.js +122 -96
- package/node_modules/@sema/gerador-python/dist/index.js.map +1 -1
- package/node_modules/@sema/gerador-python/package.json +1 -1
- package/node_modules/@sema/gerador-typescript/dist/index.js +153 -153
- package/node_modules/@sema/gerador-typescript/package.json +1 -1
- package/node_modules/@sema/nucleo/dist/formatador/index.js +12 -4
- package/node_modules/@sema/nucleo/dist/formatador/index.js.map +1 -1
- package/node_modules/@sema/nucleo/package.json +1 -1
- package/node_modules/@sema/padroes/package.json +1 -1
- package/package.json +11 -11
|
@@ -1,35 +1,35 @@
|
|
|
1
|
-
module exemplos.pagamento.dominio {
|
|
2
|
-
docs {
|
|
3
|
-
resumo: "Contratos de dominio compartilhados pelo vertical oficial de pagamento da Sema 0.5."
|
|
4
|
-
}
|
|
5
|
-
|
|
6
|
-
entity Pagamento {
|
|
7
|
-
fields {
|
|
8
|
-
id: Id
|
|
9
|
-
valor: Decimal
|
|
10
|
-
status: StatusPagamento
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
enum StatusPagamento {
|
|
15
|
-
PENDENTE,
|
|
16
|
-
AUTORIZADO,
|
|
17
|
-
RECUSADO,
|
|
18
|
-
PROCESSADO
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
state ciclo_pagamento {
|
|
22
|
-
fields {
|
|
23
|
-
status: StatusPagamento
|
|
24
|
-
conciliado: Booleano
|
|
25
|
-
}
|
|
26
|
-
invariants {
|
|
27
|
-
status existe
|
|
28
|
-
}
|
|
29
|
-
transitions {
|
|
30
|
-
PENDENTE -> AUTORIZADO
|
|
31
|
-
AUTORIZADO -> PROCESSADO
|
|
32
|
-
PENDENTE -> RECUSADO
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
}
|
|
1
|
+
module exemplos.pagamento.dominio {
|
|
2
|
+
docs {
|
|
3
|
+
resumo: "Contratos de dominio compartilhados pelo vertical oficial de pagamento da Sema 0.5."
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
entity Pagamento {
|
|
7
|
+
fields {
|
|
8
|
+
id: Id
|
|
9
|
+
valor: Decimal
|
|
10
|
+
status: StatusPagamento
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
enum StatusPagamento {
|
|
15
|
+
PENDENTE,
|
|
16
|
+
AUTORIZADO,
|
|
17
|
+
RECUSADO,
|
|
18
|
+
PROCESSADO
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
state ciclo_pagamento {
|
|
22
|
+
fields {
|
|
23
|
+
status: StatusPagamento
|
|
24
|
+
conciliado: Booleano
|
|
25
|
+
}
|
|
26
|
+
invariants {
|
|
27
|
+
status existe
|
|
28
|
+
}
|
|
29
|
+
transitions {
|
|
30
|
+
PENDENTE -> AUTORIZADO
|
|
31
|
+
AUTORIZADO -> PROCESSADO
|
|
32
|
+
PENDENTE -> RECUSADO
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
package/exemplos/pedido.sema
CHANGED
|
@@ -1,255 +1,255 @@
|
|
|
1
|
-
module exemplos.pedido {
|
|
2
|
-
docs {
|
|
3
|
-
resumo: "Ciclo completo de pedido IA-first com dependencias explicitas para pagamento e estoque."
|
|
4
|
-
}
|
|
5
|
-
|
|
6
|
-
use exemplos.pagamento
|
|
7
|
-
use exemplos.estoque
|
|
8
|
-
|
|
9
|
-
enum StatusPedido {
|
|
10
|
-
RASCUNHO,
|
|
11
|
-
AGUARDANDO_PAGAMENTO,
|
|
12
|
-
APROVADO,
|
|
13
|
-
CANCELADO,
|
|
14
|
-
ENVIADO,
|
|
15
|
-
ENTREGUE
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
state ciclo_pedido {
|
|
19
|
-
fields {
|
|
20
|
-
status: StatusPedido
|
|
21
|
-
}
|
|
22
|
-
invariants {
|
|
23
|
-
status em [RASCUNHO, AGUARDANDO_PAGAMENTO, APROVADO, CANCELADO, ENVIADO, ENTREGUE]
|
|
24
|
-
}
|
|
25
|
-
transitions {
|
|
26
|
-
RASCUNHO -> AGUARDANDO_PAGAMENTO
|
|
27
|
-
AGUARDANDO_PAGAMENTO -> APROVADO
|
|
28
|
-
AGUARDANDO_PAGAMENTO -> CANCELADO
|
|
29
|
-
APROVADO -> CANCELADO
|
|
30
|
-
APROVADO -> ENVIADO
|
|
31
|
-
ENVIADO -> ENTREGUE
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
entity Pedido {
|
|
36
|
-
fields {
|
|
37
|
-
id: Id
|
|
38
|
-
cliente_id: Id
|
|
39
|
-
status: StatusPedido
|
|
40
|
-
total: Decimal
|
|
41
|
-
criado_em: Timestamp
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
entity ItemPedido {
|
|
46
|
-
fields {
|
|
47
|
-
id: Id
|
|
48
|
-
pedido_id: Id
|
|
49
|
-
produto_id: Id
|
|
50
|
-
quantidade: Inteiro
|
|
51
|
-
preco_unitario: Decimal
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
task criar_pedido {
|
|
56
|
-
input {
|
|
57
|
-
cliente_id: Id required
|
|
58
|
-
itens: Lista required
|
|
59
|
-
}
|
|
60
|
-
output {
|
|
61
|
-
pedido: Pedido
|
|
62
|
-
status: StatusPedido
|
|
63
|
-
}
|
|
64
|
-
authz {
|
|
65
|
-
escopo: pedidos.criar
|
|
66
|
-
tenant: obrigatorio
|
|
67
|
-
}
|
|
68
|
-
dados {
|
|
69
|
-
classificacao_padrao: interno
|
|
70
|
-
redacao_log: obrigatoria
|
|
71
|
-
input {
|
|
72
|
-
cliente_id: pii
|
|
73
|
-
itens: interno
|
|
74
|
-
}
|
|
75
|
-
output {
|
|
76
|
-
pedido: financeiro
|
|
77
|
-
status: interno
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
audit {
|
|
81
|
-
evento: pedido.criado
|
|
82
|
-
ator: auth.usuario
|
|
83
|
-
correlacao: request_id
|
|
84
|
-
retencao: "180d"
|
|
85
|
-
motivo: obrigatorio
|
|
86
|
-
}
|
|
87
|
-
forbidden {
|
|
88
|
-
shell.exec
|
|
89
|
-
log.segredo
|
|
90
|
-
retorno.credencial
|
|
91
|
-
}
|
|
92
|
-
rules {
|
|
93
|
-
itens deve_ser nao_vazio
|
|
94
|
-
cliente_id deve_ser valido
|
|
95
|
-
}
|
|
96
|
-
effects {
|
|
97
|
-
consulta Cliente por cliente_id criticidade = media
|
|
98
|
-
consulta Produto por cada item.produto_id criticidade = media
|
|
99
|
-
persistencia Pedido criticidade = alta
|
|
100
|
-
persistencia ItemPedido criticidade = alta
|
|
101
|
-
evento pedido_criado criticidade = media
|
|
102
|
-
auditoria criacao_pedido criticidade = media
|
|
103
|
-
}
|
|
104
|
-
vinculos {
|
|
105
|
-
tabela: pedidos
|
|
106
|
-
tabela: itens_pedido
|
|
107
|
-
evento: pedido_criado
|
|
108
|
-
}
|
|
109
|
-
execucao {
|
|
110
|
-
idempotencia: verdadeiro
|
|
111
|
-
timeout: "10s"
|
|
112
|
-
retry: "nenhum"
|
|
113
|
-
compensacao: "cancelar_pedido"
|
|
114
|
-
criticidade_operacional: alta
|
|
115
|
-
}
|
|
116
|
-
state ciclo_pedido {
|
|
117
|
-
transitions {
|
|
118
|
-
RASCUNHO -> AGUARDANDO_PAGAMENTO
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
guarantees {
|
|
122
|
-
pedido existe
|
|
123
|
-
status == AGUARDANDO_PAGAMENTO
|
|
124
|
-
}
|
|
125
|
-
error {
|
|
126
|
-
cliente_invalido: "Cliente nao encontrado."
|
|
127
|
-
item_invalido: "Um ou mais produtos nao existem."
|
|
128
|
-
carrinho_vazio: "O pedido deve ter ao menos um item."
|
|
129
|
-
}
|
|
130
|
-
tests {
|
|
131
|
-
caso "cria pedido valido" {
|
|
132
|
-
given {
|
|
133
|
-
cliente_id: "cli_1"
|
|
134
|
-
itens: "prod_1:2"
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
expect {
|
|
138
|
-
sucesso: verdadeiro
|
|
139
|
-
status: "AGUARDANDO_PAGAMENTO"
|
|
140
|
-
pedido: "ped_1"
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
task cancelar_pedido {
|
|
147
|
-
input {
|
|
148
|
-
pedido_id: Id required
|
|
149
|
-
status_atual: StatusPedido required
|
|
150
|
-
motivo: Texto required
|
|
151
|
-
}
|
|
152
|
-
output {
|
|
153
|
-
protocolo: Id
|
|
154
|
-
status: StatusPedido
|
|
155
|
-
}
|
|
156
|
-
authz {
|
|
157
|
-
escopo: pedidos.cancelar
|
|
158
|
-
tenant: obrigatorio
|
|
159
|
-
}
|
|
160
|
-
dados {
|
|
161
|
-
classificacao_padrao: interno
|
|
162
|
-
redacao_log: obrigatoria
|
|
163
|
-
input {
|
|
164
|
-
pedido_id: interno
|
|
165
|
-
status_atual: interno
|
|
166
|
-
motivo: interno
|
|
167
|
-
}
|
|
168
|
-
output {
|
|
169
|
-
protocolo: interno
|
|
170
|
-
status: interno
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
audit {
|
|
174
|
-
evento: pedido.cancelado
|
|
175
|
-
ator: auth.usuario
|
|
176
|
-
correlacao: request_id
|
|
177
|
-
retencao: "180d"
|
|
178
|
-
motivo: obrigatorio
|
|
179
|
-
}
|
|
180
|
-
forbidden {
|
|
181
|
-
shell.exec
|
|
182
|
-
log.segredo
|
|
183
|
-
}
|
|
184
|
-
rules {
|
|
185
|
-
pedido_id deve_ser valido
|
|
186
|
-
status_atual em [AGUARDANDO_PAGAMENTO, APROVADO]
|
|
187
|
-
motivo deve_ser preenchido
|
|
188
|
-
}
|
|
189
|
-
effects {
|
|
190
|
-
persistencia Pedido criticidade = alta
|
|
191
|
-
evento pedido_cancelado criticidade = alta
|
|
192
|
-
notificacao cliente pedido_cancelado criticidade = media
|
|
193
|
-
auditoria cancelamento_pedido criticidade = media
|
|
194
|
-
}
|
|
195
|
-
vinculos {
|
|
196
|
-
tabela: pedidos
|
|
197
|
-
evento: pedido_cancelado
|
|
198
|
-
}
|
|
199
|
-
execucao {
|
|
200
|
-
idempotencia: verdadeiro
|
|
201
|
-
timeout: "10s"
|
|
202
|
-
retry: "nenhum"
|
|
203
|
-
compensacao: "notificar_operacao"
|
|
204
|
-
criticidade_operacional: alta
|
|
205
|
-
}
|
|
206
|
-
state ciclo_pedido {
|
|
207
|
-
transitions {
|
|
208
|
-
AGUARDANDO_PAGAMENTO -> CANCELADO
|
|
209
|
-
APROVADO -> CANCELADO
|
|
210
|
-
}
|
|
211
|
-
}
|
|
212
|
-
guarantees {
|
|
213
|
-
protocolo existe
|
|
214
|
-
status == CANCELADO
|
|
215
|
-
}
|
|
216
|
-
error {
|
|
217
|
-
pedido_nao_cancelavel: "Pedido ja enviado ou entregue nao pode ser cancelado."
|
|
218
|
-
}
|
|
219
|
-
tests {
|
|
220
|
-
caso "cancela pedido pendente" {
|
|
221
|
-
given {
|
|
222
|
-
pedido_id: "ped_1"
|
|
223
|
-
status_atual: "AGUARDANDO_PAGAMENTO"
|
|
224
|
-
motivo: "Desistencia do cliente"
|
|
225
|
-
}
|
|
226
|
-
|
|
227
|
-
expect {
|
|
228
|
-
sucesso: verdadeiro
|
|
229
|
-
protocolo: "cancel_1"
|
|
230
|
-
status: "CANCELADO"
|
|
231
|
-
}
|
|
232
|
-
}
|
|
233
|
-
}
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
flow aprovacao_pedido {
|
|
237
|
-
pedido_id: Id
|
|
238
|
-
valor: Decimal
|
|
239
|
-
produto_id: Id
|
|
240
|
-
quantidade: Inteiro
|
|
241
|
-
token_pagamento: Texto
|
|
242
|
-
itens_reservados: Texto
|
|
243
|
-
status_cancelamento: StatusPedido
|
|
244
|
-
motivo_pagamento_recusado: Texto
|
|
245
|
-
motivo_estoque_insuficiente: Texto
|
|
246
|
-
etapa pagar usa processar_pagamento com pagamento_id = pedido_id, valor = valor, token = token_pagamento em_sucesso reservar em_erro cancelar_por_pagamento
|
|
247
|
-
etapa reservar usa reservar_estoque com produto_id = produto_id, quantidade = quantidade, pedido_id = pedido_id depende_de pagar em_sucesso aprovar em_erro cancelar_por_estoque
|
|
248
|
-
etapa aprovar usa criar_pedido com cliente_id = pedido_id, itens = itens_reservados depende_de reservar
|
|
249
|
-
etapa cancelar_por_pagamento usa cancelar_pedido com pedido_id = pedido_id, status_atual = status_cancelamento, motivo = motivo_pagamento_recusado depende_de pagar
|
|
250
|
-
etapa cancelar_por_estoque usa cancelar_pedido com pedido_id = pedido_id, status_atual = status_cancelamento, motivo = motivo_estoque_insuficiente depende_de reservar
|
|
251
|
-
effects {
|
|
252
|
-
auditoria fluxo_aprovacao_pedido criticidade = alta
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
}
|
|
1
|
+
module exemplos.pedido {
|
|
2
|
+
docs {
|
|
3
|
+
resumo: "Ciclo completo de pedido IA-first com dependencias explicitas para pagamento e estoque."
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
use exemplos.pagamento
|
|
7
|
+
use exemplos.estoque
|
|
8
|
+
|
|
9
|
+
enum StatusPedido {
|
|
10
|
+
RASCUNHO,
|
|
11
|
+
AGUARDANDO_PAGAMENTO,
|
|
12
|
+
APROVADO,
|
|
13
|
+
CANCELADO,
|
|
14
|
+
ENVIADO,
|
|
15
|
+
ENTREGUE
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
state ciclo_pedido {
|
|
19
|
+
fields {
|
|
20
|
+
status: StatusPedido
|
|
21
|
+
}
|
|
22
|
+
invariants {
|
|
23
|
+
status em [RASCUNHO, AGUARDANDO_PAGAMENTO, APROVADO, CANCELADO, ENVIADO, ENTREGUE]
|
|
24
|
+
}
|
|
25
|
+
transitions {
|
|
26
|
+
RASCUNHO -> AGUARDANDO_PAGAMENTO
|
|
27
|
+
AGUARDANDO_PAGAMENTO -> APROVADO
|
|
28
|
+
AGUARDANDO_PAGAMENTO -> CANCELADO
|
|
29
|
+
APROVADO -> CANCELADO
|
|
30
|
+
APROVADO -> ENVIADO
|
|
31
|
+
ENVIADO -> ENTREGUE
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
entity Pedido {
|
|
36
|
+
fields {
|
|
37
|
+
id: Id
|
|
38
|
+
cliente_id: Id
|
|
39
|
+
status: StatusPedido
|
|
40
|
+
total: Decimal
|
|
41
|
+
criado_em: Timestamp
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
entity ItemPedido {
|
|
46
|
+
fields {
|
|
47
|
+
id: Id
|
|
48
|
+
pedido_id: Id
|
|
49
|
+
produto_id: Id
|
|
50
|
+
quantidade: Inteiro
|
|
51
|
+
preco_unitario: Decimal
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
task criar_pedido {
|
|
56
|
+
input {
|
|
57
|
+
cliente_id: Id required
|
|
58
|
+
itens: Lista required
|
|
59
|
+
}
|
|
60
|
+
output {
|
|
61
|
+
pedido: Pedido
|
|
62
|
+
status: StatusPedido
|
|
63
|
+
}
|
|
64
|
+
authz {
|
|
65
|
+
escopo: pedidos.criar
|
|
66
|
+
tenant: obrigatorio
|
|
67
|
+
}
|
|
68
|
+
dados {
|
|
69
|
+
classificacao_padrao: interno
|
|
70
|
+
redacao_log: obrigatoria
|
|
71
|
+
input {
|
|
72
|
+
cliente_id: pii
|
|
73
|
+
itens: interno
|
|
74
|
+
}
|
|
75
|
+
output {
|
|
76
|
+
pedido: financeiro
|
|
77
|
+
status: interno
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
audit {
|
|
81
|
+
evento: pedido.criado
|
|
82
|
+
ator: auth.usuario
|
|
83
|
+
correlacao: request_id
|
|
84
|
+
retencao: "180d"
|
|
85
|
+
motivo: obrigatorio
|
|
86
|
+
}
|
|
87
|
+
forbidden {
|
|
88
|
+
shell.exec
|
|
89
|
+
log.segredo
|
|
90
|
+
retorno.credencial
|
|
91
|
+
}
|
|
92
|
+
rules {
|
|
93
|
+
itens deve_ser nao_vazio
|
|
94
|
+
cliente_id deve_ser valido
|
|
95
|
+
}
|
|
96
|
+
effects {
|
|
97
|
+
consulta Cliente por cliente_id criticidade = media
|
|
98
|
+
consulta Produto por cada item.produto_id criticidade = media
|
|
99
|
+
persistencia Pedido criticidade = alta
|
|
100
|
+
persistencia ItemPedido criticidade = alta
|
|
101
|
+
evento pedido_criado criticidade = media
|
|
102
|
+
auditoria criacao_pedido criticidade = media
|
|
103
|
+
}
|
|
104
|
+
vinculos {
|
|
105
|
+
tabela: pedidos
|
|
106
|
+
tabela: itens_pedido
|
|
107
|
+
evento: pedido_criado
|
|
108
|
+
}
|
|
109
|
+
execucao {
|
|
110
|
+
idempotencia: verdadeiro
|
|
111
|
+
timeout: "10s"
|
|
112
|
+
retry: "nenhum"
|
|
113
|
+
compensacao: "cancelar_pedido"
|
|
114
|
+
criticidade_operacional: alta
|
|
115
|
+
}
|
|
116
|
+
state ciclo_pedido {
|
|
117
|
+
transitions {
|
|
118
|
+
RASCUNHO -> AGUARDANDO_PAGAMENTO
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
guarantees {
|
|
122
|
+
pedido existe
|
|
123
|
+
status == AGUARDANDO_PAGAMENTO
|
|
124
|
+
}
|
|
125
|
+
error {
|
|
126
|
+
cliente_invalido: "Cliente nao encontrado."
|
|
127
|
+
item_invalido: "Um ou mais produtos nao existem."
|
|
128
|
+
carrinho_vazio: "O pedido deve ter ao menos um item."
|
|
129
|
+
}
|
|
130
|
+
tests {
|
|
131
|
+
caso "cria pedido valido" {
|
|
132
|
+
given {
|
|
133
|
+
cliente_id: "cli_1"
|
|
134
|
+
itens: "prod_1:2"
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
expect {
|
|
138
|
+
sucesso: verdadeiro
|
|
139
|
+
status: "AGUARDANDO_PAGAMENTO"
|
|
140
|
+
pedido: "ped_1"
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
task cancelar_pedido {
|
|
147
|
+
input {
|
|
148
|
+
pedido_id: Id required
|
|
149
|
+
status_atual: StatusPedido required
|
|
150
|
+
motivo: Texto required
|
|
151
|
+
}
|
|
152
|
+
output {
|
|
153
|
+
protocolo: Id
|
|
154
|
+
status: StatusPedido
|
|
155
|
+
}
|
|
156
|
+
authz {
|
|
157
|
+
escopo: pedidos.cancelar
|
|
158
|
+
tenant: obrigatorio
|
|
159
|
+
}
|
|
160
|
+
dados {
|
|
161
|
+
classificacao_padrao: interno
|
|
162
|
+
redacao_log: obrigatoria
|
|
163
|
+
input {
|
|
164
|
+
pedido_id: interno
|
|
165
|
+
status_atual: interno
|
|
166
|
+
motivo: interno
|
|
167
|
+
}
|
|
168
|
+
output {
|
|
169
|
+
protocolo: interno
|
|
170
|
+
status: interno
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
audit {
|
|
174
|
+
evento: pedido.cancelado
|
|
175
|
+
ator: auth.usuario
|
|
176
|
+
correlacao: request_id
|
|
177
|
+
retencao: "180d"
|
|
178
|
+
motivo: obrigatorio
|
|
179
|
+
}
|
|
180
|
+
forbidden {
|
|
181
|
+
shell.exec
|
|
182
|
+
log.segredo
|
|
183
|
+
}
|
|
184
|
+
rules {
|
|
185
|
+
pedido_id deve_ser valido
|
|
186
|
+
status_atual em [AGUARDANDO_PAGAMENTO, APROVADO]
|
|
187
|
+
motivo deve_ser preenchido
|
|
188
|
+
}
|
|
189
|
+
effects {
|
|
190
|
+
persistencia Pedido criticidade = alta
|
|
191
|
+
evento pedido_cancelado criticidade = alta
|
|
192
|
+
notificacao cliente pedido_cancelado criticidade = media
|
|
193
|
+
auditoria cancelamento_pedido criticidade = media
|
|
194
|
+
}
|
|
195
|
+
vinculos {
|
|
196
|
+
tabela: pedidos
|
|
197
|
+
evento: pedido_cancelado
|
|
198
|
+
}
|
|
199
|
+
execucao {
|
|
200
|
+
idempotencia: verdadeiro
|
|
201
|
+
timeout: "10s"
|
|
202
|
+
retry: "nenhum"
|
|
203
|
+
compensacao: "notificar_operacao"
|
|
204
|
+
criticidade_operacional: alta
|
|
205
|
+
}
|
|
206
|
+
state ciclo_pedido {
|
|
207
|
+
transitions {
|
|
208
|
+
AGUARDANDO_PAGAMENTO -> CANCELADO
|
|
209
|
+
APROVADO -> CANCELADO
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
guarantees {
|
|
213
|
+
protocolo existe
|
|
214
|
+
status == CANCELADO
|
|
215
|
+
}
|
|
216
|
+
error {
|
|
217
|
+
pedido_nao_cancelavel: "Pedido ja enviado ou entregue nao pode ser cancelado."
|
|
218
|
+
}
|
|
219
|
+
tests {
|
|
220
|
+
caso "cancela pedido pendente" {
|
|
221
|
+
given {
|
|
222
|
+
pedido_id: "ped_1"
|
|
223
|
+
status_atual: "AGUARDANDO_PAGAMENTO"
|
|
224
|
+
motivo: "Desistencia do cliente"
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
expect {
|
|
228
|
+
sucesso: verdadeiro
|
|
229
|
+
protocolo: "cancel_1"
|
|
230
|
+
status: "CANCELADO"
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
flow aprovacao_pedido {
|
|
237
|
+
pedido_id: Id
|
|
238
|
+
valor: Decimal
|
|
239
|
+
produto_id: Id
|
|
240
|
+
quantidade: Inteiro
|
|
241
|
+
token_pagamento: Texto
|
|
242
|
+
itens_reservados: Texto
|
|
243
|
+
status_cancelamento: StatusPedido
|
|
244
|
+
motivo_pagamento_recusado: Texto
|
|
245
|
+
motivo_estoque_insuficiente: Texto
|
|
246
|
+
etapa pagar usa processar_pagamento com pagamento_id = pedido_id, valor = valor, token = token_pagamento em_sucesso reservar em_erro cancelar_por_pagamento
|
|
247
|
+
etapa reservar usa reservar_estoque com produto_id = produto_id, quantidade = quantidade, pedido_id = pedido_id depende_de pagar em_sucesso aprovar em_erro cancelar_por_estoque
|
|
248
|
+
etapa aprovar usa criar_pedido com cliente_id = pedido_id, itens = itens_reservados depende_de reservar
|
|
249
|
+
etapa cancelar_por_pagamento usa cancelar_pedido com pedido_id = pedido_id, status_atual = status_cancelamento, motivo = motivo_pagamento_recusado depende_de pagar
|
|
250
|
+
etapa cancelar_por_estoque usa cancelar_pedido com pedido_id = pedido_id, status_atual = status_cancelamento, motivo = motivo_estoque_insuficiente depende_de reservar
|
|
251
|
+
effects {
|
|
252
|
+
auditoria fluxo_aprovacao_pedido criticidade = alta
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
}
|