Skip to main content

Classes e utilitarios para uso em apis rest com django.

Project description

O que há neste pacote?

Este pacote tem ferramentas para extender as funcionalidades de API's rest escritas em Django e Django Rest Framework.

Middlewares

Envelope

Este middleware dá a capacidade de incluir um envelope na respostas da API:

Ex:

Requisição: https://[.....]/?envelope=true

Resposta:

{
    "code": 200,
    "message": "OK",
    "data": {
        "id": "11e87365528a11659bdd005056a83b77",
        "numero_loja": 2,
        "endereco": "RUA OTAVIO ROCHA, 152",
        "cidade": "PORTO ALEGRE",
        "estado": "RS",
        "cep": 90020150,
        "telefone": "(51) 3901-6053"
    }
}

Requisição: https://[.....]/?envelope=false

Resposta:

{
    "id": "11e87365528a11659bdd005056a83b77",
    "numero_loja": 2,
    "endereco": "RUA OTAVIO ROCHA, 152",
    "cidade": "PORTO ALEGRE",
    "estado": "RS",
    "cep": 90020150,
    "telefone": "(51) 3901-6053"
}

Obs.: Por default, o recurso de envelope fica desabilitado (igual a envelope=false).

Log

Este middleware habilita uma personalização dos logs para envio para o Graylog, ferramenta de registro de logs.

Segue um exemplo de configuração:

LOGGING = {
    'version': 1,
    'filters': {
        'require_debug_true': {
            '()': 'django.utils.log.RequireDebugTrue',
        },
        'settings_filter': {
            '()': 'apicredito.core.logfilter.SettingsFilter',
        }
    },
    'handlers': {
        'console': {
            'level': 'DEBUG',
            'filters': ['require_debug_true'],
            'class': 'logging.StreamHandler',
        },
        'graypy': {
            'level': 'INFO',
            'class': 'graypy.GELFHandler', # configurações do Graylog
            'host': '192.168.0.45',
            'port': 12201,
            'level_names': True,
            'extra_fields': True
        }
    },
    'loggers': {       
        'apilog': {
            'level': 'INFO',
            'handlers': ['graypy'],
            'filters': ['settings_filter']
        }
    }
}

Para habilitar os middlewares, coloque na seção MIDDLEWARE do settings.py da sua API Django:

MIDDLEWARE = [
    [...]
    'lins_restapi.http.EnvelopeMiddleware',
    'lins_restapi.http.LoggingMiddleware',
]

Paginação

Este pacote estende a biblioteca de paginação do Django, padronizando e integrando com os demais middlewares do pacote. Ele adiciona headers nas respostas da API, contendo o total de registros, o número de registros retornados na página e qual a pagina atual. Se envelope=true, também retorna como um campo do envelope.

Conceitos:

  • total ou X-Total: Total de registros da requisição;
  • page ou X-Page: Página atual/requisitada;
  • per_page ou X-Per-Page: Número de registros por página;

Ex.:

Requisição:

https://[...]?per_page=2&page=5&envelope=true

Resposta:

{
    "code": 200,
    "message": "OK",
    "total": 43,
    "page": 5,
    "per_page": 2,
    "data": [
        {
            "id": "11e87365528a5bff9bdd005056a83b77",
            "numero_loja": 10,
            "endereco": "RUA JULIO DE CASTILHOS, 2030",
            "cidade": "CAXIAS DO SUL",
            "estado": "RS",
            "cep": 95010002,
            "telefone": "(54) 3223-1685"
        },
        {
            "id": "11e87365528a62609bdd005056a83b77",
            "numero_loja": 11,
            "endereco": "AV. NAÇÕES UNIDAS, 2001",
            "cidade": "NOVO HAMBURGO",
            "estado": "RS",
            "cep": 93320020,
            "telefone": "(51) 3594.5948"
        }
    ]
}

Headers:

X-Page 5
X-Per-Page 2
X-Total 43

Obs.: Se houver cors, como o django-cors-headers, é necessário adicionar os headers de paginação como exceção:

CORS_EXPOSE_HEADERS = [
    'X-Page',
    'X-Per-Page',
    'X-Total'
]

Outros recursos

  • Sobrescrita de classes do Swagger Generator afim de tratar o protocolo https;

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

lins_restapi-2.0.2.26.tar.gz (5.9 kB view details)

Uploaded Source

Built Distribution

lins_restapi-2.0.2.26-py3-none-any.whl (7.5 kB view details)

Uploaded Python 3

File details

Details for the file lins_restapi-2.0.2.26.tar.gz.

File metadata

  • Download URL: lins_restapi-2.0.2.26.tar.gz
  • Upload date:
  • Size: 5.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.3

File hashes

Hashes for lins_restapi-2.0.2.26.tar.gz
Algorithm Hash digest
SHA256 5408915bb001ac500902b1bb4116c5f018e9efd23e2544233c4189138e7ca23a
MD5 3479f8fa77ef7b6064f967a88c4f08e7
BLAKE2b-256 a81cf392ab8f2f84b0af4b643684edeb7f8cad3efc8fe3a6d1258d39df255e6b

See more details on using hashes here.

File details

Details for the file lins_restapi-2.0.2.26-py3-none-any.whl.

File metadata

  • Download URL: lins_restapi-2.0.2.26-py3-none-any.whl
  • Upload date:
  • Size: 7.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.3

File hashes

Hashes for lins_restapi-2.0.2.26-py3-none-any.whl
Algorithm Hash digest
SHA256 318d8a0e788a4edba9e5186081ed6e67664489a6de307896c9ce8fa021eb917c
MD5 d2aaa1546f707eb249c36401129659d3
BLAKE2b-256 1910dcd9866a26241b99c60ff87ea0c465267b0df5519d522f7299241bee1c5d

See more details on using hashes here.

Supported by

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