Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Objective-C) hacienda.go.cr Recepción de comprobantes electrónicos y respuestas del receptor.Comprobantes Electrónicos API version v1 -- Recepción de comprobantes electrónicos y respuestas del receptor. For more information, see https://www.hacienda.go.cr/ATV/ComprobanteElectronico/docs/esquemas/2016/v4.1/comprobantes-electronicos-api.html#recepcion_post
#import <CkoHttp.h> #import <CkoBinData.h> #import <CkoJsonObject.h> #import <CkoHttpResponse.h> // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkoHttp *http = [[CkoHttp alloc] init]; BOOL success; // Implements the following CURL command: // curl -X POST -H "Content-Type: application / json" \ // -H 'authorization: Bearer {access_token}' \ // -d '{ // "clave": "50601011600310112345600100010100000000011999999999", // "fecha": "2016-01-01T00:00:00-0600", // "emisor": { // "tipoIdentificacion": "02", // "numeroIdentificacion": "003101123456" // }, // "receptor": { // "tipoIdentificacion": "02", // "numeroIdentificacion": "003101123456" // }, // "comprobanteXml": "PD94..." // }' https://api.comprobanteselectronicos.go.cr/recepcion/v1/recepcion // Use the following online tool to generate HTTP code from a CURL command // Convert a cURL Command to HTTP Source Code // Use this online tool to generate code from sample JSON: // Generate Code to Create JSON // The following JSON is sent in the request body. // { // "clave": "50601011600310112345600100010100000000011999999999", // "fecha": "2016-01-01T00:00:00-0600", // "emisor": { // "tipoIdentificacion": "02", // "numeroIdentificacion": "003101123456" // }, // "receptor": { // "tipoIdentificacion": "02", // "numeroIdentificacion": "003101123456" // }, // "comprobanteXml": "PD94b..." // } // Load the previously signed XML. CkoBinData *bdSignedXml = [[CkoBinData alloc] init]; success = [bdSignedXml LoadFile: @"someDir/signed.xml"]; if (success == NO) { NSLog(@"%@",@"Failed to load the XAdES signed XML."); return; } CkoJsonObject *json = [[CkoJsonObject alloc] init]; [json UpdateString: @"clave" value: @"50601011600310112345600100010100000000011999999999"]; [json UpdateString: @"fecha" value: @"2016-01-01T00:00:00-0600"]; [json UpdateString: @"emisor.tipoIdentificacion" value: @"02"]; [json UpdateString: @"emisor.numeroIdentificacion" value: @"003101123456"]; [json UpdateString: @"receptor.tipoIdentificacion" value: @"02"]; [json UpdateString: @"receptor.numeroIdentificacion" value: @"003101123456"]; // Add the base64 encoded representation of the signed XML. [json UpdateString: @"comprobanteXml" value: [bdSignedXml GetEncoded: @"base64"]]; // Load our previously obtained OAuth2 access token. CkoJsonObject *jsonToken = [[CkoJsonObject alloc] init]; BOOL success = [jsonToken LoadFile: @"qa_data/tokens/hacienda_cr.json"]; if (success != YES) { NSLog(@"%@",@"Failed to load constantContact.json"); return; } // Adds the "Authorization: Bearer {access_token}" header. http.AuthToken = [jsonToken StringOf: @"access_token"]; [http SetRequestHeader: @"Content-Type" value: @"application / json"]; CkoHttpResponse *resp = [http PostJson3: @"https://api.comprobanteselectronicos.go.cr/recepcion/v1/recepcion" contentType: @"application/json" json: json]; if (http.LastMethodSuccess == NO) { NSLog(@"%@",http.LastErrorText); return; } // A 201 status code indicates success. NSLog(@"%@%d",@"Response status code: ",[resp.StatusCode intValue]); NSLog(@"%@",@"Response body:"); NSLog(@"%@",resp.BodyStr); |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.