Dúvida relacionada a utilização do Serviço windows
Estou com a seguinte dúvida, tenho um serviço windows, e nele após ler o arquivo eu movo esse arquivo para uma outra pasta, porém caso algum código de barras que existe dentro desse arquivo não estiver cadastrado na minha base de dados, eu não irei inserir numa outra determinada tabela, estou explicando somente o processo.
Agora minha dúvida:
No log gerado, eu informo esse código de barras que não foi inserido por esse motivo, porém gostaria de saber como eu poderia fazer para informar a pessoa responsável, que o código de barras tal não foi inserido na determinada tabela do banco por não esta cadastrado, existe uma forma de enviar um email informando esse código de barras e solicitando para que a mesma cadastre o mesmo? como eu poderia fazer a códificação para o e- mail?
//Método InsertLog
private static void InsertLog(string linha)
{
//Cria Pasta de Log, Caso não exista
if (!Directory.Exists(PastaArquivoLog))
{
Directory.CreateDirectory(PastaArquivoLog);
}
//Cria Arquivo de Log, Caso não exista
string FullPath = PastaArquivoLog+ "\\Log de Processamento de comprovantes.txt";
if (!File.Exists(FullPath))
{
using (File.Create(FullPath)) ;
}
//Escreve no arquivo de LOG
using (StreamWriter file = new StreamWriter(FullPath,true))
{
file.WriteLine(linha);
file.Dispose();
}
}
//Aqui eu busco todos os proc_inter da tabela sdpj_proc_interessado
//que possui o código de barras lido no arquivo, somente para vocês entenderem aonde quero chegar.
private static string GetCodProcInter(string CodBarra)
{
using (DB db = new DB())
{
string SQL = string.Format(@"SELECT T0.cod_proc_inter FROM sdpj_proc_inter T0 WHERE T0.cod_barras_banestes = '{0}'",CodBarra);
var dados = db.ExecutaComandoComRetorno(SQL);
if(dados.Read())
{
return dados["cod_proc_inter"].ToString();
}
}
return "";
}
//Esse método, eu utilizo para mover os arquivos lidos.
private static void MoveFile(string FileName)
{
try
{
PastaArquivosImportados += "\\" + FileName;
PastaArquivosPendentes += "\\" + FileName;
File.Move(PastaArquivosPendentes, PastaArquivosImportados);
}
catch (Exception)
{
throw;
}
}
//Nesse método eu percorro todas as linhas, até eu encontrar as informações que
//eu necessido ler e gravar.
private static void ProcessaArquivo(string FullPathFile, string FileName)
{
try
{
bool Mover = true;
string[] StringLinha = System.IO.File.ReadAllLines(FullPathFile);
string CodBarra = "";
for (int line = 0; line < StringLinha.Length; line++)
{
string DtAgendamento = "";
string VlrDocumento = "";
string Protocolo = "";
string Registro = "";
string Emissao = "";
#region Recupera o Código de Barra
if (StringLinha[line].Contains("Cod. Barras:"))
{
CodBarra += StringLinha[line].Replace("Cod. Barras:", "");
line += 2;
}
if (CodBarra != "")
{
CodBarra += StringLinha[line];
CodBarra = CodBarra.Replace(" ", "");
}
#endregion
if (CodBarra == "")
continue;
line += 6;
#region Data de Agendamento
if (StringLinha[line].Contains("Dt.Agendamento:"))
{
DtAgendamento += StringLinha[line].Replace("Dt.Agendamento:", "").Replace(" ", " ");
}
#endregion
line += 2;
#region Valor do Documentos
if (StringLinha[line].Contains("Vlr.Documento:"))
{
VlrDocumento += StringLinha[line].Replace("Vlr.Documento:", "").Replace(" ", "");
}
#endregion
line += 2;
#region Protocolo
if (StringLinha[line].Contains("Protocolo:"))
{
Protocolo += StringLinha[line].Replace("Protocolo:", "").Replace(" ", "");
}
#endregion
line += 12;
#region Registro
if (StringLinha[line].Contains("Registro:"))
{
Registro += StringLinha[line].Replace("Registro:", "");
}
#endregion
line += 2;
#region Emissao
if (StringLinha[line].Contains("Emissao.:"))
{
Emissao += StringLinha[line].Replace("Emissao.:", "");
}
#endregion
//Busca Código de Barra
string CodProcInter = GetCodProcInter(CodBarra);
if (!string.IsNullOrEmpty(CodProcInter))
{
if(!CodBarraJaInserido(CodBarra))
{
//Insere Código de Barra
bool inserido = InsereDadosBanco(CodProcInter,CodBarra,DtAgendamento,VlrDocumento,Protocolo,Registro,Emissao);
}
else
{
//Código de Barra já Inserido
InsertLog("\n Já Existe -> " + CodBarra);
}
}
else
{
//Código de Barra não esta disponível na tabela -> sdpj_proc_inter
//caso ele não esteja disponivel, devo comunicar a pessoa responsável, enviando o numero do código de barras para essa pessoa, como fazer?
Mover = false;
InsertLog("\n Cód. Barra Não disponível -> " + CodBarra);
}
//Limpar Variaveis
CodBarra = "";
}
if (Mover)
{
MoveFile(FileName);
}
}
catch (Exception)
{
throw;
}
}
Nessa parte do código mora a minha dúvida.
if (!string.IsNullOrEmpty(CodProcInter))
{
if(!CodBarraJaInserido(CodBarra))
{
//Insere Código de Barra
bool inserido = InsereDadosBanco(CodProcInter,CodBarra,DtAgendamento,VlrDocumento,Protocolo,Registro,Emissao);
}
else
{
//Código de Barra já Inserido
InsertLog("\n Já Existe -> " + CodBarra);
}
}
else
{
//Código de Barra não esta disponível na tabela -> sdpj_proc_inter
//caso ele não esteja disponivel, devo comunicar a pessoa responsável, enviando o numero do código de barras para essa pessoa, como fazer?
Mover = false;
InsertLog("\n Cód. Barra Não disponível -> " + CodBarra);
}Discussão (3)
Carregando comentários...