Para "publicar" a funcionalidade Progress ABL basta criar o programa (.p) com o seguinte caminho: sec/api/v1/users.p (<módulo>/api/<versão API>/<recurso>.p).
A sub-pasta "api" passa então a concentrar todas as funcionalidades de integração do módulo em questão: Aviso |
---|
Os programas Progress disponibilizados, deverão seguir o padrão de localização abaixo e devem estar compilados, ou seja, é necessário o *.r: <módulo>/api/<versão API>/<recurso>.r |
---|
OBS: Outros caminhos e parâmetros podem ser adicionados a URL, mas sempre de acordo com o Guia de Implementação de APIs. |
O Guia de Implementação de API TOTVS define também que a troca de mensagens é feita (impreterivelmente) no formato JSON, e por conta disso, a troca de mensagens com as funcionalidades Progress também devem ser feitas nesse formato, mais especificamente por meio de um parâmetro de entrada e outro de saída do tipo LONGCHAR que devem ser devidamente tratados (parseados e formatados) pela funcionalidade utilizando as includes utilitárias disponibilizadas: Include | Parâmetros | Descrição |
---|
utp/ut-api.i | Não há. | Faz o parser do parâmetro LONGCHAR de entrada e cria um objeto JsonObject chamado jsonInput. | utp/ut-api-action.i | 1 - Nome da procedure interna que deve ser executada. 2 - Método da Requisição. 3 - Rota. | Faz o roteamento do objeto jsonInput para uma procedure interna especificada pelo desenvolvedor. | utp/ut-api-notfound.i | Não há. | Caso nenhuma procedure interna tenha sido encontrada, retorna uma mensagem "Method not found" com HTTP Status 400. |
Para garantindo o controle de erros, controle de chamada EPC e padronização no retorno das mensagens, foram criadas includes para executar os principais eventos, além de permitir a chamada de eventos específicos de negócio: Include | Parâmetros | Evento | Descrição |
---|
utp/ut-api-exec-metadata.i | Parâmetros:1 - PI interna a ser definida no programa (a mesma informada na include de rota correspondente); 2 - Programa de negócio a ser executado; 3 - PI interna do programa de negócio a ser executada. | Metadata | Devolve metadata para geração das telas. | utp/ut-api-exec-vld-form.i | Parâmetros:1 - PI interna a ser definida no programa (a mesma informada na include de rota correspondente); 2 - Programa de negócio a ser executado; 3 - PI interna do programa de negócio a ser executada. | VldForm | Validação de formulário. | utp/ut-api-exec-vld-field.i | Parâmetros: | 1 - PI interna a ser definida no programa (a mesma informada na include de rota correspondente); 2 - Programa de negócio a ser executado; 3 - PI interna do programa de negócio a ser executada. | VldField | Validação de campo. | utp/ut-api-exec-get.i | Parâmetros:1 - PI interna a ser definida no programa (a mesma informada na include de rota correspondente); 2 - Programa de negócio a ser executado; 3 - PI interna do programa de negócio a ser executada. | Get | Busca um registro. | utp/ut-api-exec-query.i | Parâmetros:1 - PI interna a ser definida no programa (a mesma informada na include de rota correspondente); 2 - Programa de negócio a ser executado; 3 - PI interna do programa de negócio a ser executada. | Query | Busca vários registros. | utp/ut-api-exec-create.i | Parâmetros:1 - PI interna a ser definida no programa (a mesma informada na include de rota correspondente); 2 - Programa de negócio a ser executado; 3 - PI interna do programa de negócio a ser executada. | Create | Criação de registro. | utp/ut-api-exec-update.i | Parâmetros:1 - PI interna a ser definida no programa (a mesma informada na include de rota correspondente); 2 - Programa de negócio a ser executado; 3 - PI interna do programa de negócio a ser executada. | Update | Alteração de registro. | utp/ut-api-exec-patch.i | Parâmetros:1 - PI interna a ser definida no programa (a mesma informada na include de rota correspondente); 2 - Programa de negócio a ser executado; 3 - PI interna do programa de negócio a ser executada. | Patch | Alteração de registro. | utp/ut-api-exec-delete.i | Parâmetros:1 - PI interna a ser definida no programa (a mesma informada na include de rota correspondente); 2 - Programa de negócio a ser executado; 3 - PI interna do programa de negócio a ser executada. | Delete | Eliminação de registro. | utp/ut-api-exec-delete-list.i | Parâmetros: | 1 - PI interna a ser definida no programa (a mesma informada na include de rota correspondente); 2 - Programa de negócio a ser executado; 3 - PI interna do programa de negócio a ser executada. | DeleteList | Eliminação em lote. | utp/ut-api-exec-custom.i | Parâmetros: | 1 - PI interna a ser definida no programa (a mesma informada na include de rota correspondente); 2 - Programa de negócio a ser executado; 3 - PI interna do programa de negócio a ser executada; 4 - Tipo de Retorno do endpoint: "Object" = O conteúdo retornado pelo programa de negócio será um Objeto. "Array" = O conteúdo retornado pelo programa de negócio será um Array. 5 - Código do Endpoint que será utilizado para envio para EPC. | Custom (NEG) | Tratativa especifica de negócio. |
Informações |
---|
| - O programa informado será executado de forma persistente e executado a PI informada;
- A Include irá utilizar a classe utilitária JsonAPIExecution para realizar a execução do programa;
- As informações que serão envidas para a EPC, podem ser consultas aqui.
|
>>>>>Abaixo um exemplo de recurso desenvolvido em Progress ABL para ser utilizado junto ao serviço de API<<<<<< Expandir |
---|
title | Clique para visualizar o exemplo ... |
---|
| No início do código estão todas as includes necessárias. O que vale ressaltar neste trecho é referente a include ut-api-action: - Nesta include são declaradas as procedures utilizadas na API, por exemplo: pi-send, pi-update.
- Na mesma declaração é definido qual o método http aplicado, por exemplo: GET, POST, entre outros.
- Em seguida é definido como o recurso será acessado pela URI, por exemplo: /~*/SEND
- Isso significa que ao acessar a URI teremos algo como: http://host:port/dts/datasul-rest/resources/prg/sec/v1/users/send onde:
draw.io Diagram |
---|
border | true |
---|
viewerToolbar | true |
---|
fitWindow | false |
---|
diagramName | estrutura |
---|
simpleViewer | false |
---|
width | 600 |
---|
links | auto |
---|
tbstyle | top |
---|
lbox | true |
---|
diagramWidth | 785 |
---|
revision | 5 |
---|
|
Bloco de código |
---|
| {utp/ut-api.i}
{utp/ut-api-action.i pi-send GET /~*/SEND by=email,address=~* }
{utp/ut-api-action.i pi-update POST /~* }
{utp/ut-api-action.i pi-find GET /~* }
{utp/ut-api-action.i pi-default GET }
{utp/ut-api-notfound.i}
PROCEDURE pi-send:
DEF INPUT PARAM jsonInput AS JsonObject NO-UNDO.
DEF OUTPUT PARAM jsonOutput AS JsonObject NO-UNDO.
DEFINE VARIABLE aJsonArray AS JsonArray NO-UNDO.
DEFINE VARIABLE oJsonObject AS JsonObject NO-UNDO.
aJsonArray = NEW JSONArray().
oJsonObject = NEW JSONObject().
oJsonObject:ADD("teste", "teste").
oJsonObject:ADD("teste1", "teste1").
oJsonObject:ADD("teste2", "teste2").
aJsonArray:ADD(oJsonObject).
oJsonObject = NEW JSONObject().
oJsonObject:ADD("teste", "teste").
oJsonObject:ADD("teste1", "teste1").
oJsonObject:ADD("teste2", "teste2").
aJsonArray:ADD(oJsonObject).
jsonOutput = JsonAPIResponseBuilder:ok(aJsonArray, false).
END.
PROCEDURE pi-update:
DEF INPUT PARAM jsonInput AS JsonObject NO-UNDO.
DEF OUTPUT PARAM jsonOutput AS JsonObject NO-UNDO.
jsonOutput = NEW JSONObject().
jsonOutput = jsonInput.
END.
PROCEDURE pi-find:
DEF INPUT PARAM jsonInput AS JsonObject NO-UNDO.
DEF OUTPUT PARAM jsonOutput AS JsonObject NO-UNDO.
jsonOutput = NEW JSONObject().
jsonOutput:ADD("method", "GET").
jsonOutput:ADD("procedure", "pi-find").
jsonOutput:ADD("description", "Test").
END.
PROCEDURE pi-default:
DEF INPUT PARAM jsonInput AS JsonObject NO-UNDO.
DEF OUTPUT PARAM jsonOutput AS JsonObject NO-UNDO.
jsonOutput = NEW JSONObject().
jsonOutput:ADD("method", "GET").
jsonOutput:ADD("procedure", "pi-default").
jsonOutput:ADD("description", "Test").
END. |
|
No exemplo acima, temos as seguintes includes utilitárias: draw.io Diagram |
---|
border | true |
---|
viewerToolbar | true |
---|
fitWindow | false |
---|
diagramName | utilitarios |
---|
simpleViewer | false |
---|
diagramWidth | 1079 |
---|
revision | 5 |
---|
|
Informações |
---|
Algumas considerações sobre o uso da include de roteamento (ut-api-action): - Os roteamentos devem ser definidos do mais específico (detalhado) para o mais genérico (simples);
- O utilitário faz uso da função MATCHES do Progress, que basicamente permite o uso do ponto "." (ponto) como coringa de uma determinada posição (1 caractere apenas) e o "*" (asterisco) para um conjunto de caracteres variáveis;
- O caracter de escape "~" deve ser utilizado sempre que necessário, antecedendo caracteres especiais que comprometam a compilação do código progress;
- Para definir mais de um parâmetro de pesquisa, utilize "," (vírgula) como separador. O processamento de mais de um parâmetro de pesquisa será sempre traduzido para usar o operador AND.
- Permite o uso de todos métodos HTTP suportados pelo API Manager (GET, POST, PUT, DELETE, PATCH, ...)
|
Informações |
---|
A include ut-api.i precisa ser adicionada obrigatoriamente no início do programa Progress, visto que esta include faz uso da instrução USING para importação de classes. Portanto, devido a esta caraterística do Progress ABL, somente será possível adicionar outras includes depois da adição da ut-api.i e ut-api-notfound.i, respectivamente. |
|