Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Visual FoxPro) Box.com OAuth2 with JSON Web TokensSee more Box ExamplesDemonstrates how to obtain an OAuth2 access token using a JSON Web Token. The following explanation is copied from Box Authentication Models
LOCAL loJsonRsaKey LOCAL lnSuccess LOCAL lcPassphrase LOCAL lcPrivateKeyPem LOCAL loRsaKey LOCAL loJwt LOCAL loJose LOCAL loClaims LOCAL loPrng LOCAL loRest LOCAL lnBAutoReconnect LOCAL lcJsonResponse LOCAL loJResponse LOCAL lcAccessToken * This requires the Chilkat API to have been previously unlocked. * See Global Unlock Sample for sample code. * When you created an RSA key pair using the Box web user interface, * you downloaded a json file named something like "7152782_kkdxptq2_config.json" * This contains the following: * { * "boxAppSettings": { * "clientID": "0kraci84o0jfr7yuw596tf394iigzbe7", * "clientSecret": "xxxxxxxxxxxxxxxxxxxxxxxxx", * "appAuth": { * "publicKeyID": "kkdxptq2", * "privateKey": "-----BEGIN ENCRYPTED PRIVATE KEY-----\nMIIFDj ... nceU=\n-----END ENCRYPTED PRIVATE KEY-----\n", * "passphrase": "xxxxxxxxxxxxxxxxxxxxxxxx" * } * }, * "enterpriseID": "7152782" * } * * Load it into a Chilkat JSON object to allow access to the content. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.JsonObject') loJsonRsaKey = CreateObject('Chilkat.JsonObject') lnSuccess = loJsonRsaKey.LoadFile("qa_data/tokens/7152782_kkdxptq2_config.json") * Load the private key into a Chilkat private key object. lcPassphrase = loJsonRsaKey.StringOf("boxAppSettings.appAuth.passphrase") lcPrivateKeyPem = loJsonRsaKey.StringOf("boxAppSettings.appAuth.privateKey") * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.PrivateKey') loRsaKey = CreateObject('Chilkat.PrivateKey') lnSuccess = loRsaKey.LoadEncryptedPem(lcPrivateKeyPem,lcPassphrase) IF (lnSuccess <> 1) THEN ? loRsaKey.LastErrorText RELEASE loJsonRsaKey RELEASE loRsaKey CANCEL ENDIF * The JSON Web Token will be created using the JWT class * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Jwt') loJwt = CreateObject('Chilkat.Jwt') * Construct the JOSE header... * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.JsonObject') loJose = CreateObject('Chilkat.JsonObject') * Chilkat supports the following algorithms: "RS256", "RS384", and "RS512". (Chilkat also supports other algorithms that Box does not yet support.) loJose.UpdateString("alg","RS256") loJose.UpdateString("typ","JWT") loJose.UpdateString("kid",loJsonRsaKey.StringOf("boxAppSettings.appAuth.publicKeyID")) * Now let's build the JWT claims. Most of this is just boilerplate (i.e. the same every time..) * The JWT claims contain these required and optional elements: * iss (required, String) The Client ID of the service that created the JWT assertion. * sub (required, String) enterprise_id for a token specific to an enterprise when creating and managing app users, or the app user_id for a token specific to an individual app user. * box_sub_type (required, String) "enterprise" or "user" depending on the type of token being requested in the sub claim. * aud (required, String) Always "https://api.box.com/oauth2/token" for OAuth2 token requests * jti (required, String) A universally unique identifier specified by the client for this JWT. This is a unique string that is at least 16 characters and at most 128 characters. * exp (required, NumericDate) The unix time as to when this JWT will expire. This can be set to a maximum value of 60 seconds beyond the issue time. Note: It is recommended to set this value to less than the maximum allowed 60 seconds. * iat (optional, NumericDate) Issued at time. The token cannot be used before this time. * nbf (optional, NumericDate) Not before. Specifies when the token will start being valid. * * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.JsonObject') loClaims = CreateObject('Chilkat.JsonObject') loClaims.UpdateString("iss",loJsonRsaKey.StringOf("boxAppSettings.clientID")) loClaims.UpdateString("sub",loJsonRsaKey.StringOf("enterpriseID")) loClaims.UpdateString("box_sub_type","enterprise") loClaims.UpdateString("aud","https://api.box.com/oauth2/token") * Generate 32 random bytes (base64 encoded) for the "jti" * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Prng') loPrng = CreateObject('Chilkat.Prng') loClaims.UpdateString("jti",loPrng.GenRandom(32,"base64")) * Set the expiration time to 60 seconds after the current time. loClaims.UpdateInt("exp",loJwt.GenNumericDate(60)) * We're going to do the following POST to get a JSON response that contains our OAuth2 access token: * POST /oauth2/token * Content-Type: application/x-www-form-urlencoded * grant_type=urn:ietf:params:oauth:grant-type:jwt-bearer& * assertion=<JWT>& * client_id=<client_id>& * client_secret=<client_secret> * First, make the initial connection. * A single REST object, once connected, can be used for many Box REST API calls. * The auto-reconnect indicates that if the already-established HTTPS connection is closed, * then it will be automatically re-established as needed. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Rest') loRest = CreateObject('Chilkat.Rest') lnBAutoReconnect = 1 lnSuccess = loRest.Connect("api.box.com",443,1,lnBAutoReconnect) IF (lnSuccess <> 1) THEN ? loRest.LastErrorText RELEASE loJsonRsaKey RELEASE loRsaKey RELEASE loJwt RELEASE loJose RELEASE loClaims RELEASE loPrng RELEASE loRest CANCEL ENDIF * Add the query params. * Calling ClearAllParts is wise if previous requests were sent prior to this one on the same REST object.. loRest.ClearAllParts() loRest.AddQueryParam("grant_type","urn:ietf:params:oauth:grant-type:jwt-bearer") loRest.AddQueryParam("client_id",loJsonRsaKey.StringOf("boxAppSettings.clientID")) loRest.AddQueryParam("client_secret",loJsonRsaKey.StringOf("boxAppSettings.clientSecret")) loRest.AddQueryParam("assertion",loJwt.CreateJwtPk(loJose.Emit(),loClaims.Emit(),loRsaKey)) lcJsonResponse = loRest.FullRequestFormUrlEncoded("POST","/oauth2/token") IF (loRest.LastMethodSuccess <> 1) THEN ? loRest.LastErrorText RELEASE loJsonRsaKey RELEASE loRsaKey RELEASE loJwt RELEASE loJose RELEASE loClaims RELEASE loPrng RELEASE loRest CANCEL ENDIF * If successful, we'll get a response status code equal to 200, * and a JSON response that looks like this: * { * "access_token": "mNr1FrCvOeWiGnwLL0OcTL0Lux5jbyBa", * "expires_in": 4169, * "restricted_to": [], * "token_type": "bearer" * } * * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.JsonObject') loJResponse = CreateObject('Chilkat.JsonObject') loJResponse.EmitCompact = 0 loJResponse.Load(lcJsonResponse) IF (loRest.ResponseStatusCode <> 200) THEN ? loJResponse.Emit() ? "Failed." RELEASE loJsonRsaKey RELEASE loRsaKey RELEASE loJwt RELEASE loJose RELEASE loClaims RELEASE loPrng RELEASE loRest RELEASE loJResponse CANCEL ENDIF ? loJResponse.Emit() * Get the access token: lcAccessToken = loJResponse.StringOf("access_token") ? "Access token, valid for 60 minutes: " + lcAccessToken RELEASE loJsonRsaKey RELEASE loRsaKey RELEASE loJwt RELEASE loJose RELEASE loClaims RELEASE loPrng RELEASE loRest RELEASE loJResponse |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.