Consumir Comunicaciones de Ventanilla Electrónica


Solicitud
using System.Net.Http;
using System.Text;
using Newtonsoft.Json;

// Deben cambiar los datos de "params" por los que correspondan. 
// Esta request de ejemplo incluye todos posibles valores para 
// llamar al metodo consumirComunicacion, puede que algun valor sea opcional.
var data = new Dictionary<string, object> {
    ["environment"] = "dev",
    ["method"] = "consumirComunicacion",
    ["wsid"] = "veconsumerws",
    ["params"] = new Dictionary<string, object> {
        ["authRequest"] = new Dictionary<string, object> {
            ["token"] = "string",
            ["sign"] = "string",
            ["cuitRepresentada"] = 1
        },
        ["idComunicacion"] = 1,
        ["incluirAdjuntos"] = true
    }
};

// Creamos un cliente HTTP para llamar a la API
var requestClient = new HttpClient();
var requestUrl = "https://app.afipsdk.com/api/v1/afip/requests";

// Reemplazar con tu access_token obtenido de https://app.afipsdk.com
var accessToken = "TU_TOKEN_AQUI";
requestClient.DefaultRequestHeaders.Add("Authorization", $"Bearer {accessToken}"); 

// Realizamos la llamada a la API
var dataJSON = new StringContent(JsonConvert.SerializeObject(data), Encoding.UTF8, "application/json");
var requestResponse = await requestClient.PostAsync(requestUrl, dataJSON);

// En caso de error lo mostramos por consola
if (!requestResponse.IsSuccessStatusCode) {
    Console.WriteLine($"Error en la request: {requestResponse.StatusCode}");
    var errorResponse = JsonConvert.DeserializeObject(await requestResponse.Content.ReadAsStringAsync());
    Console.WriteLine(errorResponse);

    return;
}

// Obtenemos la respuesta
var requestResponseBody = await requestResponse.Content.ReadAsStringAsync();

// Convertimos la respuesta en un objeto
dynamic response = JsonConvert.DeserializeObject(requestResponseBody);

// Mostramos la respuesta por consola
Console.WriteLine(response);
Respuesta
{
    "Comunicacion": {
        "idComunicacion": "long",
        "cuitDestinatario": "long",
        "fechaPublicacion": "string",
        "fechaVencimiento": "string",
        "sistemaPublicador": "long",
        "sistemaPublicadorDesc": "string",
        "estado": "integer",
        "estadoDesc": "string",
        "asunto": "string",
        "prioridad": "integer",
        "tieneAdjunto": "bool",
        "referencia1": "string",
        "referencia2": "string",
        "mensaje": "string",
        "tiempoDeVida": "integer",
        "adjuntos": {
            "adjunto": [
                "string"
            ]
        }
    }
}