Skip to main content

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.resource do 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

  1. 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").
  2. Fazer push das alterações.
  3. 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).
  4. Testar as APIs compiladas.

Fluxo de deploy direto pela API

  1. Criar o JSON de descrição da entidade desejada.
  2. 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.
  1. 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.

  1. 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:

  1. Crie um diretório, e coloque todos os seus EDLs lá (garantindo que EDLs relacionados estejam no mesmo).
  2. Instale, no seu ambiente pyhton de teste, a biblioteca nsj-rest-lib2:
pip install nsj-rest-lib2
  1. 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:

  1. 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.

  1. 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.
  1. 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.

  1. 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nsj_rest_lib2-0.0.40.tar.gz (75.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nsj_rest_lib2-0.0.40-py3-none-any.whl (80.9 kB view details)

Uploaded Python 3

File details

Details for the file nsj_rest_lib2-0.0.40.tar.gz.

File metadata

  • Download URL: nsj_rest_lib2-0.0.40.tar.gz
  • Upload date:
  • Size: 75.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.2

File hashes

Hashes for nsj_rest_lib2-0.0.40.tar.gz
Algorithm Hash digest
SHA256 35997150124c165fa340d1d43231b8ab118e2c9ee5bcffa867876d3cc7aabdaa
MD5 5b62ef0b1a1b21ea43e8d36d8f0f9bb4
BLAKE2b-256 b982b42eb5330220a4447ce5714421539824c70a326050a6bb207a66031c533d

See more details on using hashes here.

File details

Details for the file nsj_rest_lib2-0.0.40-py3-none-any.whl.

File metadata

  • Download URL: nsj_rest_lib2-0.0.40-py3-none-any.whl
  • Upload date:
  • Size: 80.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.2

File hashes

Hashes for nsj_rest_lib2-0.0.40-py3-none-any.whl
Algorithm Hash digest
SHA256 ec7c4bb19d4449145a7bc46984120cd35fc162b19f62b4c728eea2b9fee448ae
MD5 82568e384c4bedb157cffa3b8fe48502
BLAKE2b-256 a2f3f1e7aedfe7e6aeaa1f60f31be7a3d1a4aeacf0b5ccc9792017963d678efe

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page