/// <summary> /// Recupera información de interés del servicio y la envía en un archivo a un servidor FTP especificado /// </summary> /// <param name="secuencia">Secuencia de notificación del servicio</param> /// <param name="codificacion">Codificación del archivo</param> /// <returns></returns> private RetornoOperacion enviaInformacionServicioFTP(int secuencia, System.Text.Encoding codificacion) { //Declarando objeto de resultado sin errores RetornoOperacion resultado = new RetornoOperacion(this._id_servicio); //Obteniendo Proveedores FTP using (DataTable dtProveedoresFTP = SAT_CL.Monitoreo.ProveedorWS.ObtieneProveedoresFTP(this._id_compania_emisor)) { //Validando Proveedores if (Validacion.ValidaOrigenDatos(dtProveedoresFTP)) { //Recorriendo Datos foreach (DataRow dr in dtProveedoresFTP.Rows) { //Validando la Compania if (this._id_compania_emisor == 76) { switch (dr["Identificador"].ToString()) { case "TEM - Omnitracs FTP": { //Realizando la recuperación de información using (DataTable mit = Reportes.CargaInformacionServicioOmnitracs(this._id_servicio, Convert.ToInt32(dr["Id"]))) { //Si hay elementos que utilizar if (mit != null) { //Instanciando compañía a la que pertenece el servicio using (CompaniaEmisorReceptor comp = new CompaniaEmisorReceptor(this._id_compania_emisor)) { //Definiendo variables auxiliares string no_viaje = ""; byte[] bytesArchivo = null; //Creando archivo en memoria using (MemoryStream archivo = new MemoryStream()) { //Creando escritos de texto en flujo StreamWriter escritor = new StreamWriter(archivo, codificacion); //Añadiendo encabezado escritor.Write("OPERACION|FECHA VIAJE|DT|PI ORIGEN|CITA LLEGADA ORIGEN|PI DESTINO|CITA LLEGADA DESTINO|SHIPPER|RUTA MAESTRA|EJE TRANSITO|NIVEL SEGURIDAD|SCAC|OPERADOR|VEHICULO|PLATPORTABLE1|PORTABLE1|TIPO REMOLQUE|REMOLQUE1|PLATPORTABLE2|PORTABLE2|REMOLQUE2|PLATPORTABLE3|PORTABLE3|SHIPPER2|DESCRIPCION|EVENTO LOG1|EVENTO LOG2"); //Dando el formato solicitado para el contenido del archivo foreach (DataRow r in mit.Rows) { //Extrayendo número de viaje no_viaje = Cadena.TruncaCadena(string.Format("{0}{1}", r["DT"].ToString(), secuencia > 0 ? "-" + secuencia.ToString() : ""), 15, ""); //Nueva linea de texto string linea = string.Format("{0}|{1}|NS{2}|{3}|{4}|{5}|{6}|{7}|{8}|{9}|{10}|{11}|{12}|{13}|{14}|{15}|{16}|{17}|{18}|{19}|{20}|{21}|{22}|{23}|{24}|{25}|{26}", Cadena.TruncaCadena(r["Operacion"].ToString(), 3, ""), r.Field <DateTime>("FechaViaje").ToString("dd/MM/yyyy HH:mm"), no_viaje, Cadena.TruncaCadena(r["PiOrigen"].ToString(), 31, ""), r.Field <DateTime>("CitaLlegadaOrigen").ToString("dd/MM/yyyy HH:mm"), Cadena.TruncaCadena(r["PiDestino"].ToString(), 31, ""), r.Field <DateTime>("CitaLlegadaDestino").ToString("dd/MM/yyyy HH:mm"), Cadena.TruncaCadena(r["Shipper"].ToString(), 30, ""), Cadena.TruncaCadena(r["RutaMaestra"].ToString(), 30, ""), Cadena.TruncaCadena(r["EjeTransito"].ToString(), 30, ""), Cadena.TruncaCadena(r["NivelSeguridad"].ToString(), 8, ""), Cadena.TruncaCadena(r["SCAC"].ToString(), 4, ""), Cadena.TruncaCadena(r["Operador"].ToString(), 40, ""), Cadena.TruncaCadena(r["Vehiculo"].ToString(), 30, ""), Cadena.TruncaCadena(r["PlatPortable1"].ToString(), 10, ""), Cadena.TruncaCadena(r["Portable1"].ToString(), 15, ""), Cadena.TruncaCadena(r["TipoRemolque"].ToString(), 30, ""), Cadena.TruncaCadena(r["Remolque1"].ToString(), 30, ""), Cadena.TruncaCadena(r["PlatPortable2"].ToString(), 10, ""), Cadena.TruncaCadena(r["Portable2"].ToString(), 15, ""), Cadena.TruncaCadena(r["Remolque2"].ToString(), 30, ""), Cadena.TruncaCadena(r["PlatPortable3"].ToString(), 10, ""), Cadena.TruncaCadena(r["Portable3"].ToString(), 15, ""), Cadena.TruncaCadena(r["Shipper2"].ToString(), 30, ""), Cadena.TruncaCadena(r["Descripcion"].ToString(), 30, ""), Cadena.TruncaCadena(r["EventoLog1"].ToString(), 15, ""), Cadena.TruncaCadena(r["EventoLog2"].ToString(), 15, "")); //Añadiendo linea creada if (!string.IsNullOrEmpty(linea)) { escritor.Write(Environment.NewLine + linea); } } //Confirmando cambios en flujo y liberando recursos de escritor escritor.Flush(); //Obteniendo arreglo de bytes del flujo de archivo bytesArchivo = TSDK.Base.Flujo.ConvierteFlujoABytes(archivo); } //Recuperando datos de autenticación en servidor FTP string servidorFTP = dr["Endpoint"].ToString(); string usuarioFTP = dr["Usuario"].ToString(); string contrasenaFTP = dr["Contraseña"].ToString(); try { //Definiendo nombre de archivo string nombre_archivo = string.Format("{0}-DT{1}_{2:ddMMyyyy_HHmmss}.csv", comp.nombre_corto, no_viaje, Fecha.ObtieneFechaEstandarMexicoCentro()); //Creando peticioón FTP FtpWebRequest peticionFTP = FTP.CreaPeticionFTP(string.Format("{0}/{1}", servidorFTP, nombre_archivo), WebRequestMethods.Ftp.UploadFile, usuarioFTP, contrasenaFTP); //Dimensionando archivo por transferir en la petición peticionFTP.ContentLength = bytesArchivo.Length; //Recuperando flujo de petición ftp Stream flujoPeticionFTP = peticionFTP.GetRequestStream(); //Añadiendo bytes del archivo creado a flujo de petición (escribiendo) flujoPeticionFTP.Write(bytesArchivo, 0, bytesArchivo.Length); //Cerrando flujo de escritura de archivo flujoPeticionFTP.Close(); } //Si no hubo petición devuelta catch (NullReferenceException) { //En caso de error resultado = new RetornoOperacion(string.Format("Error al crear petición al servidor FTP '{0}'.", servidorFTP)); using (EventLog eventLog = new EventLog("Application")) { eventLog.Source = "Application"; eventLog.WriteEntry(resultado.Mensaje, EventLogEntryType.Information, 101, 1); } } catch (Exception ex) { //En caso de error resultado = new RetornoOperacion(ex.Message); using (EventLog eventLog = new EventLog("Application")) { eventLog.Source = "Application"; eventLog.WriteEntry(resultado.Mensaje, EventLogEntryType.Information, 101, 1); } } } } else { resultado = new RetornoOperacion("No pudo ser recuperada la información del servicio para su envío."); } } break; } case "TEM - Unicomm FTP": { //Realizando la recuperación de información using (DataTable mit = Reportes.CargaInformacionServicioOmnitracs(this._id_servicio, Convert.ToInt32(dr["Id"]))) { //Si hay elementos que utilizar if (mit != null) { //Definiendo variables auxiliares string no_viaje = ""; byte[] bytesArchivo = Excel.BytesDataTableExcel(mit, "Reporte UNICOMM FTP", new string[] { "FechaViaje", "CitaLlegadaDestino", "CitaLlegadaOrigen" }); //Recuperando datos de autenticación en servidor FTP string servidorFTP = dr["Endpoint"].ToString(); string usuarioFTP = dr["Usuario"].ToString(); string contrasenaFTP = dr["Contraseña"].ToString(); //Instanciando compañía a la que pertenece el servicio using (CompaniaEmisorReceptor comp = new CompaniaEmisorReceptor(this._id_compania_emisor)) { try { //Definiendo nombre de archivo string nombre_archivo = string.Format("{0}-DT{1}_{2:ddMMyyyy_HHmmss}.xlsx", comp.nombre_corto, no_viaje, Fecha.ObtieneFechaEstandarMexicoCentro()); //Creando peticioón FTP FtpWebRequest peticionFTP = FTP.CreaPeticionFTP(string.Format("{0}/{1}", servidorFTP, nombre_archivo), WebRequestMethods.Ftp.UploadFile, usuarioFTP, contrasenaFTP); //Dimensionando archivo por transferir en la petición peticionFTP.ContentLength = bytesArchivo.Length; //Recuperando flujo de petición ftp Stream flujoPeticionFTP = peticionFTP.GetRequestStream(); //Añadiendo bytes del archivo creado a flujo de petición (escribiendo) flujoPeticionFTP.Write(bytesArchivo, 0, bytesArchivo.Length); //Cerrando flujo de escritura de archivo flujoPeticionFTP.Close(); //Guardamos el Archivo en la Ruta Especifica Archivo.GuardaArchivoCreandoRuta(bytesArchivo, string.Format(@"{0}UnicommTEM\{1}", SAT_CL.CapaNegocio.m_capaNegocio.RegresaVariableCatalogoBD("Directorio Raíz Gestor Archivos SAT"), nombre_archivo), false); } //Si no hubo petición devuelta catch (NullReferenceException) { //En caso de error resultado = new RetornoOperacion(string.Format("Error al crear petición al servidor FTP '{0}'.", servidorFTP)); using (EventLog eventLog = new EventLog("Application")) { eventLog.Source = "Application"; eventLog.WriteEntry(resultado.Mensaje, EventLogEntryType.Information, 101, 1); } } catch (Exception ex) { //En caso de error resultado = new RetornoOperacion(ex.Message); using (EventLog eventLog = new EventLog("Application")) { eventLog.Source = "Application"; eventLog.WriteEntry(resultado.Mensaje, EventLogEntryType.Information, 101, 1); } } } } } break; } } } } } } //Devolviendo resultado return(resultado); }