Sample code for 30+ languages & platforms
Classic ASP

IntakeQ: Send a Questionnaire

See more IntakeQ Examples

Send an intake package using the API.

Chilkat Classic ASP Downloads

Classic ASP
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0

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

set http = Server.CreateObject("Chilkat.Http")

' Implements the following CURL command:

' curl -H "Content-Type: application/json" \
'      -H 'X-Auth-Key: xxxxxxxxxxxxxxxxxxxxxxxxx' \
'      -X POST \
'      -d '{     		
' 	"QuestionnaireId": "00000000-0000-0000-0000-000000000000",     		
' 	"ClientId": 123, 
' 	"ClientName": "Dexter Morgan",
' 	"ClientEmail": "dexter@email.com",
' 	"ClientPhone": "2222222222", 
' 	"PractitionerId": "00000000-0000-0000-0000-000000000000",
' }' https://intakeq.com/api/v1/intakes/send

' 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.

' {
'   "QuestionnaireId": "00000000-0000-0000-0000-000000000000",
'   "ClientId": 123,
'   "ClientName": "Dexter Morgan",
'   "ClientEmail": "dexter@email.com",
'   "ClientPhone": "2222222222",
'   "PractitionerId": "00000000-0000-0000-0000-000000000000"
' }

set json = Server.CreateObject("Chilkat.JsonObject")
success = json.UpdateString("QuestionnaireId","00000000-0000-0000-0000-000000000000")
success = json.UpdateInt("ClientId",123)
success = json.UpdateString("ClientName","Dexter Morgan")
success = json.UpdateString("ClientEmail","dexter@email.com")
success = json.UpdateString("ClientPhone","2222222222")
success = json.UpdateString("PractitionerId","00000000-0000-0000-0000-000000000000")

http.SetRequestHeader "Content-Type","application/json"
http.SetRequestHeader "X-Auth-Key","xxxxxxxxxxxxxxxxxxxxxxxxx"

set resp = Server.CreateObject("Chilkat.HttpResponse")
success = http.HttpJson("POST","https://intakeq.com/api/v1/intakes/send",json,"application/json",resp)
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( http.LastErrorText) & "</pre>"
    Response.End
End If

set sbResponseBody = Server.CreateObject("Chilkat.StringBuilder")
success = resp.GetBodySb(sbResponseBody)
set jResp = Server.CreateObject("Chilkat.JsonObject")
success = jResp.LoadSb(sbResponseBody)
jResp.EmitCompact = 0

Response.Write "<pre>" & Server.HTMLEncode( "Response Body:") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( jResp.Emit()) & "</pre>"

respStatusCode = resp.StatusCode
Response.Write "<pre>" & Server.HTMLEncode( "Response Status Code = " & respStatusCode) & "</pre>"
If (respStatusCode >= 400) Then
    Response.Write "<pre>" & Server.HTMLEncode( "Response Header:") & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( resp.Header) & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( "Failed.") & "</pre>"
    Response.End
End If

' Sample JSON response:
' (Sample code for parsing the JSON response is shown below)

' {
'   "Id": "00000000-0000-0000-0000-000000000000",
'   "ClientName": "test",
'   "ClientEmail": "test@email.com",
'   "ClientId": 9999,
'   "Status": "Completed",
'   "DateCreated": 1458526480368,
'   "DateSubmitted": 1458526532654,
'   "QuestionnaireName": "test",
'   "Practitioner": "test@email.com",
'   "PractitionerName": "FirstName LastName",
'   "Questions": [
'     {
'       "Id": "xxxx-1",
'       "Text": "Full name",
'       "Answer": "Dexter Morgan",
'       "QuestionType": "OpenQuestion",
'       "Rows": [
'       ],
'       "ColumnNames": [
'       ],
'       "OfficeUse": false,
'       "OfficeNote": "aaa"
'     },
'     {
'       "Id": "xxxx-2",
'       "Text": "Full name",
'       "Answer": "Dexter Morgan",
'       "QuestionType": "OpenQuestion",
'       "Rows": [
'       ],
'       "ColumnNames": [
'       ],
'       "OfficeUse": false,
'       "OfficeNote": "aaa"
'     }
'   ],
'   "AppointmentId": "xxxxxxxx",
'   "ConsentForms": [
'     {
'       "Id": "00000000-0000-0000-0000-000000000000",
'       "Name": "HIPAA Release Form",
'       "DocumentType": "Html",
'       "Signed": true,
'       "DateSubmitted": 1458526532654
'     }
'   ]
' }

' Sample code for parsing the JSON response...
' Use the following online tool to generate parsing code from sample JSON:
' Generate Parsing Code from JSON

Id = jResp.StringOf("Id")
ClientName = jResp.StringOf("ClientName")
ClientEmail = jResp.StringOf("ClientEmail")
ClientId = jResp.IntOf("ClientId")
Status = jResp.StringOf("Status")
DateCreated = jResp.IntOf("DateCreated")
DateSubmitted = jResp.IntOf("DateSubmitted")
QuestionnaireName = jResp.StringOf("QuestionnaireName")
Practitioner = jResp.StringOf("Practitioner")
PractitionerName = jResp.StringOf("PractitionerName")
AppointmentId = jResp.StringOf("AppointmentId")
i = 0
count_i = jResp.SizeOfArray("Questions")
Do While i < count_i
    jResp.I = i
    Id = jResp.StringOf("Questions[i].Id")
    Text = jResp.StringOf("Questions[i].Text")
    Answer = jResp.StringOf("Questions[i].Answer")
    QuestionType = jResp.StringOf("Questions[i].QuestionType")
    OfficeUse = jResp.BoolOf("Questions[i].OfficeUse")
    OfficeNote = jResp.StringOf("Questions[i].OfficeNote")
    j = 0
    count_j = jResp.SizeOfArray("Questions[i].Rows")
    Do While j < count_j
        jResp.J = j
        j = j + 1
    Loop
    j = 0
    count_j = jResp.SizeOfArray("Questions[i].ColumnNames")
    Do While j < count_j
        jResp.J = j
        j = j + 1
    Loop
    i = i + 1
Loop
i = 0
count_i = jResp.SizeOfArray("ConsentForms")
Do While i < count_i
    jResp.I = i
    Id = jResp.StringOf("ConsentForms[i].Id")
    Name = jResp.StringOf("ConsentForms[i].Name")
    DocumentType = jResp.StringOf("ConsentForms[i].DocumentType")
    Signed = jResp.BoolOf("ConsentForms[i].Signed")
    DateSubmitted = jResp.IntOf("ConsentForms[i].DateSubmitted")
    i = i + 1
Loop

%>
</body>
</html>