Skip to main content

Cliente para listas quienesquien

Project description

quienesquien

test codecov PyPI

Client for the Quienesquien list service (https://app.q-detect.com/)

[!IMPORTANT] Generating a new authentication token automatically invalidates any previously created tokens. If multiple applications or services are using the same credentials, creating a new token will render the old ones invalid, potentially causing other applications to fail. To avoid issues, reuse an existing token whenever possible by storing it in an environment variable or a secure location.

Installation

pip install quienesquien

Development & Testing

The project configuration is managed through environment variables. Set them before running tests:

export $(<env.template)

To run unit tests, use pytest.

pytest

Usage

Before using the client, configure the required environment variables:

export QEQ_USER=your_user
export QEQ_CLIENT_ID=your_client_id
export QEQ_SECRET_ID=your_secret_key

Token Generation

Before performing searches, you need to create an authentication token using the create_token method:

from quienesquien import Client

auth_token = await Client.create_token(os.environ['QEQ_CLIENT_ID'], os.environ['QEQ_SECRET_ID'])

You can reuse this token in subsequent requests.

Example

Once you have the token, you can perform searches by passing it:

import os
from quienesquien import Client
from quienesquien.enums import Gender, SearchList, SearchType
from quienesquien.exc import (
    InsufficientBalanceError,
    InvalidPlanError,
    InvalidTokenError,
    PersonNotFoundError,
)

auth_token = await Client.create_token(os.environ['QEQ_CLIENT_ID'], os.environ['QEQ_SECRET_ID'])

client = Client(
    os.environ['QEQ_USER'],
    auth_token,
)

try:
    persons = await client.search(
        full_name='Andres Manuel Lopez Obrador',
        match_score=85,
        rfc='LOOA531113F15',
        curp='LOOA531113HTCPBN07',
        gender=Gender.masculino,
        birthday=dt.date(1953, 11, 13),
        search_type=SearchType.fisica,
        search_list=(SearchList.PPE, SearchList.ONU),
    )
except InsufficientBalanceError:
    print('Saldo insuficiente')
except InvalidPlanError:
    print('Plan inválido')
except InvalidTokenError:
    print('Token inválido')
except PersonNotFoundError:
    persons = []

Environment Variable (Optional)

To simplify usage, you can store the token in an environment variable:

export QEQ_AUTH_TOKEN=your_auth_token

Then, instantiate the client using the environment variable:

import os

client = Client(
    os.environ['QEQ_USER'],
    os.environ['QEQ_CLIENT_ID'],
    os.environ.get('QEQ_AUTH_TOKEN'),
)

Search Parameters

  • full_name (str): Full name of the person.
  • match_score (int): Minimum match percentage (default: 60).
  • rfc (str): Mexican RFC.
  • curp (str): Mexican CURP.
  • gender (Gender): masculino or femenino.
  • birthday (datetime.date): Date of birth.
  • search_type (SearchType): fisica or moral.
  • search_list (tuple[SearchList, ...]): Lists to search. If not provided, searches all.
  • include_history (bool | None): If True, include historical records; if False, only current; if None, use API default.

The search follows a hierarchical approach: it first attempts to find a match using the RFC. If no match is found, it searches by CURP. Finally, if neither is found, it looks for a match by name. You must specify at least one search parameter: full_name, rfc or curp.

Response Structure

  • persons (list): List of matched persons.

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

quienesquien-1.0.4.tar.gz (9.5 kB view details)

Uploaded Source

Built Distribution

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

quienesquien-1.0.4-py3-none-any.whl (11.4 kB view details)

Uploaded Python 3

File details

Details for the file quienesquien-1.0.4.tar.gz.

File metadata

  • Download URL: quienesquien-1.0.4.tar.gz
  • Upload date:
  • Size: 9.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for quienesquien-1.0.4.tar.gz
Algorithm Hash digest
SHA256 ab41d74a6efa55b17a318d369d5598b7274239e1fd2d37f8ef8a874705f1c58d
MD5 268b427e8529c567462d14e152dd72e2
BLAKE2b-256 bce441a1285165daa4c83945633862e2f5f60168d0d32b3b1c94e2ac1898580f

See more details on using hashes here.

File details

Details for the file quienesquien-1.0.4-py3-none-any.whl.

File metadata

  • Download URL: quienesquien-1.0.4-py3-none-any.whl
  • Upload date:
  • Size: 11.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for quienesquien-1.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 7317d0d5093d2252c36953bc6ec0469b7e3ad4f2400f1e58014fea14b6890bb8
MD5 512f72391f1a5bdd693ba3434d3454d1
BLAKE2b-256 b12811c38a226efcb876d7b06f16118125952291cbe0fa64f174eda8557ff257

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