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) Etsy OAuth1 AuthorizationSee more Etsy ExamplesDemonstrates 3-legged OAuth1 authorization for Etsy. For more information, see https://www.etsy.com/developers/documentation/getting_started/oauth
LOCAL lcConsumerKey LOCAL lcConsumerSecret LOCAL lcRequestTokenUrl LOCAL lcAuthorizeUrl LOCAL lcAccessTokenUrl LOCAL lcCallbackUrl LOCAL lnCallbackLocalPort LOCAL loHttp LOCAL lnSuccess LOCAL loReq LOCAL loResp LOCAL loHashTab LOCAL lcRequestToken LOCAL lcRequestTokenSecret LOCAL loSbUrlForBrowser LOCAL lcUrl LOCAL loListenSock LOCAL lnBackLog LOCAL lnMaxWaitMs LOCAL loTask LOCAL loSock LOCAL lcStartLine LOCAL lcRequestHeader LOCAL loSbResponseHtml LOCAL loSbResponse LOCAL loSbStartLine LOCAL lnNumReplacements LOCAL lcAuthVerifier LOCAL lcAccessToken LOCAL lcAccessTokenSecret LOCAL loJson LOCAL loFac lcConsumerKey = "keystring" lcConsumerSecret = "shared_secret" * Specify one or more SPACE separated scopes as query params in the requestTokenUrl * See https://www.etsy.com/developers/documentation/getting_started/oauth#section_permission_scopes lcRequestTokenUrl = "https://openapi.etsy.com/v2/oauth/request_token?scope=email_r%20listings_r%20listings_w%20listings_d" lcAuthorizeUrl = "https://www.etsy.com/oauth/signin" lcAccessTokenUrl = "https://openapi.etsy.com/v2/oauth/access_token" * The port number is picked at random. It's some unused port that won't likely conflict with anything else.. lcCallbackUrl = "http://localhost:3017/" lnCallbackLocalPort = 3017 * The 1st step in 3-legged OAuth1.0a is to send a POST to the request token URL to obtain an OAuth Request Token * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Http') loHttp = CreateObject('Chilkat.Http') loHttp.OAuth1 = 1 loHttp.OAuthConsumerKey = lcConsumerKey loHttp.OAuthConsumerSecret = lcConsumerSecret loHttp.OAuthCallback = lcCallbackUrl * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.HttpRequest') loReq = CreateObject('Chilkat.HttpRequest') loResp = loHttp.PostUrlEncoded(lcRequestTokenUrl,loReq) IF (loHttp.LastMethodSuccess <> 1) THEN ? loHttp.LastErrorText RELEASE loHttp RELEASE loReq CANCEL ENDIF * If successful, the resp.BodyStr contains something like this: * login_url=https%3A%2F%2Fwww.etsy.com%2Foauth%2Fsignin%3Foauth_consumer_key%3D9ad9l1omxzbwfr2niq0ce1ly%26oauth_token%3D7116b4d0c72c2736561853d9e50113%26service%3Dv2_prod&oauth_token=7116b4d0c72c2736561853d9e50113&oauth_token_secret=3b7612b5d3&oauth_callback_confirmed=true&oauth_consumer_key=9ad9l1omxzbwfr2niq0ce1ly&oauth_callback=http%3A%2F%2Flocalhost%3A3017%2F ? loResp.BodyStr * We'll need this for later.. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Hashtable') loHashTab = CreateObject('Chilkat.Hashtable') loHashTab.AddQueryParams(loResp.BodyStr) lcRequestToken = loHashTab.LookupStr("oauth_token") lcRequestTokenSecret = loHashTab.LookupStr("oauth_token_secret") loHttp.OAuthTokenSecret = lcRequestTokenSecret ? "oauth_token = " + lcRequestToken ? "oauth_token_secret = " + lcRequestTokenSecret * --------------------------------------------------------------------------- * The next step is to form a URL to send to the authorizeUrl * This is an HTTP GET that we load into a popup browser. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.StringBuilder') loSbUrlForBrowser = CreateObject('Chilkat.StringBuilder') loSbUrlForBrowser.Append(lcAuthorizeUrl) loSbUrlForBrowser.Append("?") loSbUrlForBrowser.Append(loResp.BodyStr) lcUrl = loSbUrlForBrowser.GetAsString() RELEASE loResp * When the url is loaded into a browser, the response from Etsy will redirect back to localhost:3017 * We'll need to start a socket that is listening on port 3017 for the callback from the browser. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Socket') loListenSock = CreateObject('Chilkat.Socket') lnBackLog = 5 lnSuccess = loListenSock.BindAndListen(lnCallbackLocalPort,lnBackLog) IF (lnSuccess <> 1) THEN ? loListenSock.LastErrorText RELEASE loHttp RELEASE loReq RELEASE loHashTab RELEASE loSbUrlForBrowser RELEASE loListenSock CANCEL ENDIF * Wait for the browser's connection in a background thread. * (We'll send load the URL into the browser following this..) * Wait a max of 60 seconds before giving up. lnMaxWaitMs = 60000 loTask = loListenSock.AcceptNextConnectionAsync(lnMaxWaitMs) loTask.Run() * **************************************************************** * At this point, your application should load the URL in a browser. * For example, * in C#: System.Diagnostics.Process.Start(url); * in Java: Desktop.getDesktop().browse(new URI(url)); * in VBScript: Set wsh=WScript.CreateObject("WScript.Shell") * wsh.Run url * in Xojo: ShowURL(url) (see http://docs.xojo.com/index.php/ShowURL) * in Dataflex: Runprogram Background "c:\Program Files\Internet Explorer\iexplore.exe" sUrl * The Google account owner would interactively accept or deny the authorization request. * Add the code to load the url in a web browser here... * Add the code to load the url in a web browser here... * Add the code to load the url in a web browser here... * System.Diagnostics.Process.Start(url); * **************************************************************** * Wait for the listenSock's task to complete. lnSuccess = loTask.Wait(lnMaxWaitMs) IF (NOT lnSuccess OR (loTask.StatusInt <> 7) OR (loTask.TaskSuccess <> 1)) THEN IF (NOT lnSuccess) THEN * The task.LastErrorText applies to the Wait method call. ? loTask.LastErrorText ELSE * The ResultErrorText applies to the underlying task method call (i.e. the AcceptNextConnection) ? loTask.Status ? loTask.ResultErrorText ENDIF RELEASE loTask RELEASE loHttp RELEASE loReq RELEASE loHashTab RELEASE loSbUrlForBrowser RELEASE loListenSock CANCEL ENDIF * If we get to this point, the connection from the browser arrived and was accepted. * We no longer need the listen socket... * Stop listening on port 3017. loListenSock.Close(10) * First get the connected socket. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Socket') loSock = CreateObject('Chilkat.Socket') loSock.LoadTaskResult(loTask) RELEASE loTask * Read the start line of the request.. lcStartLine = loSock.ReceiveUntilMatch(CHR(13) + CHR(10)) IF (loSock.LastMethodSuccess <> 1) THEN ? loSock.LastErrorText RELEASE loHttp RELEASE loReq RELEASE loHashTab RELEASE loSbUrlForBrowser RELEASE loListenSock RELEASE loSock CANCEL ENDIF * Read the request header. lcRequestHeader = loSock.ReceiveUntilMatch(CHR(13) + CHR(10) + CHR(13) + CHR(10)) IF (loSock.LastMethodSuccess <> 1) THEN ? loSock.LastErrorText RELEASE loHttp RELEASE loReq RELEASE loHashTab RELEASE loSbUrlForBrowser RELEASE loListenSock RELEASE loSock CANCEL ENDIF * The browser SHOULD be sending us a GET request, and therefore there is no body to the request. * Once the request header is received, we have all of it. * We can now send our HTTP response. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.StringBuilder') loSbResponseHtml = CreateObject('Chilkat.StringBuilder') loSbResponseHtml.Append("<html><body><p>Chilkat thanks you!</b></body</html>") * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.StringBuilder') loSbResponse = CreateObject('Chilkat.StringBuilder') loSbResponse.Append("HTTP/1.1 200 OK" + CHR(13) + CHR(10)) loSbResponse.Append("Content-Length: ") loSbResponse.AppendInt(loSbResponseHtml.Length) loSbResponse.Append(CHR(13) + CHR(10)) loSbResponse.Append("Content-Type: text/html" + CHR(13) + CHR(10)) loSbResponse.Append(CHR(13) + CHR(10)) loSbResponse.AppendSb(loSbResponseHtml) loSock.SendString(loSbResponse.GetAsString()) loSock.Close(50) * The information we need is in the startLine. * For example, the startLine will look like this: * GET /?oauth_token=a3bc8bec84acc31418b68a532e9511&oauth_verifier=b5558d37 HTTP/1.1 * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.StringBuilder') loSbStartLine = CreateObject('Chilkat.StringBuilder') loSbStartLine.Append(lcStartLine) lnNumReplacements = loSbStartLine.Replace("GET /?","") lnNumReplacements = loSbStartLine.Replace(" HTTP/1.1","") loSbStartLine.Trim() * oauth_token=a3bc8bec84acc31418b68a532e9511&oauth_verifier=b5558d37 ? "startline: " + loSbStartLine.GetAsString() loHashTab.Clear() loHashTab.AddQueryParams(loSbStartLine.GetAsString()) lcRequestToken = loHashTab.LookupStr("oauth_token") lcAuthVerifier = loHashTab.LookupStr("oauth_verifier") * ------------------------------------------------------------------------------ * Finally , we must exchange the OAuth Request Token for an OAuth Access Token. loHttp.OAuthToken = lcRequestToken loHttp.OAuthVerifier = lcAuthVerifier loResp = loHttp.PostUrlEncoded(lcAccessTokenUrl,loReq) IF (loHttp.LastMethodSuccess <> 1) THEN ? loHttp.LastErrorText RELEASE loHttp RELEASE loReq RELEASE loHashTab RELEASE loSbUrlForBrowser RELEASE loListenSock RELEASE loSock RELEASE loSbResponseHtml RELEASE loSbResponse RELEASE loSbStartLine CANCEL ENDIF * Make sure a successful response was received. IF (loResp.StatusCode <> 200) THEN ? loResp.StatusLine ? loResp.Header ? loResp.BodyStr RELEASE loHttp RELEASE loReq RELEASE loHashTab RELEASE loSbUrlForBrowser RELEASE loListenSock RELEASE loSock RELEASE loSbResponseHtml RELEASE loSbResponse RELEASE loSbStartLine CANCEL ENDIF * If successful, the resp.BodyStr contains something like this: * oauth_token=7898d7ba280dc791586dcfd26b37a9&oauth_token_secret=f2a7c267aa ? loResp.BodyStr loHashTab.Clear() loHashTab.AddQueryParams(loResp.BodyStr) lcAccessToken = loHashTab.LookupStr("oauth_token") lcAccessTokenSecret = loHashTab.LookupStr("oauth_token_secret") RELEASE loResp * The access token + secret is what should be saved and used for * subsequent REST API calls. ? "Access Token = " + lcAccessToken ? "Access Token Secret = " + lcAccessTokenSecret * Save this access token for future calls. * Just in case we need user_id and screen_name, save those also.. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.JsonObject') loJson = CreateObject('Chilkat.JsonObject') loJson.AppendString("oauth_token",lcAccessToken) loJson.AppendString("oauth_token_secret",lcAccessTokenSecret) * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.FileAccess') loFac = CreateObject('Chilkat.FileAccess') loFac.WriteEntireTextFile("qa_data/tokens/etsy.json",loJson.Emit(),"utf-8",0) ? "Success." RELEASE loHttp RELEASE loReq RELEASE loHashTab RELEASE loSbUrlForBrowser RELEASE loListenSock RELEASE loSock RELEASE loSbResponseHtml RELEASE loSbResponse RELEASE loSbStartLine RELEASE loJson RELEASE loFac |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.