Creación de VEPs para entidades externas (WSCREATEVEP)


Solicitud
import (
    "fmt"
    "strings"
    "net/http"
    "io/ioutil"
    "encoding/json"
)

// Deben cambiar los datos de "params" por los que correspondan. 
// Esta request de ejemplo incluye todos posibles valores para 
// llamar al metodo createVEP, puede que algun valor sea opcional.
requestData, _ := json.Marshal(map[string]any {
    "environment" : "dev",
    "method" : "createVEP",
    "wsid" : "setipagob2b_createvep",
    "params" : map[string]any {
        "token" : "string",
        "sign" : "string",
        "entidadDePago" : 1,
        "vep" : map[string]any {
            "nroVEP" : 1,
            "fechaHoraCreacion" : "string",
            "fechaExpiracion" : "string",
            "fechaVencimiento" : "string",
            "nroFormulario" : 1,
            "orgRecaudDesc" : "string",
            "codTipoPago" : 1,
            "pagoDesc" : "string",
            "pagoDescExtracto" : "string",
            "usuarioCUIT" : 1,
            "autorizanteCUIT" : 1,
            "contribuyenteCUIT" : 1,
            "establecimiento" : 1,
            "concepto" : 1,
            "conceptoDesc" : "string",
            "subConcepto" : 1,
            "subConceptoDesc" : "string",
            "periodoFiscal" : 1,
            "anticipoCuota" : 1,
            "importe" : 1.5,
            "ownerCuit" : 1,
            "ownerTransactionId" : 1,
            "Detalles" : map[string]any {
                "Detalle" : [...]any {
                    map[string]any {
                        "campo" : 1,
                        "campoTipo" : "string",
                        "campoDesc" : "string",
                        "contenido" : "string",
                        "contenidoDesc" : "string",
                    },
                },
            },
            "Obligaciones" : map[string]any {
                "Obligacion" : [...]any {
                    map[string]any {
                        "impuesto" : 1,
                        "impuestoDesc" : "string",
                        "importe" : 1.5,
                    },
                },
            },
        },
    },
})

// Creamos un cliente HTTP para llamar a la API
clientRequest := &http.Client {}
urlRequest := "https://app.afipsdk.com/api/v1/afip/requests"
methodRequest := "POST"
reqRequest, _ := http.NewRequest(methodRequest, urlRequest, strings.NewReader(string(requestData)))

// Reemplazar con tu access_token obtenido de https://app.afipsdk.com
accessToken := "TU_TOKEN_AQUI"
reqRequest.Header.Add("Authorization", "Bearer " + accessToken)

// Realizamos la llamada a la API
reqRequest.Header.Add("Content-Type", "application/json")
resRequest, _ := clientRequest.Do(reqRequest)
defer resRequest.Body.Close()
bodyRequest, _ := ioutil.ReadAll(resRequest.Body)

// En caso de error lo mostramos por consola
if resRequest.StatusCode >= 400 {
    var responseError map[string]any
    json.Unmarshal([]byte(string(bodyRequest)), &responseError)
    responseErrorString, _ := json.MarshalIndent(responseError, "", "    ")
    fmt.Println(string(responseErrorString))
    return
}

// Convertimos la respuesta en un objeto
var response map[string]any
json.Unmarshal([]byte(string(bodyRequest)), &response)

// Mostramos la respuesta por consola
responseString, _ := json.MarshalIndent(response, "", "    ")
fmt.Println(string(responseString))
Respuesta
{
    "createVEPReturn": "long"
}