FrameAppWS

<back to all web services

AMDCValidaPagoRQ

Requires Authentication
The following routes are available for this service:
All Verbs/pago/ValidarPagosArticulo
import Foundation
import ServiceStack

public class AMDCValidaPagoRQ : DatosBanco
{
    public var numeroDocumento:String
    public var banco:String
    public var sucursal:String
    public var usuario:String
    public var terminal:String

    required public init(){ super.init() }

    private enum CodingKeys : String, CodingKey {
        case numeroDocumento
        case banco
        case sucursal
        case usuario
        case terminal
    }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
        let container = try decoder.container(keyedBy: CodingKeys.self)
        numeroDocumento = try container.decodeIfPresent(String.self, forKey: .numeroDocumento)
        banco = try container.decodeIfPresent(String.self, forKey: .banco)
        sucursal = try container.decodeIfPresent(String.self, forKey: .sucursal)
        usuario = try container.decodeIfPresent(String.self, forKey: .usuario)
        terminal = try container.decodeIfPresent(String.self, forKey: .terminal)
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
        var container = encoder.container(keyedBy: CodingKeys.self)
        if numeroDocumento != nil { try container.encode(numeroDocumento, forKey: .numeroDocumento) }
        if banco != nil { try container.encode(banco, forKey: .banco) }
        if sucursal != nil { try container.encode(sucursal, forKey: .sucursal) }
        if usuario != nil { try container.encode(usuario, forKey: .usuario) }
        if terminal != nil { try container.encode(terminal, forKey: .terminal) }
    }
}

public class DatosBanco : Codable
{
    public var banco:String
    public var sucursal:String
    public var usuario:String
    public var terminal:String

    required public init(){}
}

public class AMDCValidaPagoRS : CoreRes
{
    public var listaPagosRoot:[ValidarPago] = []
    public var tranId:String
    public var code:String
    public var infoMsg:String

    required public init(){ super.init() }

    private enum CodingKeys : String, CodingKey {
        case listaPagosRoot
        case tranId
        case code
        case infoMsg
    }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
        let container = try decoder.container(keyedBy: CodingKeys.self)
        listaPagosRoot = try container.decodeIfPresent([ValidarPago].self, forKey: .listaPagosRoot) ?? []
        tranId = try container.decodeIfPresent(String.self, forKey: .tranId)
        code = try container.decodeIfPresent(String.self, forKey: .code)
        infoMsg = try container.decodeIfPresent(String.self, forKey: .infoMsg)
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
        var container = encoder.container(keyedBy: CodingKeys.self)
        if listaPagosRoot.count > 0 { try container.encode(listaPagosRoot, forKey: .listaPagosRoot) }
        if tranId != nil { try container.encode(tranId, forKey: .tranId) }
        if code != nil { try container.encode(code, forKey: .code) }
        if infoMsg != nil { try container.encode(infoMsg, forKey: .infoMsg) }
    }
}

public class CoreRes : Codable
{
    public var tranId:String
    public var code:String
    public var infoMsg:String

    required public init(){}
}

public class ValidarPago : Codable
{
    public var idPagoPasarela:Int
    public var estado:String
    public var requesT_PAGO:RequestPago
    public var responsE_PAGO:ResponsePago

    required public init(){}
}

public class RequestPago : Codable
{
    public var solicitudPago:SolicitudPago

    required public init(){}
}

public class SolicitudPago : Codable
{
    public var idTransaccionBanco:String
    public var fechaTransaccionBanco:Int
    public var horaMinSeg:Int
    public var numeroDocumento:String
    public var idTipoImpuesto:Int
    public var pagoParcial:Int
    public var anio:Int
    public var pagoArticulos:[PagoArticulo] = []

    required public init(){}
}

public class PagoArticulo : Codable
{
    public var idObligacion:Int
    public var monto:Double

    required public init(){}
}

public class ResponsePago : Codable
{
    public var pagoRespuesta:ResultadoPago

    required public init(){}
}

public class ResultadoPago : ResultadoTransaccion
{
    public var idPago:Int
    public var checkSum:String
    public var resultado:String
    // @DataMember(Name="Mensaje")
    public var Mensaje:String

    public var fechaTransaccion:String

    required public init(){ super.init() }

    private enum CodingKeys : String, CodingKey {
        case idPago
        case checkSum
        case resultado
        case Mensaje
        case fechaTransaccion
    }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
        let container = try decoder.container(keyedBy: CodingKeys.self)
        idPago = try container.decodeIfPresent(Int.self, forKey: .idPago)
        checkSum = try container.decodeIfPresent(String.self, forKey: .checkSum)
        resultado = try container.decodeIfPresent(String.self, forKey: .resultado)
        Mensaje = try container.decodeIfPresent(String.self, forKey: .Mensaje)
        fechaTransaccion = try container.decodeIfPresent(String.self, forKey: .fechaTransaccion)
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
        var container = encoder.container(keyedBy: CodingKeys.self)
        if idPago != nil { try container.encode(idPago, forKey: .idPago) }
        if checkSum != nil { try container.encode(checkSum, forKey: .checkSum) }
        if resultado != nil { try container.encode(resultado, forKey: .resultado) }
        if Mensaje != nil { try container.encode(Mensaje, forKey: .Mensaje) }
        if fechaTransaccion != nil { try container.encode(fechaTransaccion, forKey: .fechaTransaccion) }
    }
}

public class ResultadoTransaccion : Codable
{
    public var resultado:String
    // @DataMember(Name="Mensaje")
    public var Mensaje:String

    public var fechaTransaccion:String

    required public init(){}
}


Swift AMDCValidaPagoRQ DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml

HTTP + XML

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /pago/ValidarPagosArticulo HTTP/1.1 
Host: soluser-recaudo.sgsas.co 
Accept: application/xml
Content-Type: application/xml
Content-Length: length

<AMDCValidaPagoRQ xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Tipo.Pago">
  <Banco xmlns="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Contexto.General">String</Banco>
  <Sucursal xmlns="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Contexto.General">String</Sucursal>
  <Terminal xmlns="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Contexto.General">String</Terminal>
  <Usuario xmlns="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Contexto.General">String</Usuario>
  <NumeroDocumento>String</NumeroDocumento>
</AMDCValidaPagoRQ>
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length

<AMDCValidaPagoRS xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Tipo.Pago">
  <Code xmlns="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Contexto.General">String</Code>
  <InfoMsg xmlns="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Contexto.General">String</InfoMsg>
  <TranId xmlns="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Contexto.General">String</TranId>
  <ListaPagosRoot xmlns:d2p1="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Contexto.Pago">
    <d2p1:ValidarPago>
      <d2p1:Estado>String</d2p1:Estado>
      <d2p1:IdPagoPasarela>0</d2p1:IdPagoPasarela>
      <d2p1:REQUEST_PAGO>
        <d2p1:SolicitudPago>
          <d2p1:Anio>0</d2p1:Anio>
          <d2p1:FechaTransaccionBanco>0</d2p1:FechaTransaccionBanco>
          <d2p1:HoraMinSeg>0</d2p1:HoraMinSeg>
          <d2p1:IdTipoImpuesto>0</d2p1:IdTipoImpuesto>
          <d2p1:IdTransaccionBanco>String</d2p1:IdTransaccionBanco>
          <d2p1:NumeroDocumento>String</d2p1:NumeroDocumento>
          <d2p1:PagoArticulos>
            <d2p1:PagoArticulo>
              <d2p1:IdObligacion>0</d2p1:IdObligacion>
              <d2p1:Monto>0</d2p1:Monto>
            </d2p1:PagoArticulo>
          </d2p1:PagoArticulos>
          <d2p1:PagoParcial>0</d2p1:PagoParcial>
        </d2p1:SolicitudPago>
      </d2p1:REQUEST_PAGO>
      <d2p1:RESPONSE_PAGO>
        <d2p1:PagoRespuesta>
          <FechaTransaccion xmlns="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Contexto.General">String</FechaTransaccion>
          <MensajeResultado xmlns="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Contexto.General">String</MensajeResultado>
          <Resultado xmlns="http://schemas.datacontract.org/2004/07/AMDC.Modelo.Contexto.General">String</Resultado>
          <d2p1:CheckSum>String</d2p1:CheckSum>
          <d2p1:IdPago>0</d2p1:IdPago>
        </d2p1:PagoRespuesta>
      </d2p1:RESPONSE_PAGO>
    </d2p1:ValidarPago>
  </ListaPagosRoot>
</AMDCValidaPagoRS>