SOAP WSDL Generate Code

Application / get_pdf

ASP AutoIt C C (Unicode) C++ C++ (Unicode) C# DataFlex Delphi Foxpro Go Java Node.js Objective-C Perl PHP Extension PowerBuilder Powershell PureBasic Python CkPython Ruby SQL Server Swift TCL VB.NET VB6 VBScript Xojo
load ./chilkat.dll

set xml [new_CkXml]

CkXml_put_Tag $xml "soapenv:Envelope"
CkXml_AddAttribute $xml "xmlns:soapenv" "http://schemas.xmlsoap.org/soap/envelope/"
CkXml_AddAttribute $xml "xmlns:sta" "http://facturacion.finkok.com/stamp"
CkXml_UpdateChildContent $xml "soapenv:Header" ""
CkXml_UpdateChildContent $xml "soapenv:Body|sta:get_pdf|sta:username" "string"
CkXml_UpdateChildContent $xml "soapenv:Body|sta:get_pdf|sta:password" "string"
CkXml_UpdateChildContent $xml "soapenv:Body|sta:get_pdf|sta:uuid" "string"
CkXml_UpdateChildContent $xml "soapenv:Body|sta:get_pdf|sta:notes" "string"
CkXml_UpdateChildContent $xml "soapenv:Body|sta:get_pdf|sta:status" "string"

# In a SOAP HTTP request, including the XML declaration (<?xml version="1.0" encoding="UTF-8"?>) in the XML body is generally not required. 
CkXml_put_EmitXmlDecl $xml 0
set soapRequestBody [CkXml_getXml $xml]

set endpoint "https://demo-facturacion.finkok.com/servicios/soap/stamp"
set soapAction "get_pdf"
#  For SOAP requests, the standard Content-Type is usually set to "text/xml" or "application/soap+xml"
set contentType "text/xml"

set http [new_CkHttp]

CkHttp_ClearHeaders $http
CkHttp_SetRequestHeader $http "Content-Type" $contentType
CkHttp_SetRequestHeader $http "SOAPAction" $soapAction

# resp is a CkHttpResponse
set resp [CkHttp_PostXml $http $endpoint $soapRequestBody "utf-8"]
if {[CkHttp_get_LastMethodSuccess $http] == 0} then {
    puts [CkHttp_lastErrorText $http]
    puts "Failed to send SOAP request."
    delete_CkXml $xml
    delete_CkHttp $http
    exit
}

# Get the XML response body.
set responseXml [new_CkXml]

CkHttpResponse_GetBodyXml $resp $responseXml

set statusCode [CkHttpResponse_get_StatusCode $resp]
puts "response status code: $statusCode"

delete_CkHttpResponse $resp

# If the status code does not indicate succcess, then show the response XML,
# which probably contains error information.
if {$statusCode != 200} then {
    puts [CkXml_getXml $responseXml]
    delete_CkXml $xml
    delete_CkHttp $http
    delete_CkXml $responseXml
    exit
}

puts [CkXml_getXml $responseXml]

# Parse the successful SOAP response XML.

# This is a sample of the response XML, but the namespace prefixes will be different.
# We can parse the result using "*" for the namespace prefixes (see below).

set pdf [CkXml_getChildContent $responseXml "*:Body|*:get_pdfResponse|*:get_pdfResult|*:pdf"]
set error [CkXml_getChildContent $responseXml "*:Body|*:get_pdfResponse|*:get_pdfResult|*:error"]

delete_CkXml $xml
delete_CkHttp $http
delete_CkXml $responseXml
Request XML
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:sta="http://facturacion.finkok.com/stamp">
    <soapenv:Header/>
    <soapenv:Body>
        <sta:get_pdf>
            <sta:username>string</sta:username>
            <sta:password>string</sta:password>
            <sta:uuid>string</sta:uuid>
            <sta:notes>string</sta:notes>
            <sta:status>string</sta:status>
        </sta:get_pdf>
    </soapenv:Body>
</soapenv:Envelope>
Response XML
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:sta="http://facturacion.finkok.com/stamp" xmlns:s0="apps.services.soap.core.views">
    <soapenv:Header/>
    <soapenv:Body>
        <sta:get_pdfResponse>
            <sta:get_pdfResult>
                <s0:pdf>BqozVXeZZg==</s0:pdf>
                <s0:error>string</s0:error>
            </sta:get_pdfResult>
        </sta:get_pdfResponse>
    </soapenv:Body>
</soapenv:Envelope>