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
(SQL Server) Get Google API Access Token using P12 Service Account KeyDemonstrates how to get a Google API access token using a P12 service account key.
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- This example requires the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. -- First load the PKCS12 (.p12 / .pfx) into a PFX object. DECLARE @pfx int -- Use "Chilkat_9_5_0.Pfx" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Pfx', @pfx OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END DECLARE @success int EXEC sp_OAMethod @pfx, 'LoadPfxFile', @success OUT, 'qa_data/googleSvcAccountKeys/ChilkatCloud-6ba1b17d6d16.p12', 'notasecret' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @pfx, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @pfx RETURN END DECLARE @gAuth int -- Use "Chilkat_9_5_0.AuthGoogle" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.AuthGoogle', @gAuth OUT EXEC sp_OAMethod @gAuth, 'SetP12', @success OUT, @pfx -- Set the client email address. EXEC sp_OASetProperty @gAuth, 'EmailAddress', 'pip-563@chilkatcloud.iam.gserviceaccount.com' -- Choose a scope. EXEC sp_OASetProperty @gAuth, 'Scope', 'https://www.googleapis.com/auth/cloud-platform' -- Request an access token that is valid for this many seconds. EXEC sp_OASetProperty @gAuth, 'ExpireNumSeconds', 3600 -- If the application is requesting delegated access: -- The email address of the user for which the application is requesting delegated access, -- then set the email address here. (Otherwise leave it empty.) EXEC sp_OASetProperty @gAuth, 'SubEmailAddress', '' -- Connect to www.googleapis.com using TLS (TLS 1.2 is the default.) -- The Chilkat socket object is used so that the connection can be established -- through proxies or an SSH tunnel if desired. DECLARE @tlsSock int -- Use "Chilkat_9_5_0.Socket" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Socket', @tlsSock OUT EXEC sp_OAMethod @tlsSock, 'Connect', @success OUT, 'www.googleapis.com', 443, 1, 5000 IF @success <> 1 BEGIN EXEC sp_OAGetProperty @tlsSock, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @pfx EXEC @hr = sp_OADestroy @gAuth EXEC @hr = sp_OADestroy @tlsSock RETURN END -- Send the request to obtain the access token. EXEC sp_OAMethod @gAuth, 'ObtainAccessToken', @success OUT, @tlsSock IF @success <> 1 BEGIN EXEC sp_OAGetProperty @gAuth, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @pfx EXEC @hr = sp_OADestroy @gAuth EXEC @hr = sp_OADestroy @tlsSock RETURN END -- Examine the access token: EXEC sp_OAGetProperty @gAuth, 'AccessToken', @sTmp0 OUT PRINT 'Access Token: ' + @sTmp0 EXEC @hr = sp_OADestroy @pfx EXEC @hr = sp_OADestroy @gAuth EXEC @hr = sp_OADestroy @tlsSock END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.