@semacode/cli 1.5.25 → 1.5.27

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/docs/cli.md CHANGED
@@ -4,7 +4,7 @@
4
4
 
5
5
  The Sema CLI is the public npm package for local semantic governance. It validates `.sema` contracts, checks drift, maps impact, prepares AI-first context, resolves documentation gates, and runs profile validators before an agent continues.
6
6
 
7
- Current public version: `1.5.25`.
7
+ Current public version: `1.5.27`.
8
8
 
9
9
  ```bash
10
10
  npm install -g @semacode/cli
@@ -16,7 +16,7 @@ sema validar contratos/pedidos.sema --json
16
16
 
17
17
  A CLI da Sema é o pacote público no npm para governança semântica local. Ela valida contratos `.sema`, verifica drift, mapeia impacto, prepara contexto IA-first, resolve gates de documentação e roda validadores de profiles antes de um agente continuar.
18
18
 
19
- Versão pública atual: `1.5.25`.
19
+ Versão pública atual: `1.5.27`.
20
20
 
21
21
  ```bash
22
22
  npm install -g @semacode/cli
@@ -28,7 +28,7 @@ sema validar contratos/pedidos.sema --json
28
28
 
29
29
  La CLI de Sema es el paquete público en npm para gobernanza semántica local. Valida contratos `.sema`, verifica drift, mapea impacto, prepara contexto IA-first, resuelve gates de documentación y ejecuta validadores de profiles antes de que un agente continúe.
30
30
 
31
- Versión pública actual: `1.5.25`.
31
+ Versión pública actual: `1.5.27`.
32
32
 
33
33
  ```bash
34
34
  npm install -g @semacode/cli
@@ -76,7 +76,7 @@ Adoção incremental:
76
76
 
77
77
  ## Persistência vendor-first
78
78
 
79
- A linha 1.5.25 mantém persistência vendor-first como seção canônica no contrato, no semântico, na IR e no formatador, além de `drift` com escopo real, `impacto`, renomeação semântica assistida, `verificar` mais coerente nos alvos gerados, match de métodos JS/TS definidos via `Object.assign(...prototype...)`, leitura de `Preferences`/`localStorage`/`sessionStorage`, fallback para `angular-consumer` standalone sem `.routes`, limpeza de runtime da CLI pública no Windows, Sema Author oficial e MCP remoto desmembrado da distribuição pública.
79
+ A linha 1.5.27 mantém persistência vendor-first como seção canônica no contrato, no semântico, na IR e no formatador, além de `drift` com escopo real, `impacto`, renomeação semântica assistida, `verificar` mais coerente nos alvos gerados, match de métodos JS/TS definidos via `Object.assign(...prototype...)`, leitura de `Preferences`/`localStorage`/`sessionStorage`, fallback para `angular-consumer` standalone sem `.routes`, limpeza de runtime da CLI pública no Windows, Sema Author oficial e MCP remoto desmembrado da distribuição pública.
80
80
 
81
81
  Cobertura pública:
82
82
 
package/docs/env.md CHANGED
@@ -25,13 +25,13 @@ Ambiente necessário para publicar a Sema.
25
25
  No PowerShell, o instalador recebe a versão por parametro:
26
26
 
27
27
  ```powershell
28
- .\install-sema.ps1 -Version 1.5.25 -WithVSCode
28
+ .\install-sema.ps1 -Version 1.5.27 -WithVSCode
29
29
  ```
30
30
 
31
31
  No shell:
32
32
 
33
33
  ```bash
34
- SEMA_VERSION=1.5.25 ./install-sema.sh --with-vscode
34
+ SEMA_VERSION=1.5.27 ./install-sema.sh --with-vscode
35
35
  ```
36
36
 
37
37
  ## Credenciais
@@ -92,7 +92,7 @@ Nunca publique `/mcp` ou `/sse` na internet sem chave comercial bearer por reque
92
92
 
93
93
  ## GitHub Release
94
94
 
95
- O tag público deve seguir `v<versao>`, por exemplo `v1.5.25`.
95
+ O tag público deve seguir `v<versao>`, por exemplo `v1.5.27`.
96
96
 
97
97
  Os assets ficam em `.tmp/release-assets` e sao derivados dos scripts versionados no repositório.
98
98
 
@@ -4,7 +4,7 @@
4
4
 
5
5
  This guide covers the current public installation path for the Sema CLI and VS Code extension. The remote MCP server is a private/commercial authorized service and is not distributed as a public npm package.
6
6
 
7
- Current public version: `1.5.25`.
7
+ Current public version: `1.5.27`.
8
8
 
9
9
  ```bash
10
10
  npm install -g @semacode/cli
@@ -16,7 +16,7 @@ sema doctor
16
16
 
17
17
  Este guia cobre o caminho público atual da Sema para CLI e extensão VS Code. O servidor MCP remoto é um serviço privado/comercial autorizado e não é distribuído como pacote npm público.
18
18
 
19
- Versão pública atual: `1.5.25`.
19
+ Versão pública atual: `1.5.27`.
20
20
 
21
21
  ```bash
22
22
  npm install -g @semacode/cli
@@ -28,7 +28,7 @@ sema doctor
28
28
 
29
29
  Esta guía cubre el camino público actual de instalación para la CLI de Sema y la extensión de VS Code. El servidor MCP remoto es un servicio privado/comercial autorizado y no se distribuye como paquete público de npm.
30
30
 
31
- Versión pública actual: `1.5.25`.
31
+ Versión pública actual: `1.5.27`.
32
32
 
33
33
  ```bash
34
34
  npm install -g @semacode/cli
@@ -58,7 +58,7 @@ sema docs-impacto --intencao "alterar projeto" --json
58
58
  Instalação de uma versão específica pelo npm:
59
59
 
60
60
  ```bash
61
- npm install -g @semacode/cli@1.5.25
61
+ npm install -g @semacode/cli@1.5.27
62
62
  ```
63
63
 
64
64
  Instalação local ao projeto:
@@ -93,7 +93,7 @@ Se quiser uma tag específica, troque `main` pela versão desejada.
93
93
 
94
94
  ```bash
95
95
  npm run extensao:empacotar
96
- code --install-extension .tmp/editor-vscode/sema-language-tools-1.5.25.vsix --force
96
+ code --install-extension .tmp/editor-vscode/sema-language-tools-1.5.27.vsix --force
97
97
  ```
98
98
 
99
99
  Os assets versionados da VSIX devem ser anexados manualmente a GitHub Releases quando houver release pública com binários. Se `--with-vscode` for usado antes disso, o instalador mantém a CLI instalada e apenas pula a extensão.
@@ -6,7 +6,7 @@
6
6
  > ES: Español al final; não traduza comandos, rotas nem sómbolos `.sema` sem contrato.
7
7
 
8
8
 
9
- Sema 1.5.25 trata banco como superficie semântica de primeira classe. Isso significa assumir diferenças reais entre engines e coloca-las no contrato, no semântico, na IR, no drift, no impact map, na renomeacao assistida, no `verificar` e na extensao. Nesta linha, o `drift` também materializa persistência local real em `Preferences`, `localStorage` e `sessionStorage` quando a task está ancorada no arquivo que usa essas APIs, preservando o framing IA-first da release atual.
9
+ Sema 1.5.27 trata banco como superficie semântica de primeira classe. Isso significa assumir diferenças reais entre engines e coloca-las no contrato, no semântico, na IR, no drift, no impact map, na renomeacao assistida, no `verificar` e na extensao. Nesta linha, o `drift` também materializa persistência local real em `Preferences`, `localStorage` e `sessionStorage` quando a task está ancorada no arquivo que usa essas APIs, preservando o framing IA-first da release atual.
10
10
 
11
11
  ## Engines publicas
12
12
 
@@ -0,0 +1,54 @@
1
+ # Repository Boundary
2
+
3
+ <!-- sema:i18n -->
4
+ > EN: English first.
5
+ > PT: Português depois.
6
+ > ES: Español al final.
7
+
8
+ ## English
9
+
10
+ Sema uses an open-core repository boundary.
11
+
12
+ The public repository contains the semantic language, parser, public CLI, base profiles, examples, generic documentation, public tests, and the basic editor extension. It must be useful for adoption, learning, local validation, and community contribution without exposing commercial operations.
13
+
14
+ The private repository contains the hosted product: commercial website, account panel, OAuth and key issuance flows, Supabase control plane, billing, production deployment, operational runbooks, private integrations, customer data, private rule packs, generated snapshots, and commercial showcases.
15
+
16
+ Before any public push, release, or npm publication, run:
17
+
18
+ ```bash
19
+ npm run repo:verificar-publico
20
+ ```
21
+
22
+ If the check blocks a file, move it to the private repository or replace it with a public-safe example.
23
+
24
+ ## Português
25
+
26
+ A Sema usa uma fronteira open-core entre repositórios.
27
+
28
+ O repositório público contém a linguagem semântica, parser, CLI pública, profiles base, exemplos, documentação genérica, testes públicos e a extensão básica do editor. Ele precisa ser útil para adoção, aprendizado, validação local e contribuição da comunidade sem expor a operação comercial.
29
+
30
+ O repositório privado contém o produto hospedado: site comercial, painel de conta, fluxos de OAuth e emissão de chaves, control plane Supabase, billing, deploy de produção, runbooks operacionais, integrações privadas, dados de clientes, rule packs privados, snapshots gerados e showcases comerciais.
31
+
32
+ Antes de qualquer push público, release ou publicação npm, rode:
33
+
34
+ ```bash
35
+ npm run repo:verificar-publico
36
+ ```
37
+
38
+ Se o check bloquear um arquivo, mova para o repositório privado ou substitua por um exemplo seguro para o público.
39
+
40
+ ## Español
41
+
42
+ Sema usa una frontera open-core entre repositorios.
43
+
44
+ El repositorio público contiene el lenguaje semántico, parser, CLI pública, perfiles base, ejemplos, documentación genérica, pruebas públicas y la extensión básica del editor. Debe servir para adopción, aprendizaje, validación local y contribución de la comunidad sin exponer la operación comercial.
45
+
46
+ El repositorio privado contiene el producto hospedado: sitio comercial, panel de cuenta, flujos de OAuth y emisión de claves, control plane Supabase, billing, despliegue de producción, runbooks operativos, integraciones privadas, datos de clientes, rule packs privados, snapshots generados y showcases comerciales.
47
+
48
+ Antes de cualquier push público, release o publicación npm, ejecuta:
49
+
50
+ ```bash
51
+ npm run repo:verificar-publico
52
+ ```
53
+
54
+ Si el check bloquea un archivo, muévelo al repositorio privado o sustitúyelo por un ejemplo seguro para el público.
package/docs/rollback.md CHANGED
@@ -25,7 +25,7 @@ npm dist-tag add @semacode/cli@<versao-boa> latest
25
25
  ```
26
26
 
27
27
  3. Se o problema for só VSIX ou asset de release, substitua o asset no GitHub Release ou publique uma release patch.
28
- 4. Prefira publicar patch corretivo (`1.5.25`, por exemplo) quando o pacote já saiu para usuários.
28
+ 4. Prefira publicar patch corretivo (`1.5.27`, por exemplo) quando o pacote já saiu para usuários.
29
29
 
30
30
  ## Validação de rollback
31
31
 
@@ -0,0 +1,126 @@
1
+ # Security
2
+
3
+ <!-- sema:i18n -->
4
+ > EN: English first.
5
+ > PT: Português depois, com acentos preservados.
6
+ > ES: Español al final.
7
+
8
+ ## EN
9
+
10
+ The remote Sema MCP is a sensitive surface. It lets authorized agents read contracts, check drift, generate IA-first context, and operate inside allowed roots. Security depends on these controls working together:
11
+
12
+ 1. HTTPS on the public proxy.
13
+ 2. Commercial `sema_mcp_*` bearer key per request or OAuth authentication.
14
+ 3. `SEMA_MCP_PROJECT_ROOTS` pointing to a dedicated server root, for example `/srv/sema/projetos`.
15
+ 4. Contract-first operation before code, deploy, docs, workflow, Author text, game, legal, research, or ops actions.
16
+
17
+ Do not publish the server without those controls.
18
+
19
+ ### Data That Must Not Leak
20
+
21
+ - GitHub, npm, Supabase, SSH, or Git Credential Manager tokens.
22
+ - Client-side `SEMA_MCP_AUTH_TOKEN` values containing `sema_mcp_*` keys.
23
+ - `SEMA_MCP_OAUTH_SECRET`.
24
+ - `SEMA_MCP_OAUTH_PASSCODE`.
25
+ - Private key content.
26
+ - `.env`, build caches, uploads, installed dependencies, or temporary snapshots with secrets.
27
+
28
+ Operational runbooks may document non-secret references, such as the public domain, service name, and generic deployment role. They must never include private key bodies, private-key filenames, local key paths, non-public IPs, real server paths, or secret inventory details.
29
+
30
+ ### Remote Operation
31
+
32
+ - Use the smallest privilege that still performs the job.
33
+ - Do not log `Authorization` headers.
34
+ - Do not publish `/mcp` with empty `SEMA_MCP_PROJECT_ROOTS`.
35
+ - Keep Caddy or the reverse proxy with valid TLS.
36
+ - Test `/mcp` without token and expect an authorization challenge.
37
+ - Test account-scoped MCP tokens before declaring the product flow ready.
38
+
39
+ ### Incident
40
+
41
+ If a secret appears in chat, screenshot, log, release, or Git history:
42
+
43
+ 1. Treat it as compromised.
44
+ 2. Rotate it at the provider.
45
+ 3. Remove it from the current file.
46
+ 4. If it reached Git, rewrite history or revoke it permanently.
47
+
48
+ ## PT
49
+
50
+ O Sema MCP remoto é uma superfície sensível. Ele permite que agentes autorizados leiam contratos, verifiquem drift, gerem contexto IA-first e operem dentro das raízes permitidas. A segurança depende destas travas trabalhando juntas:
51
+
52
+ 1. HTTPS no proxy público.
53
+ 2. Autenticacao por chave comercial `sema_mcp_*` por request ou OAuth.
54
+ 3. `SEMA_MCP_PROJECT_ROOTS` apontando para uma raiz dedicada no servidor, por exemplo `/srv/sema/projetos`.
55
+ 4. Operação contract-first antes de código, deploy, docs, workflow, texto Author, jogo, jurídico, pesquisa ou ops.
56
+
57
+ Não publique o servidor sem essas travas.
58
+
59
+ ### Dados Que Não Podem Vazar
60
+
61
+ - Tokens de GitHub, npm, Supabase, SSH ou Git Credential Manager.
62
+ - Valores locais de `SEMA_MCP_AUTH_TOKEN` contendo chaves `sema_mcp_*`.
63
+ - `SEMA_MCP_OAUTH_SECRET`.
64
+ - `SEMA_MCP_OAUTH_PASSCODE`.
65
+ - Conteúdo de chave privada.
66
+ - `.env`, caches de build, uploads, dependências instaladas ou snapshots temporários com segredo.
67
+
68
+ Runbooks operacionais podem documentar referências não secretas, como domínio público, nome do serviço e papel genérico de deploy. Eles nunca devem incluir corpo de chave privada, nomes de arquivos de chave privada, caminhos locais de chave, IPs não públicos, caminhos reais de servidor ou detalhes do inventário de segredos.
69
+
70
+ ### Operação Remota
71
+
72
+ - Use o menor privilégio que ainda executa o trabalho.
73
+ - Não registre headers `Authorization` em logs.
74
+ - Não publique `/mcp` com `SEMA_MCP_PROJECT_ROOTS` vazio.
75
+ - Mantenha Caddy ou reverse proxy com TLS válido.
76
+ - Teste `/mcp` sem token esperando desafio de autorização.
77
+ - Teste tokens MCP por conta antes de declarar o fluxo de produto pronto.
78
+
79
+ ### Incidente
80
+
81
+ Se um segredo aparecer em chat, print, log, release ou histórico Git:
82
+
83
+ 1. Considere comprometido.
84
+ 2. Rotacione no provedor de origem.
85
+ 3. Remova do arquivo atual.
86
+ 4. Se chegou ao Git, reescreva histórico ou revogue definitivamente o segredo.
87
+
88
+ ## ES
89
+
90
+ El Sema MCP remoto es una superficie sensible. Permite que agentes autorizados lean contratos, verifiquen drift, generen contexto IA-first y operen dentro de las raíces permitidas. La seguridad depende de estos controles trabajando juntos:
91
+
92
+ 1. HTTPS en el proxy público.
93
+ 2. Autenticacion por clave comercial `sema_mcp_*` por request u OAuth.
94
+ 3. `SEMA_MCP_PROJECT_ROOTS` apuntando a una raíz dedicada en el servidor, por ejemplo `/srv/sema/projetos`.
95
+ 4. Operación contract-first antes de código, despliegue, docs, workflow, texto Author, juego, legal, investigación u ops.
96
+
97
+ No publiques el servidor sin esos controles.
98
+
99
+ ### Datos Que No Deben Filtrarse
100
+
101
+ - Tokens de GitHub, npm, Supabase, SSH o Git Credential Manager.
102
+ - Valores locales de `SEMA_MCP_AUTH_TOKEN` con claves `sema_mcp_*`.
103
+ - `SEMA_MCP_OAUTH_SECRET`.
104
+ - `SEMA_MCP_OAUTH_PASSCODE`.
105
+ - Contenido de llave privada.
106
+ - `.env`, cachés de build, uploads, dependencias instaladas o snapshots temporales con secretos.
107
+
108
+ Los runbooks operativos pueden documentar referencias no secretas, como dominio público, nombre del servicio y rol genérico de despliegue. Nunca deben incluir el cuerpo de la llave privada, nombres de archivos de llave privada, rutas locales de llaves, IPs no públicas, rutas reales del servidor o detalles del inventario de secretos.
109
+
110
+ ### Operación Remota
111
+
112
+ - Usa el menor privilegio que todavía permita ejecutar el trabajo.
113
+ - No registres headers `Authorization` en logs.
114
+ - No publiques `/mcp` con `SEMA_MCP_PROJECT_ROOTS` vacío.
115
+ - Mantén Caddy o el reverse proxy con TLS válido.
116
+ - Prueba `/mcp` sin token y espera un desafío de autorización.
117
+ - Prueba tokens MCP por cuenta antes de declarar listo el flujo de producto.
118
+
119
+ ### Incidente
120
+
121
+ Si un secreto aparece en chat, captura, log, release o historial Git:
122
+
123
+ 1. Trátalo como comprometido.
124
+ 2. Rótalo en el proveedor de origen.
125
+ 3. Elimínalo del archivo actual.
126
+ 4. Si llegó a Git, reescribe el historial o revócalo definitivamente.
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sema/gerador-css",
3
- "version": "1.5.25",
3
+ "version": "1.5.27",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sema/gerador-dart",
3
- "version": "1.5.25",
3
+ "version": "1.5.27",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sema/gerador-html",
3
- "version": "1.5.25",
3
+ "version": "1.5.27",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sema/gerador-javascript",
3
- "version": "1.5.25",
3
+ "version": "1.5.27",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sema/gerador-lua",
3
- "version": "1.5.25",
3
+ "version": "1.5.27",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sema/gerador-python",
3
- "version": "1.5.25",
3
+ "version": "1.5.27",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sema/gerador-typescript",
3
- "version": "1.5.25",
3
+ "version": "1.5.27",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sema/nucleo",
3
- "version": "1.5.25",
3
+ "version": "1.5.27",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sema/padroes",
3
- "version": "1.5.25",
3
+ "version": "1.5.27",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts"
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@semacode/cli",
3
- "version": "1.5.25",
3
+ "version": "1.5.27",
4
4
  "description": "Semantic governance CLI for AI agents: contracts, drift, impact, documentation gates, and Sema profiles for live systems.",
5
5
  "type": "module",
6
6
  "icon": "logo.png",
@@ -49,15 +49,15 @@
49
49
  "LICENSE"
50
50
  ],
51
51
  "dependencies": {
52
- "@sema/nucleo": "1.5.25",
53
- "@sema/gerador-dart": "1.5.25",
54
- "@sema/gerador-lua": "1.5.25",
55
- "@sema/gerador-python": "1.5.25",
56
- "@sema/gerador-typescript": "1.5.25",
57
- "@sema/gerador-javascript": "1.5.25",
58
- "@sema/gerador-html": "1.5.25",
59
- "@sema/gerador-css": "1.5.25",
60
- "@sema/padroes": "1.5.25",
52
+ "@sema/nucleo": "1.5.27",
53
+ "@sema/gerador-dart": "1.5.27",
54
+ "@sema/gerador-lua": "1.5.27",
55
+ "@sema/gerador-python": "1.5.27",
56
+ "@sema/gerador-typescript": "1.5.27",
57
+ "@sema/gerador-javascript": "1.5.27",
58
+ "@sema/gerador-html": "1.5.27",
59
+ "@sema/gerador-css": "1.5.27",
60
+ "@sema/padroes": "1.5.27",
61
61
  "typescript": "^5.8.3"
62
62
  },
63
63
  "bundledDependencies": [