/
API Authorization

API Authorization

WinKAS Api is tokens based and you will need to provide an active token to all API calls. To get a token, you will need to call the “Authorization” API and it requires the following information:

  • ContractId (Normal customer’s license or agreementId)

  • Username (The username that the customer has created with API access)

  • Password: (The assigned password for the username)

When you have retrieved a token with success, then read our suggestions for handling the token.

Authorization

Url: https://air.winkas.net/api/Authentication/Authenticate

Requesttype: Post

Body: {“UserName”:”NAME”, “UserPassword”:”PASSWORD”, “UserContractCode”:”CODE”}

Parameters description:

All parameters are string

Response example:

{     "AuthenticationMessage": "User successfully authenticated",     "WinKasData": {         "Id": 3397,         "UserName": "",         "UserPassword": "",         "UserContractCode": "",         "CurrentToken": "U1vTDs062o1iadVMJK72-nblIDVDB|86VbN3h7sSiW9QOZMrofSKw|xPE3Y3mHX7tU8U-jI-pZPJTiWlTI8n|nX45nUweWqh89gaPthYa|lTDEDqXc2ISwsoK-aWL9wL1C2rPS1onwa8|j1PouTZjxLi|SdGisCQqspzYy3jerLaUikSS|Q5VrN23a|cIqtxe|HDCOyb5B-CeyjVTkTwTl6yiQ92nkvJq43oSxP7-crg_",         "UserRealName": "MJ",         "AuthLevel": null,         "Profile": null     },     "WinkasErrorCode": 0,     "WinKasStatus": 0,     "WinKasStatusString": "Okay",     "WinKasMessage": "Authentication was okay.",     "ApiVersion": "5.67.2.1",     "ResponseDateTime": "2022-03-21T10:43:26",     "ResponseInfo": {         "ElapsedSeconds": 0.1,         "ServerName": "WINKAS-AIRWEB02"     },     "Source": null

Code example – Authentication.

Below examples for authentication in the following languages:

  • C#

  • Javascript / Ajax

  • Php

  • ASP (Classic)

C#

public string GetToken() { var httpWebRequest = (HttpWebRequest)WebRequest.Create("https://air.winkas.net/api/Authentication/Authenticate"); httpWebRequest.ContentType = "text/json"; httpWebRequest.Method = "POST"; using (var streamWriter = new StreamWriter(httpWebRequest.GetRequestStream())) { string json = new JavaScriptSerializer().Serialize(new { UserName = "xxxxx", UserPassword = "xxxxx", UserContractCode = "xxxxx" }); streamWriter.Write(json); streamWriter.Flush(); streamWriter.Close(); var httpResponse = (HttpWebResponse)httpWebRequest.GetResponse(); using (var streamReader = new StreamReader(httpResponse.GetResponseStream())) { var _jsonAuth = streamReader.ReadToEnd(); dynamic _jsonContent = JsonConvert.DeserializeObject(_jsonAuth); string _token = _jsonContent.WinKasData.CurrentToken; return _token; } } }

Javascript

$(document).ready(function () { var winkasServer = (function () { var getAccounts = function (request) { return $.ajax( 'https://air.winkas.net/api/Accounts/All', { type: "POST", data: request }); }; var authenticate = function (request) { return $.ajax( 'https://air.winkas.net/api/Authentication/Authenticate', { type: "POST", data: request } ); }; return { getAccounts: getAccounts, authenticate: authenticate }; }()); var el = { btnAction: $('#action'), result: $('#result') }; el.btnAction.on('click', function () { el.result.html("Getting..."); var request = { "UserName": "xxxxx", "UserPassword": "xxxxx", "UserContractCode": "xxxxx" }; winkasServer.authenticate(request).done(function (data) { var token = data.WinKasData.CurrentToken; request = { "Token": token }; winkasServer.getAccounts(request).done(function (accounts) { var acc = accounts.Accounts; var html = ""; for (var i = 0; i < acc.length; i++) { html += acc[i].Number + ", "; } el.result.html(html); }); }); }); });

PHP

//create array of data to be posted $post_data['UserName'] = 'xxxxx'; //You should add your test user $post_data['UserPassword'] = 'xxxxx'; //You should add your test password $post_data['UserContractCode'] = 'xxxxx'; //You should add your test account/contract //traverse array and prepare data for posting (key1=value1) foreach ( $post_data as $key => $value) { $post_items[] = $key . '=' . $value; } //create the final string to be posted using implode() $post_string = implode ('&', $post_items); //create cURL connection $curl_connection = curl_init('https://air.winkas.net/api/Authentication/Authenticate'); //set options curl_setopt($curl_connection, CURLOPT_CONNECTTIMEOUT, 30); curl_setopt($curl_connection, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)"); curl_setopt($curl_connection, CURLOPT_RETURNTRANSFER, true); curl_setopt($curl_connection, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($curl_connection, CURLOPT_FOLLOWLOCATION, 1); //set data to be posted curl_setopt($curl_connection, CURLOPT_POSTFIELDS, $post_string); //perform our request $result = curl_exec($curl_connection); //dump result echo ' '; print_r($result); echo ' ------------------------ '; //show information regarding the request echo ' '; print_r(curl_getinfo($curl_connection)); echo ' '; //close the connection curl_close($curl_connection);

ASP (classic)

<% '/// Include json converter - http://www.aspjson.com %> <% Const apiUrl = "https://air.winkas.net/api/" Dim apiMethod Dim requestBody Dim apiResponse Dim responseBody Dim responseStatus Dim responseMessage Dim httpService Dim token '/// Get access token apiMethod = "Authentication/Authenticate" Set requestBody = New aspJSON With requestBody.data .Add "UserName", "xxxxx" .Add "UserPassword", "xxxxx" .Add "UserContractCode", "xxxxx" End With Set httpService = Server.CreateObject("MSXML2.ServerXMLHTTP.6.0") httpService.open "POST", apiUrl & apiMethod httpService.setRequestHeader "Content-Type", "application/json; charset=utf-8" httpService.send requestBody.JSONoutput apiResponse = httpService.responseText Set responseBody = New aspJSON responseBody.loadJSON apiResponse responseStatus = responseBody.data("WinKasStatus") responseMessage = responseBody.data("WinKasMessage") If responseStatus <> 0 Then Response.Write " Authentication failed! " Response.Write " " & responseMessage & " " Response.End End If token = responseBody.data("WinKasData").item("CurrentToken")

 

Related content