Sample code for 30+ languages & platforms
Tcl

Belgium eHealth Platform - AddressBook - Search for Professionals

See more Belgian eHealth Platform Examples

Demonstrates how to search for professionals using the AddressBook API.

Chilkat Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.

# --------------------------------------------------------------------------------
# Also see Chilkat's Online WSDL Code Generator
# to generate code and SOAP Request and Response XML for each operation in a WSDL.
# --------------------------------------------------------------------------------

# Provide a certificate + private key.
# Note: If your certificate + private key is located on a hardware token or smartcard, you can call a different function to load from smartcard..
set cert [new_CkCert]

set success [CkCert_LoadPfxFile $cert "SSIN=12345678.acc.p12" "p12_password"]
if {$success == 0} then {
    puts [CkCert_lastErrorText $cert]
    delete_CkCert $cert
    exit
}

# Let's get the SAML Security Token obtained from https://services-acpt.ehealth.fgov.be/IAM/SecurityTokenService/v1/RequestSecurityToken
# a very short time ago..

# See this example for how we got the SAML security token: eHealth Belgium Request Security Token
set bdSecToken [new_CkBinData]

set success [CkBinData_LoadFile $bdSecToken "qa_data/tokens/ehealth-fgov-be-sectoken.xml"]
if {$success == 0} then {
    puts "Failed to load SAML security token"
    delete_CkCert $cert
    delete_CkBinData $bdSecToken
    exit
}

# The SAML security token is just the part from <Assertion ..> ... </Assertion>
# So let's get just that part..
set startIdx [CkBinData_FindString $bdSecToken "<Assertion" 0 "utf-8"]
if {$startIdx < 0} then {
    puts "Did not find the start of the SAML assertion."
    delete_CkCert $cert
    delete_CkBinData $bdSecToken
    exit
}

set endIdx [CkBinData_FindString $bdSecToken "</Assertion>" 0 "utf-8"]
if {$endIdx < 0} then {
    puts "Did not find the end of the SAML assertion."
    delete_CkCert $cert
    delete_CkBinData $bdSecToken
    exit
}

# Adjust the index to the 1st byte after "</Assertion>"
set endIdx [expr $endIdx + 12]
set base64_saml_token [CkBinData_getEncodedChunk $bdSecToken $startIdx [expr $endIdx - $startIdx] "base64"]

puts "$base64_saml_token"

# Our SOAP request will look like this:

# The SOAP request to search for professionals looks like this:

# <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:add="urn:be:fgov:ehealth:addressbook:protocol:v1">
#     <soapenv:Header>
# 	      <wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd">
# 	         <wsse:BinarySecurityToken
# 	            ValueType="http://docs.oasis-open.org/wss/oasis-wss-saml-token-profile-1.0#SAMLAssertionID"
# 	            EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary">BASE64_SAML_TOKEN</wsse:BinarySecurityToken>
# 	      </wsse:Security>
#     </soapenv:Header>
#     <soapenv:Body>
#         <add:SearchProfessionalsRequest Id="bdc38ae62-3e7f-4f80-80f7-c3e745500fa3" IssueInstant="2016-03-23T18:49:26.968+01:00" Offset="0" MaxElements="100">
#             <add:SSIN>74062423769</add:SSIN>
#         </add:SearchProfessionalsRequest>
#     </soapenv:Body>
# </soapenv:Envelope>

set xml [new_CkXml]

CkXml_put_Tag $xml "soapenv:Envelope"
CkXml_UpdateAttrAt $xml "soapenv:Header|wsse:Security" 1 "xmlns:wsse" "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd"
CkXml_UpdateAttrAt $xml "soapenv:Header|wsse:Security|wsse:BinarySecurityToken" 1 "ValueType" "http://docs.oasis-open.org/wss/oasis-wss-saml-token-profile-1.0#SAMLAssertionID"
CkXml_UpdateAttrAt $xml "soapenv:Header|wsse:Security|wsse:BinarySecurityToken" 1 "EncodingType" "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary"

CkXml_UpdateChildContent $xml "soapenv:Header|wsse:Security|wsse:BinarySecurityToken" $base64_saml_token

CkXml_UpdateAttrAt $xml "soapenv:Body|add:SearchProfessionalsRequest" 1 "Id" "bdc38ae62-3e7f-4f80-80f7-c3e745500fa3"

set dt [new_CkDateTime]

CkDateTime_SetFromCurrentSystemTime $dt
CkXml_UpdateAttrAt $xml "soapenv:Body|add:SearchProfessionalsRequest" 1 "IssueInstant" [CkDateTime_getAsTimestamp $dt 1]

CkXml_UpdateAttrAt $xml "soapenv:Body|add:SearchProfessionalsRequest" 1 "Offset" "0"
CkXml_UpdateAttrAt $xml "soapenv:Body|add:SearchProfessionalsRequest" 1 "MaxElements" "100"
CkXml_UpdateChildContent $xml "soapenv:Body|add:SearchProfessionalsRequest|urn:SSIN" "74062423769"

puts [CkXml_getXml $xml]

set http [new_CkHttp]

set success [CkHttp_SetSslClientCert $http $cert]
if {$success == 0} then {
    puts [CkHttp_lastErrorText $http]
    delete_CkCert $cert
    delete_CkBinData $bdSecToken
    delete_CkXml $xml
    delete_CkDateTime $dt
    delete_CkHttp $http
    exit
}

CkHttp_SetRequestHeader $http "Content-Type" "text/xml"
CkHttp_SetRequestHeader $http "SOAPAction" "urn:be:fgov:ehealth:addressbook:protocol:v1:searchProfessionals"

set xmlStr [CkXml_getXml $xml]
set resp [new_CkHttpResponse]

set success [CkHttp_HttpStr $http "POST" "https://services.ehealth.fgov.be/AddressBook/v1" $xmlStr "utf-8" "application/xml" $resp]
if {$success == 0} then {
    puts [CkHttp_lastErrorText $http]
    delete_CkCert $cert
    delete_CkBinData $bdSecToken
    delete_CkXml $xml
    delete_CkDateTime $dt
    delete_CkHttp $http
    delete_CkHttpResponse $resp
    exit
}

puts [CkHttpResponse_bodyStr $resp]
puts "response status code = [CkHttpResponse_get_StatusCode $resp]"

delete_CkCert $cert
delete_CkBinData $bdSecToken
delete_CkXml $xml
delete_CkDateTime $dt
delete_CkHttp $http
delete_CkHttpResponse $resp