## SENATRAN / Consultar Exame Toxicológico
Retorna o prazo para o próximo exame e a situação toxicológica do condutor na base do SENATRAN através do CPF, data de nascimento e vencimento da CNH informados.


### Site URL
- https://portalservicos.senatran.serpro.gov.br/#/condutor/consultar-toxicologico

### Request
POST endpoint: `https://api.infosimples.com/api/v2/consultas/senatran/exame-toxicologico`



| Parameter            | Description                                                                                                                                                                                                          |
| -------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| token*               | The token that will authenticate and authorize the request.                                                                                                                                                          |
| cpf*                 | CPF of the individual to be queried.                                                                                                                                                                                 |
| birthdate*           | Date of birth in ISO 8601 format. For example, April 22, 1985 is represented as "1985-04-22". Make sure to include leading zeros; the format "1985-4-22" is invalid.                                                 |
| data_vencimento_cnh* | Data de validade da CNH no formato ISO 8601. Por exemplo, 22 de Abril de 1985 é representado em ISO 8601 da forma "1985-04-22". Preste atenção que é necessário incluir zeros, o formato "1985-4-22" seria inválido. |

> * Required parameter.

> ** Optional parameter. Sometimes it is necessary to set at least one of the optional parameters for the service to work properly.


### Response examples (OK)
```json
{
  "code": 200,
  "code_message": "A requisição foi processada com sucesso.",
  "errors": [],
  "header": {
    "api_version": "v2",
    "api_version_full": "2.2.33-20260109171147",
    "product": "Consultas",
    "service": "senatran/exame-toxicologico",
    "parameters": {
      "birthdate": "11/11/1111",
      "cpf": "123.456.789-01",
      "data_vencimento_cnh": "11/11/1111"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.26",
    "requested_at": "2026-01-12T15:16:42.000-03:00",
    "elapsed_time_in_milliseconds": 574,
    "remote_ip": "111.111.111.111",
    "signature": "f6+lNvSytklcimW/EOy4aH5iqf7k3/9Pg4ZHxgthgit6kbgDBi8g9f4Ds4K42t+oR6dNZfwW60aU/J+CDGe7Qo14t2+tf1Azz6MMAw=="
  },
  "data_count": 1,
  "data": [
    {
      "data_coleta_amostra": "Não há registro de uma nova coleta",
      "observacao": "Exemplo de Texto",
      "prazo_novo_exame": "11/11/1111",
      "site_receipt": "https://www.exemplo.com/exemplo-de-url"
    }
  ],
  "site_receipts": [
    "https://www.exemplo.com/exemplo-de-url"
  ]
}
```


### Preview file

The preview file (`site_receipts`) in the response JSON may be **synthesized by Infosimples** using data from the source (website/app) that processed the automation if the file generated by the source is not suitable for viewing.

### Code snippets


#### Python
```python
# Tested with: Python 3.10.19, Python 3.14.0
import requests

url = 'https://api.infosimples.com/api/v2/consultas/senatran/exame-toxicologico'
args = {
  "cpf":                 "VALUE_OF_PARAMETER_CPF",
  "birthdate":           "VALUE_OF_PARAMETER_BIRTHDATE",
  "data_vencimento_cnh": "VALUE_OF_PARAMETER_DATA_VENCIMENTO_CNH",
  "token":               "WRITE_YOUR_TOKEN_HERE",
  "timeout":             "300"
}

response = requests.post(url, args)
response_json = response.json()
response.close()

if response_json['code'] == 200:
  print("Retorno com sucesso: ", response_json['data'])
elif response_json['code'] in range(600, 799):
  mensagem = "Resultado sem sucesso. Leia para saber mais: \n"
  mensagem += "Código: {} ({})\n".format(response_json['code'], response_json['code_message'])
  mensagem += "; ".join(response_json['errors'])
  print(mensagem)

print("Cabeçalho da consulta: ", response_json['header'])
print("URLs com arquivos de visualização (HTML/PDF): ", response_json['site_receipts'])
```


## We are here to help
Do you still need to figure something out? Reach us at [suporte@infosimples.com.br](mailto:suporte@infosimples.com.br) and our highly qualified support team will be happy to help.
