Yordi.Tools 1.0.1

There is a newer version of this package available.
See the version list below for details.
dotnet add package Yordi.Tools --version 1.0.1                
NuGet\Install-Package Yordi.Tools -Version 1.0.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Yordi.Tools" Version="1.0.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Yordi.Tools --version 1.0.1                
#r "nuget: Yordi.Tools, 1.0.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Yordi.Tools as a Cake Addin
#addin nuget:?package=Yordi.Tools&version=1.0.1

// Install Yordi.Tools as a Cake Tool
#tool nuget:?package=Yordi.Tools&version=1.0.1                

Yordi.Tools

Ferramentas simples .NET para trabalhar com arquivos, strings, números, datas, etc.

Classes e Ferramentas

ValidaObjetos

Uma classe para validação de diferentes tipos de dados.

Métodos
  • IsEmail(string email): Verifica se uma string é um endereço de e-mail válido.
  • IsCPF(string cpf): Verifica se uma string é um CPF válido.
  • IsCNPJ(string cnpj): Verifica se uma string é um CNPJ válido.
  • IsFone(string fone): Verifica se uma string é um número de telefone válido.
  • IsCircuito(string circuito): Verifica se uma string é um circuito válido.
  • IsMacAddress(string macAddress): Verifica se uma string é um endereço MAC válido.
  • IsIPv4(string value): Verifica se uma string é um endereço IPv4 válido.
  • IsIP(string value, out IPAddress? address): Verifica se uma string é um endereço IP válido.
  • IsURL(string value): Verifica se uma string é uma URL válida.
  • IsIPorURL(string value): Verifica se uma string é um endereço IP ou URL válido.
  • IsInt(string value, out int valor): Verifica se uma string pode ser convertida para um inteiro.
  • IsDouble(string value, out double valor): Verifica se uma string pode ser convertida para um double.
  • IsEnumValid(Enum enumValue, int value, int minValue, int maxValue): Verifica se um valor é válido para um enum.

LoggerYordi

Uma classe para logging.

Métodos
  • LoggerInstance(string path = ""): Retorna uma instância do logger.
  • BeginScope<TState>(TState state): Inicia um escopo de logging.
  • IsEnabled(LogLevel logLevel): Verifica se um nível de log está habilitado.
  • Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception? exception, Func<TState, Exception?, string> formatter): Registra uma mensagem de log.

NewGuid

Uma classe para gerar GUIDs sequenciais.

Métodos
  • NewSequentialGuid(): Gera um novo GUID sequencial baseado no timestamp e tipo de banco de dados.

FileTools

Uma classe para operações comuns com arquivos.

Métodos
  • ReadAllTextAsync(string filePath, Encoding? encoding = null): Lê todo o conteúdo de um arquivo de forma assíncrona.
  • ReadAllText(string filePath): Lê todo o conteúdo de um arquivo.
  • WriteText(string? filePath, string text, Encoding? encoding = null, bool replace = false): Escreve texto em um arquivo.
  • WriteAllBytes(string filePath, byte[] bytes, bool replace = false): Escreve bytes em um arquivo.
  • WriteTextAsync(string? filePath, string text, Encoding? encoding = null): Escreve texto em um arquivo de forma assíncrona.
  • DetectFileEncoding(string filename, Encoding? defaultEncoding = null): Detecta a codificação de um arquivo.
  • NomeArquivo(string? filePath): Retorna o nome do arquivo de um caminho especificado.
  • PastaSomente(string? nomeArquivoCompleto): Retorna o nome da pasta de um caminho especificado.
  • PastaTemporaria(): Retorna o caminho da pasta temporária.
  • NomeArquivoSemExtensao(string? filePath): Retorna o nome do arquivo sem a extensão.
  • Extensao(string? filePath): Retorna a extensão do arquivo.
  • GetBuildDate(): Retorna a data de compilação do assembly.
  • ArquivoExiste(string arquivo): Verifica se um arquivo existe.
  • PastaExiste(string pasta): Verifica se uma pasta existe.
  • CriaDiretorio(string path): Cria um diretório.
  • Combina(string pasta, string arquivo): Combina uma pasta e um arquivo em um caminho.
  • UltimoLog(string pasta): Retorna o último arquivo de log na pasta especificada.
  • LogDiaAnterior(string pasta): Retorna o arquivo de log do dia anterior na pasta especificada.
  • Excluir(string arquivo): Exclui um arquivo.
  • Mover(string arquivoOrigem, string arquivoDestino): Move um arquivo de origem para um arquivo de destino.
  • DataCriacao(string arq): Retorna a data de criação de um arquivo.

EventBaseClass

Uma classe base para eventos.

Métodos
  • Message(string mensagem, string origem = "", int line = 0, string path = ""): Dispara um evento de mensagem.
  • Error(string mensagem, string origem = "", int line = 0, string path = ""): Dispara um evento de erro.
  • Error(Exception e, string origem = "", int line = 0, string path = ""): Dispara um evento de exceção.
  • Rows(float registros): Dispara um evento de quantidade de registros.
  • Progresso(float progresso): Dispara um evento de progresso.

DataPadrao

Uma classe para manipulação de datas padrão.

Propriedades
  • Brasilia: Retorna a data e hora atual de Brasília.
  • Maquina: Retorna a data e hora atual da máquina.
  • DataBrasiliaToMSSQL: Retorna a data e hora atual de Brasília no formato MSSQL.
  • MinValue: Retorna a data mínima no MySQL.

Cripto

Uma classe para criptografia.

Métodos
  • GetKey(): Gera a chave de criptografia válida.
  • Encrypt(string texto): Criptografa um texto.
  • Decrypt(string textoCriptografado): Descriptografa um texto criptografado.

Conversores

Uma classe para conversão de tipos de dados.

Métodos
  • ToDataHora(string expressao): Converte uma string para DateTime.
  • ToDataHora(object objeto): Converte um objeto para DateTime.
  • DateToString(DateTime dataHora): Converte um DateTime para string no formato "yyyy-MM-dd HH:mm:ss".
  • ToDecimal(string? expressao): Converte uma string para decimal.
  • ToDecimal(object? expressao): Converte um objeto para decimal.
  • ToDouble(string? expressao): Converte uma string para double.
  • ToDouble(object? expressao): Converte um objeto para double.
  • ToInt(string? expressao): Converte uma string para int.
  • ToInt(object? expressao): Converte um objeto para int.
  • ToInt(bool valor): Converte um bool para int.
  • ToInt(this bool? valor): Converte um bool? para int?.
  • ToBool(int valor): Converte um int para bool.
  • ToBool(string? expressao): Converte uma string para bool.
  • ToBool(object? objeto): Converte um objeto para bool.
  • ToBool(this int? valor): Converte um int? para bool?.
  • PropriedadeTipo(PropertyInfo p): Retorna o tipo de uma propriedade.
  • Right(string value, int size): Retorna os últimos caracteres de uma string.
  • SubstituiDiacritico(this string texto): Substitui caracteres diacríticos em uma string.
  • RemoveCaracteresEspeciais(this string texto, bool aceitaEspaco = true, bool substituiAcentos = false, bool substituiPontos = true): Remove caracteres especiais de uma string.
  • RemovePontos(this string texto): Remove pontos de uma string.
  • ToVersion(string texto): Converte uma string para Version.
  • RetornaNumeros(string texto): Retorna apenas os números de uma string.
  • ToJson<T>(T? obj, bool writeIndent = false): Converte um objeto para JSON.
  • ToJson(this object? obj, bool writeIndent = false): Converte um objeto para JSON.
  • ToJsonUtf8(Object obj): Converte um objeto para JSON em bytes UTF-8.
  • FromJson<T>(string obj) where T : class: Converte uma string JSON para um objeto.
  • FromJson(string? obj, Type type): Converte uma string JSON para um objeto de um tipo específico.
  • FromJson(string? obj, string? assemblyQualifiedName): Converte uma string JSON para um objeto de um tipo específico.
  • FromJson<T>(byte[] bytes) where T : class: Converte bytes JSON para um objeto.
  • FromJson(byte[] obj, Type type): Converte bytes JSON para um objeto de um tipo específico.
  • FromJson(byte[] obj, string assemblyQualifiedName): Converte bytes JSON para um objeto de um tipo específico.

Instalação

Para instalar o pacote, use o seguinte comando:

<pre>dotnet add package Yordi.Tools</pre>

Uso

Aqui estão alguns exemplos de como usar as ferramentas: <pre> using Yordi.Tools; // Exemplo de uso do ValidaObjetos bool isEmail = ValidaObjetos.IsEmail("example@example.com"); bool isCPF = ValidaObjetos.IsCPF("123.456.789-09"); // Exemplo de uso do LoggerYordi var logger = LoggerYordi.LoggerInstance(); logger.Log(LogLevel.Information, new EventId(), "Mensagem de log", null, (state, exception) ⇒ state.ToString()); // Exemplo de uso do NewGuid Guid newGuid = NewGuid.NewSequentialGuid(); // Exemplo de uso do FileTools string content = FileTools.ReadAllText("example.txt"); FileTools.WriteText("example.txt", "Hello, World!"); // Exemplo de uso do EventBaseClass var eventBase = new EventBaseClass(); eventBase.Message("Mensagem de evento"); // Exemplo de uso do DataPadrao DateTime brasiliaTime = DataPadrao.Brasilia; // Exemplo de uso do Cripto var cripto = new Cripto("chave"); string encrypted = cripto.Encrypt("texto"); string? decrypted = cripto.Decrypt(encrypted); // Exemplo de uso do Conversores int intValue = Conversores.ToInt("123"); bool boolValue = Conversores.ToBool("true"); </pre>

Contribuição

Se você quiser contribuir para o projeto, por favor, siga as diretrizes de contribuição.

Licença

Este projeto está licenciado sob a licença MIT.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on Yordi.Tools:

Package Downloads
Yordi.EntityMultiSQL

Framework para criar instruções SQL para SQLite, MySQL e MSSQL. CRUD, cria tabelas e campos com base nos objetos POCO.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.3 61 2/19/2025
1.0.1 65 2/14/2025
1.0.0 85 2/13/2025 1.0.0 is deprecated because it has critical bugs.