Crates.io | brado |
lib.rs | brado |
version | 1.1.0 |
source | src |
created_at | 2023-12-14 19:41:15.012249 |
updated_at | 2024-07-30 19:12:49.221006 |
description | brado is a brazilian docs validator |
homepage | https://github.com/brenomfviana/brado |
repository | https://github.com/brenomfviana/brado |
max_upload_size | |
id | 1069905 |
size | 114,425 |
Brado é um pacote Rust para validação de documentos brasileiros. Este projeto é inspirado na biblioteca Python validate-docbr.
Brado fornece funções para identificação, validação e geração de documentos brasileiros. O nome desta biblioteca (Brado) é um acrônimo de BRAzilian DOcs validator (validador de DOcumentos BRAsileiros).
:warning: Esta biblioteca tem suporte ao CNPJ alfanumérico. :warning: A documentação desta biblioteca pode ser acessada aqui.
Para adicionar o pacote ao projeto, basta rodar o seguinte comando:
cargo add brado
Ou adicionar a linha a seguir no arquivo Cargo.toml
:
brado = "1.1.0"
CPF: Cadastro de Pessoa Física;
CNH: Carteira Nacional de Habilitação;
CNPJ: Cadastro Nacional da Pessoa Jurídica;
CNS: Cartão Nacional de Saúde;
NIS: NIS/NIT/PIS/PASEP;
Título eleitoral: Cadastro que permite cidadãos brasileiros votar;
RENAVAM: Registro Nacional de Veículos Automotores;
Certidões de Nascimento, Casamento e Óbito.
Todos os documentos possuem as mesmas funções e funcionam da mesma forma.
Valida o documento passado como parâmetro (&str
). Retorna um valor booleano (bool
), true
caso o documento seja válido, ou false
caso contrário.
use brado::cpf;
cpf::validate("63929247011"); // true
cpf::validate("639.292.470-11"); // true
cpf::validate("63929247010"); // false
cpf::validate("639.292.470-10"); // false
Mascara o documento passado como parâmetro (&str
), apenas se não possuir símbolos e tiver o número de caracteres do documento sem símbolos. Retorna uma string (Result<String, &'static str>
) correspondente ao documento mascarado ou um erro.
use brado::cpf;
cpf::mask("63929247011"); // Ok("639.292.470-11")
cpf::mask("639.292.470-11"); // Err("The given string cannot be masked as CPF!")
cpf::mask("639292470"); // Err("The given string cannot be masked as CPF!")
Verifica se o documento passado como parâmetro (&str
) não possui símbolos. Retorna um valor booleano (bool
), true
caso o documento não possua símbolos, ou false
caso contrário.
use brado::cpf;
cpf::is_bare("63929247011"); // true (CPF válido sem máscara)
cpf::is_bare("63929247010"); // true (CPF inválido sem máscara)
cpf::is_bare("639.292.470-11"); // false (CPF válido com máscara)
cpf::is_bare("639.29247011"); // false (CPF válido mascarado errado)
cpf::is_bare("639292470110"); // false (CPF inválido sem máscara)
OBS: se for utilizada a função
cpf::is_bare
para verificar se um CNPJ não possui símbolos, o resultado seráfalse
! Isso acontece pois esta função considera que a string é um CPF, ou seja, possui 11 dígitos.
Verifica se o documento passado como parâmetro (&str
) está mascarado de acordo com o documento correspondente. Retorna um valor booleano (bool
), true
caso o documento esteja mascarado, ou false
caso contrário.
use brado::cpf;
cpf::is_masked("639.292.470-11"); // true (CPF válido com máscara)
cpf::is_masked("639.292.470-10"); // true (CPF inválido com máscara)
cpf::is_masked("63929247011"); // false (CPF válido sem máscara)
cpf::is_masked("6392.92.470-11"); // false (CPF válido mascarado errado)
cpf::is_masked("639.292.470-110"); // false (CPF inválido com máscara)
OBS:
cpf::is_masked
verifica se a string passada está mascarada como um CPF.cnpj::is_masked
verifica se a string passada está mascarada como um CNPJ.
Gera um novo documento sem símbolos (String
).
use brado::cpf;
cpf::generate(); // "63929247011"
Gera um novo documento mascarado (String
).
use brado::cpf;
cpf::generate_masked(); // "639.292.470-11"
São funções que verificam se o documento passado como parâmetro (&str
) são, respectivamente, CPF, CNPJ, CNH e CNS válidos. Essas funções são atalhos (apelidos) para as funções de validação de cada documento. São indicadas para o contexto de identificação do tipo do documento.
use brado::docs;
docs::is_cpf("639.292.470-11"); // true
docs::is_cnpj("639.292.470-11"); // false
Fazer um fork do projeto;
Criar um Pull Request com as sugestões de alteração.
direnv
:nix flake clone github:your-github-user/brado --dest ./brado \
&& cd brado 1>/dev/null 2>/dev/null \
&& direnv allow
Para rodar os testes, basta executar o comando a seguir:
make test