api-key.Workspace ──┬── Workflow ──┬── Phase (fase) ──┬── Ticket
│ │ ├── Ticket
│ └── Phase └── ...
└── WorkflowstatusId: 1=em andamento, 2=insucesso, 3=sucesso). Flag finisher=true indica fase terminal.id_phase (fase atual), customer (vinculado ao CRM), mensagens, SLA, etc.super_status: "Em andamento" | "Finalizado com sucesso" | "Finalizado com insucesso"open: true|falsephase + id_phase: estado atual no workflowcustomer: cliente CRM vinculado (ou null)business: negociação vinculada (ou null)responsibles[]: operadores designadosprotocols: protocolos de atendimento ligados ao ticket| Rota | Pra que serve |
|---|---|
GET /api/v2/workspace/ | Listar workspaces + workflows acessíveis ao usuário da api-key. |
GET /api/v2/workflow-v2/workflows/{workflowId}/phases | Listar fases de um workflow. |
GET /api/v2/workflow-v2/workflow/{workflowId}/tickets/all-data | Listar tickets por fase (paginado). |
| Rota | Pra que serve |
|---|---|
POST /api/v2/ticket | Criar ticket (com crm opcional pra vincular cliente existente). |
POST /api/v2/ticket/custom | Criar ticket + auto-vincular customer (via contact_search ou criar customer novo). |
POST /api/v2/ticket/finish | Movimentar entre fases / finalizar (se a fase de destino tem finisher=true). |
GET /api/v2/ticket/info/{id} | Detalhe completo (mensagens, SLA, customer, business, eligible_phases, protocols…). |
PUT /api/v2/workflow-v2/{ticketId} | Atualizar name / description. |
PUT /api/v2/ticket/link_customer | Vincular cliente CRM a um ticket existente. |
POST /api/v2/ticket/message | Adicionar nota (is_note: true) ou mensagem. |
statusId na fase)| id | Significado | Quando entra |
|---|---|---|
| 1 | Em andamento | ticket entrou na fase mas ainda não finalizou |
| 2 | Finalizado com insucesso | fase finisher de insucesso |
| 3 | Finalizado com sucesso | fase finisher de sucesso |
canal_contato em crm.contact)| id | Canal |
|---|---|
| 2 | |
| 3 | SMS |
| 4 | |
| 6 | Telefone |
| 9 | Telegram |
| 12 | RCS |
| HTTP | Causa típica |
|---|---|
| 400 | Payload inválido, id_phase inexistente, crm.contact parcialmente preenchido |
| 401 | api-key ausente / inválida |
| 404 | Ticket / workflow / phase inexistente |
| 500 | Bug interno — abrir ticket no time de plataforma |