Biblioteca para permitir a distribuição de rotas dinâmicas numa API, configuradas por meio de EDLs declarativos (em formato JSON).
Project description
RestLib2
O RestLib2 é uma plataforma que tem por objetivo o fornecimento de APIs para os clientes, a partir da descrição da entidades envolvidas, e sem a necessidade de programação imperativa tradicional.
Em resumo, a partir da declaração em JSON das entidades que compõe um negócio, bem como dos relacionamentos entre estas, as APIs já estarão disponíveis em produção.
O objetivo final é permitir que o desenvolvimento de APIs se torne rápido e simples, acessível àqueles que tratam diretamente com o negócio (incluindo implantadores, e, no limite, o próprio cliente).
Links
Guia do EDL ESPECIFICAÇÃO DO MODELO DE ENTIDADES
Rota das APIs geradas
A rota para acesso a uma API gerada por variar de acordo com o modo de configuração escolhido pela aplicação que usar o RestLib2. Mas, via de regra, sugere-se o padrão aplicado na API de DadosMestre:
#############################
# List Prod
#############################
GET https://api.nasajon.app/dados-mestre/edl1/clientes?tenant=47&grupo_empresarial=NASAJON HTTP/1.1
Authorization: Bearer *****
Accept: application/json
- Note que, na API de Dados Mestre, todas as APIs do RestLib2 ficarão debaixo da rota:
https://api.nasajon.app/dados-mestre/edl1/ - O endpoint em si, varia a cada JSON, e fica configurado no nó
api.resourcedo JSON de EDL em questão.
Fluxo básico de uso
Há dois modos básicos de publicar novas APIs a partir de um JSON gerado, para uma aplicação previamente configurada para uso da plataforma:
Fluxo por meio de código versionado
- Criar o JSON de descrição da entidade desejada, gravando-o no diretório "@schemas/entities" da aplicação em questão (tome como exemplo o "dados-mestre").
- Fazer push das alterações.
- Aguardar o build da aplicação (pode ser útil conferir os logs do job de atualização dos JSON, na aplicação em questão, e também os logs do worker de compilação, no Argo).
- Testar as APIs compiladas.
Fluxo de deploy direto pela API
- Criar o JSON de descrição da entidade desejada.
- Registrá-lo diretamente, por meio da API de controle do RestLib2. segue exemplo de chamada abaixo:
###############################
# Post dinâmico
###############################
POST https://api.nasajon.app/restlib2/entities HTTP/1.1
Authorization: Bearer ******
Content-Type: application/json
{
"id": "{UUID}",
"escopo": "{escopo}",
"tenant": 0,
"grupo_empresarial": "00000000-0000-0000-0000-000000000000",
"codigo": "{codigo da entidade}",
"descricao": "{descrição da entidade}",
"json_schema": {
"edl_version": "1.0",
"escopo": "{escopo}",
"description": "{descrição da entidade}",
"id": "cliente",
"version": "0.0.1",
...
}
}
Observações:
- Note que, acima há placeholders a alterar.
- Note também que o JSON não está completo, e, o correto é deguir a documentação do EDL.
- Os valores tenant=0 e grupo_empresarial=00000000-0000-0000-0000-000000000000, indicam que a entidade é padrão, e serve para todos os tenants e grupos.
- Essa rota irá retornar algo semelhante a:
HTTP/1.1 202 ACCEPTED
Location: https://api.nasajon.app/restlib2/entity-compilations/status/{UUID do processo de compilação}
E, se você fizer uma chamada à rota retornada, poderá acompanhar o status da compilação, incluindo eventuais erros que venham a ocorrer.
- Testar a API compilada.
Como rodar a compilação de EDLs localmente?
Você pode testar a compilação de seus EDLs localmente, incluindo a execução de diversas validações sobre os mesmos, desde que todos estejam dispostos num mesmo diertório.
Para isso, considere os passos a seguir:
- Crie um diretório, e coloque todos os seus EDLs lá (garantindo que EDLs relacionados estejam no mesmo).
- Instale, no seu ambiente pyhton de teste, a biblioteca
nsj-rest-lib2:
pip install nsj-rest-lib2
- Rode o comando abaixo (adaptado para seu diretório):
python3 -m nsj_rest_lib2.compiler.compiler -d $(shell pwd)/{diretorio_com_os_edls_json}
O resultado da compilação será impresso no console (erros, ou código total gerado).
Como configurar uma aplicação para expôr rotas de acordo com o padrão do RestLib2?
Para que uma aplicação exponha as rotas no padrão do RestLib2, não são necessários muitos passos. Antes basta:
- Instalar, em sua aplicação, a dependência para o projeto nsj-rest-lib2
pip install nsj-rest-lib2
Não esqueça de fixar a versão usada (como sendo a última), no arquivo requirements.txt.
- Adicione a variável de ambiente abaixo em sua aplciação
ESCOPO_RESTLIB2: "{COLOQUE O IDENTIFICADOR DE ESCOPO QUE DESEJAR PARA SUA APLICAÇÃO (UMA SIMPLES STRING SEM ESPAÇO)}"
- Esse identificador de escopo deve se único para sua aplicação.
- É importante nota que sua aplicação só irá expôr JSONs de EDL configurados para o mesmo escopo definido aqui.
- Instale, como dependência a biblioteca, nsj-rest-lib2:
pip install nsj-rest-lib2
Não esqueça de fixar a versão usada (como sendo a última), no arquivo requirements.txt.
- Adicione a linha abaixo no arquivo wsgi.py (de inicilização de sua aplicação):
from nsj_rest_lib2.controller.dynamic_controller import setup_dynamic_routes
from nasajon.injector_factory_multibanco import InjectorFactoryMultibanco
setup_dynamic_routes(application, injector_factory=InjectorFactoryMultibanco)
- No exemplo acima, a rota é multibanco, mas, não é obrigatório.
- Os parâmetros de setup são:
- flask_app: Variável obrigatório, que aponte para sua aplicação Flask.
- multidb: Flag (padrão True)
- dynamic_root_path: URL padrão base de todos os endpoints do RestLib2 (padrão: "edl1")
- injector_factory: Classe de injeção de depndência usada (normalmente necessária para aplicações multibanco; o principal uso é justamente manipular a criação da conexão com o BD).
Carregando EDLs direto do disco
Também é possível carregar EDLs diretamente do disco, sem depender exclusivamente do Redis. Para isso, use o parâmetro opcional edls_path em setup_dynamic_routes, apontando para um caminho relativo ao workdir da aplicação (ou absoluto), contendo arquivos .json, .yml ou .yaml com os EDLs.
Exemplo:
from nsj_rest_lib2.controller.dynamic_controller import setup_dynamic_routes
setup_dynamic_routes(
application,
injector_factory=InjectorFactoryMultibanco,
edls_path="@schemas/entities",
)
Observações:
- Os EDLs são carregados e compilados uma vez, ficando em cache em memória. Chamadas seguintes reutilizam o cache.
- A resolução das entidades ocorre primeiro pelo cache local; se não encontrar, o Redis é consultado (quando habilitado).
Para desabilitar o Redis e usar somente EDLs do disco, defina a variável de ambiente abaixo:
EDLS_FROM_REDIS=false
O valor padrão de EDLS_FROM_REDIS é true.
Pronto, isso deve bastar para expôr os EDLs configurados para o mesmo escopo da aplicação.
OBSERVAÇÃO GERAL: Isso só funciona para aplicações Flask.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nsj_rest_lib2-0.0.38.tar.gz.
File metadata
- Download URL: nsj_rest_lib2-0.0.38.tar.gz
- Upload date:
- Size: 63.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b668cd145488c11049ee710057280b9c11b5af1539eedbdd76f7ac2d4b272df2
|
|
| MD5 |
b0517b66fb001e307850252c5757f1ca
|
|
| BLAKE2b-256 |
cb9e2ded6436827f2129459ee9dc83c796c3812d5b1e3589ab3da029a351cbcb
|
File details
Details for the file nsj_rest_lib2-0.0.38-py3-none-any.whl.
File metadata
- Download URL: nsj_rest_lib2-0.0.38-py3-none-any.whl
- Upload date:
- Size: 71.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b70539dc8a3c798fd9aa35cf62cfac3c268b2c122c79f87f0a0f5ffcb6e43916
|
|
| MD5 |
ed5a3e029cc594d8e7c1108c5bf6b9da
|
|
| BLAKE2b-256 |
98ceef029d42baadc304a2f4db55fbf7e61fcda2f8a7270a638f377ff59d0f80
|