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
(Visual FoxPro) MyInvois Malaysia Login as Intermediary SystemSee more Malaysia MyInvois ExamplesDemonstrates how to get an OAuth2 access token with an intermediary that is representing a taxpayer (acting on behalf of a specific taxpayer). The OAuth2 access token can then be used to access MyInvois protected APIs. For more information, see https://sdk.myinvois.hasil.gov.my/api/08-login-as-intermediary-system/
LOCAL loHttp LOCAL loReq LOCAL loResp LOCAL loJson LOCAL lcAccess_token LOCAL lnExpires_in LOCAL lcToken_type LOCAL lcScope * This example requires the Chilkat API to have been previously unlocked. * See Global Unlock Sample for sample code. * Sends the following HTTP POST to get a MyInvois OAUth2 access token using client_credentials * POST /connect/token HTTP/1.1 * Host: preprod-api.myinvois.hasil.gov.my * Accept: */* * Content-Length: <<variable>> * Content-Type: application/x-www-form-urlencoded * * client_id={YOUR_CLIENT_ID}&client_secret={YOUR_CLIENT_SECRET}&grant_type=client_credentials&scope=InvoicingAPI * -------------------------------------------------------------------------------------------------------- * Note: There is a large amount of information about the MyInvois API on the Internet. * The information is found at https://sdk.myinvois.hasil.gov.my/ * and also at many other companies offering solutions. * * Unfortunately, it's all completely useless to the programmer wishing to implement the API. * The reason it's useless is because no specifics are given. * A developer needs to know the specific details of the HTTP request and response. * What is the HTTP request Content-Type? * What is the endpoint? * What is the format of request body and response? JSON or XML? * What specific header fields are needed, if any? * * Providing samples of raw HTTP requests and responses tells the developer everything he/she needs to know. * All unknowns become known. * Everything becomes easy to implement. * Just show some sample raw HTTP requests and responses, and we can all spend far less time in the office * and more time relaxing on a beach. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Http') loHttp = CreateObject('Chilkat.Http') * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.HttpRequest') loReq = CreateObject('Chilkat.HttpRequest') loReq.AddParam("grant_type","client_credentials") loReq.AddParam("client_id","YOUR_CLIENT_ID") loReq.AddParam("client_secret","YOUR_CLIENT_SECRET") loReq.AddParam("scope","InvoicingAPI") loResp = loHttp.PostUrlEncoded("https://preprod-api.myinvois.hasil.gov.my/connect/token",loReq) IF (loHttp.LastMethodSuccess = 0) THEN ? loHttp.LastErrorText RELEASE loHttp RELEASE loReq CANCEL ENDIF * Note: The returned access token is valid for a short amount of time. Perhaps 1 hour. * The access token is used in the "Authorization: Bearer <access_token>" header in subsequent requests until it expires. * Your application would then need to get a new access token, and so on.. ? "Response Status Code: " + STR(loResp.StatusCode) ? "Response Body:" ? loResp.BodyStr * Here's a sample response: * { * "access_token": "eyJhbGciOiJSUzI1...", * "expires_in": 3600, * "token_type": "Bearer", * "scope": "InvoicingAPI" * } * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.JsonObject') loJson = CreateObject('Chilkat.JsonObject') loJson.Load(loResp.BodyStr) lcAccess_token = loJson.StringOf("access_token") lnExpires_in = loJson.IntOf("expires_in") lcToken_type = loJson.StringOf("token_type") lcScope = loJson.StringOf("scope") RELEASE loResp * To use an access token in a MyInvois API call, see Using a MyInvois Access Token in an API Request RELEASE loHttp RELEASE loReq RELEASE loJson |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.