public Operation Update(RptaItinerarioSF RptaItinerarioNM) { var operation = new Operation(); #region Parameters AddParameter(OutParameter.CodigoError, OracleDbType.Varchar2, RptaItinerarioNM.CodigoError, ParameterDirection.Input, 2); AddParameter(OutParameter.MensajeError, OracleDbType.Varchar2, RptaItinerarioNM.MensajeError, ParameterDirection.Input, 1000); AddParameter(OutParameter.SF_IDOPORTUNIDAD_NM, OracleDbType.Varchar2, RptaItinerarioNM.idOportunidad_SF); AddParameter(OutParameter.SF_IDITINERARIO_NM, OracleDbType.Varchar2, RptaItinerarioNM.idItinerario_SF); AddParameter(OutParameter.IdIdentificadorNM, OracleDbType.Int64, Convert.ToInt64(RptaItinerarioNM.Identificador_NM)); AddParameter(OutParameter.IdActualizados, OracleDbType.Int32, DBNull.Value, ParameterDirection.Output); #endregion #region Invoke ExecuteStoredProcedure(StoredProcedureName.AW_Upd_DetalleItinerarioNM); operation[OutParameter.IdActualizados] = GetOutParameter(OutParameter.IdActualizados); #endregion return(operation); }
public IHttpActionResult Send(UnidadNegocio unidadNegocio) { IEnumerable <DetalleItinerarioNM> detItinerarioList = null; List <RptaItinerarioSF> ListRptaItinerarioSF_Fail = new List <RptaItinerarioSF>(); RptaItinerarioSF _rptaItinerarioSF = null; object SFResponse = null; string error = string.Empty; object objEnvio = null; try { var _unidadNegocio = RepositoryByBusiness(unidadNegocio.Descripcion.ToUnidadNegocio()); /// I. Consulta de Detalle Itinerario NM detItinerarioList = (IEnumerable <DetalleItinerarioNM>)(_detalleItinerarioNMRepository.GetItinerarios())[OutParameter.CursorDetalleItinerarioNM]; if (detItinerarioList == null || detItinerarioList.ToList().Count.Equals(0)) { return(Ok(false)); } /// II. Obtiene Token y URL para envío a Salesforce var authSf = RestBase.GetToken(); var token = authSf[OutParameter.SF_Token].ToString(); var crmServer = authSf[OutParameter.SF_UrlAuth].ToString(); /// III. Construímos lista para enviar a SF var detItinerarioNM_SF = new List <object>(); foreach (var detItinerario in detItinerarioList) { detItinerarioNM_SF.Add(detItinerario.ToSalesforceEntity()); } try { /// Envío de CuentaNM a Salesforce objEnvio = new { listadatos = detItinerarioNM_SF }; QuickLog(objEnvio, "body_request.json", "DetalleItinerarioNM", previousClear: true); /// ♫ Trace var responseDetItinerarioNM = RestBase.ExecuteByKeyWithServer(crmServer, SalesforceKeys.DetItinerarioNMMethod, Method.POST, objEnvio, true, token); if (responseDetItinerarioNM.StatusCode.Equals(HttpStatusCode.OK)) { dynamic jsonResponse = new JavaScriptSerializer().DeserializeObject(responseDetItinerarioNM.Content); QuickLog(jsonResponse, "body_response.json", "DetalleItinerarioNM", previousClear: true); /// ♫ Trace SFResponse = jsonResponse["respuestas"]; foreach (var item in jsonResponse["respuestas"]) { try { #region Deserialize _rptaItinerarioSF = new RptaItinerarioSF(); _rptaItinerarioSF.CodigoError = "OK"; _rptaItinerarioSF.MensajeError = "TST"; _rptaItinerarioSF.idOportunidad_SF = "006R000000WAUr4IAH"; _rptaItinerarioSF.idItinerario_SF = "006R000000WAUr4IAC"; _rptaItinerarioSF.Identificador_NM = "2"; _rptaItinerarioSF.CodigoError = item[OutParameter.SF_Codigo]; _rptaItinerarioSF.MensajeError = item[OutParameter.SF_Mensaje]; _rptaItinerarioSF.idOportunidad_SF = item[OutParameter.SF_IdOportunidad2]; _rptaItinerarioSF.idItinerario_SF = item[OutParameter.SF_IdItinerario]; _rptaItinerarioSF.Identificador_NM = item[OutParameter.SF_IdentificadorNM]; #endregion #region ReturnToDB var updOperation = _detalleItinerarioNMRepository.Update(_rptaItinerarioSF); if (Convert.IsDBNull(updOperation[OutParameter.IdActualizados]) == true || updOperation[OutParameter.IdActualizados].ToString().ToLower().Contains("null") || Convert.ToInt32(updOperation[OutParameter.IdActualizados].ToString()) <= 0) { error = error + "Error en el Proceso de Actualizacion - No Actualizo Ningun Registro. Identificador NM : " + _rptaItinerarioSF.Identificador_NM.ToString() + "||||"; ListRptaItinerarioSF_Fail.Add(_rptaItinerarioSF); /*Analizar si se deberia grabar en una tabla de bd para posteriormente darle seguimiento*/ } #endregion } catch (Exception ex) { error = error + "Error en el Proceso de Actualizacion - Response SalesForce : " + ex.Message + "||||"; ListRptaItinerarioSF_Fail.Add(_rptaItinerarioSF); /*Analizar si se deberia grabar en una tabla de bd para posteriormente darle seguimiento*/ } } } else { error = responseDetItinerarioNM.StatusCode.ToString(); if (responseDetItinerarioNM != null && responseDetItinerarioNM.Content != null) { QuickLog(responseDetItinerarioNM.Content, "body_response.json", "DetalleItinerarioNM", previousClear: true); /// ♫ Trace } } } catch (Exception ex) { error = ex.Message; } return(Ok(true)); } catch (Exception ex) { error = error + " / " + ex.Message; return(InternalServerError(ex)); } finally { if (objEnvio != null || SFResponse != null || ListRptaItinerarioSF_Fail != null || string.IsNullOrEmpty(error) == false) { (new { Request = objEnvio, Response = SFResponse, Rpta_NoUpdate_Fail = ListRptaItinerarioSF_Fail, Exception = error //LegacySystems = detItinerarioList }).TryWriteLogObject(_logFileManager, _clientFeatures); } } }