Skip to main content

Lib para consumo da api mindset do Grupo Lins Ferrão.

Project description

Mindset Requests

pyver codecov

Pacote para consumo dos endpoints da Api Mindset.

Variáveis de ambiente

Este projeto depende das variáveis de ambiente abaixo.

API_INTEGRACAO_URL="http://api-mindset-url"
API_INTEGRACAO_USERNAME="api-mindset-username"
API_INTEGRACAO_PASSWORD="api-mindset-password"
DATA_PADRAO_INTEGRACAO="2020-04-01T00:00:00.000"
REQUEST_TIMEOUT="5" # Inteiro. Define o tempo máximo de espera pela resposta (opcional). Se não definida o padrão são 5 segundos.

Servico

Módulo responsável pelas operações no endpoint servico

>>> from mindset.api_requests import Servico
>>> servico = Servico('novo_servico')

servico.get_or_create(service_params={})

service_params:dict (opcional)

Exceto pelo filtrar, todos os métodos da classe dependem da chamada anterior do .get_or_create()

Caso o service_params não seja informado, e o serviço não exista o mesmo será criado com os seguintes dados:

self.service_params = {
  'servico': self.nome_servico, # 'novo_servico'
  'hora_agendamento': '01:00',
  'forcar_execucao': True,
  'ativo': True,
  'tipo': 'entrada',
}

Se informado os dados acima serão atualizados e o serviço criado.

>>> response, json = servico.get_or_create()  # <-- REQUIREMENT: Chamar a função get or create.
>>> json
>>> {'_id': '5fad3131ede2d05c6f5ba65d',
 'servico': 'teste',
 'hora_agendamento': '01:00:00',
 'forcar_execucao': True,
 'ativo': True,
 'tipo': 'entrada'}

Essa função retorna uma tupla (response, json) pois quando o servico existe, o json retorna em uma lista e quando é criado retorna um json. Internamente, o método trabalha para retornar o json.

servico.filtrar(filter_params={})

Método estático

filter_params:dict (opcional)

>>> len(Servico.filtrar().json()) # Sem o filter params, retorna todos os servicos
>>> 25
>>> response = servico.filtrar({'forcar_execucao': False, 'servico': 'minmaxitem-GANG'})
>>> response.json()
>>> [{'_id': '5fabf3cfd96a08315416997b',
  'servico': 'minmaxitem-GANG',
  'hora_agendamento': '01:00:00',
  'forcar_execucao': False,
  'ativo': True,
  'tipo': 'entrada'}]

Para mais informações dos filtros, consulte Mindset Servicos.

servico.get_id()

Retorna o id do servico

>>> servico.get_id()
>>> '5fac5958d96a0831541699ca'

servico.forcar_execucao()

Retorna se a execução forçada do servico é True ou False

>>> servico.forcar_execucao()
>>> True

servico.inicia_integracao()

Define o status do servico como "E" (execução).

>>> response = servico.inicia_integracao()
>>> response.json()
>>> {'data': 'Status do Serviço definido como "E"!'}

Retorna 400 se o status já está definido como "E"

>>> response = servico.inicia_integracao()
>>> response.json()
>>> {'code': 400,
 'error_code': 'invalid',
 'message': 'Entrada inválida.',
 'data': {'general': ['Processo de Integração já está em execução!']}}

servico.sucesso_integracao()

Define o status do servico como "S" (sucesso).

>>> response = servico.sucesso_integracao()
>>> response.json()
>>> {'data': 'Status do Serviço definido como "S"!'}

Retorna 400 se o servico não está setado como "E".

>>> response = servico.sucesso_integracao()
>>> response.json()
>>> {'code': 400,
 'error_code': 'invalid',
 'message': 'Entrada inválida.',
 'data': {'general': ['Processo de Integração não está em execução!']}}

servico.falha_integracao()

Define o status do servico como "F" (falha).

>>> response = servico.falha_integracao()
>>> response.json()
>>> {'data': 'Status do Serviço definido como "F"!'}

Retorna 400 se o servico não está setado como "E".

>>> response = servico.falha_integracao()
>>> response.json()
>>> {'code': 400,
 'error_code': 'invalid',
 'message': 'Entrada inválida.',
 'data': {'general': ['Processo de Integração não está em execução!']}}

servico.get_data_ultima_integracao(filter_params={})

Busca, trata e retorna a data da última integração do serviço ou o valor da variável de ambiente DATA_PADRAO_INTEGRACAO.

filter_params:dict (opcional)

Este método possui esses valores de busca padrão:

{
  '_id_servico': self.id, # busca id do servico pela função get_id()
  'status': 'S',
  'fields': 'inicio_execucao',
  'sort': '-inicio_execucao',
  'per_page': 1,
}

Caso queira modificar, informe os parâmetros no filter_params e os dados acima serão atualizados.

>>> query_params.get_data_ultima_integracao()
>>> '2020-11-12T00:00:00'

servico.update(json)

Atualiza dados do servico.

>>> response, json = servico.get_or_create()
>>> json
>>> {'_id': '5fac5958d96a0831541699ca',
 'servico': 'teste',
 'hora_agendamento': '01:00:00',
 'forcar_execucao': False,
 'ativo': True,
 'tipo': 'entrada'}
>>> response = servico.update({'forcar_execucao': True, 'hora_agendamento': '02:00:00'})
>>> response.json()
>>> {'_id': '5fac5958d96a0831541699ca',
 'servico': 'teste',
 'hora_agendamento': '02:00:00',
 'forcar_execucao': True,
 'ativo': True,
 'tipo': 'entrada'}

servico.delete()

Remove servico.

>>> response = servico.delete()
>>> response.json()
>>> {'data': 'Serviço deletado com sucesso.'}

servico.status()

Retorna todos os status do serviço

>>> response = servico.status()
>>> response.json()
>>> [{'_id': '5fad8dc2ca8d874caa8154e0',
  '_id_servico': '5fad8dc1ca8d874caa8154de',
  'inicio_execucao': '2020-11-12T19:32:18.312000',
  'fim_execucao': '2020-11-12T19:32:18.506000',
  'status': 'S'}]

servico.em_execucao()

Retorna se o servico está definido como "em execução".

>>> servico.em_execucao()
>>> False
>>> servico.inicia_integracao()
>>> <Response [200]>
>>> servico.em_execucao()
>>> True

servico.executado()

Retorna se o servico foi ou não executado.

>>> servico.executado()
>>> False

servico.pode_integrar()

Retorna se o servico pode ser integrado.

>>> servico.pode_integrar()
>>> False

Controle

Módulo responsável pelas operações no endpoint controle.

Os métodos desta classe são estáticos.

Controle.get(filter_params={})

filter_params:dict (opcional)

>>> len(Controle.get().json()) # Retorna todos os controles
>>> 25
>>> response = Controle.get({'per_page': 2}) # Filtragem por limite
>>> response.json()
>>> [{'servico': 'produtos-POMPEIA',
  '_id': '5edfdfc57a6f51710fa6ef90',
  '_id_servico': '5edfdfc57a6f51710fa6ef8f',
  'executado': False},
 {'servico': 'pedidos_gang-GANG',
  '_id': '5edfecdb1421779a4f49cf57',
  '_id_servico': '5edfecdb1421779a4f49cf56',
  'executado': False}]

Para mais informações dos filtros, consulte Mindset Controle.

Controle.limpar(id_servico, executado)

id_servico:string executado:bool

>>> Controle.limpar(servico.get_id(), False)
>>> <Response [200]>

Status

Módulo responsável pelas operações no endpoint status.

Os métodos desta classe são estáticos.

Status.get()

Retorna todos os status, ou filtrados caso o filter_param seja informado.

filter_params:dict (opcional)

>>> len(Status.get().json()) # Retorna todos os status sem o filter params
>>> 25
>>> response = Status.get({'_id_servico': servico.get_id()})
>>> response.json()
>>> [{'_id': '5fad5131d96a083154169a00',
  '_id_servico': '5fad5130d96a0831541699fe',
  'inicio_execucao': '2020-11-12T15:13:53.658000',
  'fim_execucao': '2020-11-12T15:13:53.846000',
  'status': 'S'}]

Para mais informações dos filtros, consulte Mindset Status.

Status.atuais():

Retorna todos os status atuais registrados.

>>> len(Status.atuais().json())
>>> 26
>>> Status.atuais().json()[0]
>>> {'_id': '5f2dbe80b4d3c2d250dcc06a',
 '_id_servico': '5edfdfc57a6f51710fa6ef8f',
 'inicio_execucao': '2020-08-07T20:50:08.518000',
 'fim_execucao': '2020-08-07T20:51:19.542000',
 'status': 'S',
 'servico': {'_id': '5edfdfc57a6f51710fa6ef8f',
  'servico': 'produtos-POMPEIA',
  'hora_agendamento': '01:00:00',
  'forcar_execucao': False,
  'ativo': True,
  'tipo': 'saida'}}

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_mindsetrequests-2.2.2.tar.gz (7.1 kB view details)

Uploaded Source

Built Distribution

lins_mindsetrequests-2.2.2-py3-none-any.whl (9.1 kB view details)

Uploaded Python 3

File details

Details for the file lins_mindsetrequests-2.2.2.tar.gz.

File metadata

  • Download URL: lins_mindsetrequests-2.2.2.tar.gz
  • Upload date:
  • Size: 7.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.7.3

File hashes

Hashes for lins_mindsetrequests-2.2.2.tar.gz
Algorithm Hash digest
SHA256 e2446e2b2a95540d302781117654f8e38b7ae4f01be978bf163ace5fdd935832
MD5 c1ad192b356aefccf78801fe1d4797b7
BLAKE2b-256 2711f8632f205ef7a8e102c1a06f88c7050e2b52d01ea1f615db5aabe708a220

See more details on using hashes here.

File details

Details for the file lins_mindsetrequests-2.2.2-py3-none-any.whl.

File metadata

  • Download URL: lins_mindsetrequests-2.2.2-py3-none-any.whl
  • Upload date:
  • Size: 9.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.7.3

File hashes

Hashes for lins_mindsetrequests-2.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c4919b7913777cdbb7f6dee2c6c6e095f773a4b121eb5bbd8c086dd8a9787193
MD5 13e0686df6d09fb4fa7e57607a85d7f1
BLAKE2b-256 9d8b3a018fb7a452a3be2b16072b7e2799a0daaac888b6e06ea55f1282b699f9

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