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.37.tar.gz (63.5 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.37-py3-none-any.whl (71.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: nsj_rest_lib2-0.0.37.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

Hashes for nsj_rest_lib2-0.0.37.tar.gz
Algorithm Hash digest
SHA256 c9a7f706bdadee21acbc7c6f272efcf30b7e9df6d02df0af605752b779bb0a16
MD5 d86a2213bf0e1d42254b3eb5835aec4e
BLAKE2b-256 ae6554b260b7ef807f31f6a9c05f3463a73b40f25b419959c51e05600fde639d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: nsj_rest_lib2-0.0.37-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

Hashes for nsj_rest_lib2-0.0.37-py3-none-any.whl
Algorithm Hash digest
SHA256 e2ec4974109fe963da9cc3dffc6bf7356fc64be43fc596b634a05ee00b59c9f6
MD5 cf6fedab21dca287a81ff49b990cf7f5
BLAKE2b-256 6aec0e5a3108c02a9819eb1263cc74a6b5f2353f66ff1231b2439ee0f919d17b

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