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
(CkPython) Google Cloud SQL - Start Database InstanceDemonstrates how to start a Google Cloud SQL database instance. For more information, see https://cloud.google.com/sql/docs/mysql/start-stop-restart-instance
import sys import chilkat # This example assumes the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. # In this example, Get Google Cloud SQL OAuth2 Access Token, # the service account access token was saved to a text file. This example fetches the access token from the file.. sbToken = chilkat.CkStringBuilder() sbToken.LoadFile("qa_data/tokens/google_cloud_sql_access_token.txt","utf-8") http = chilkat.CkHttp() # Implements the following CURL command: # curl -X PATCH \ # -H "Authorization: Bearer "$(gcloud auth print-access-token) \ # -H "Content-Type: application/json; charset=utf-8" \ # -d '{ # "settings": { # "activationPolicy": "ALWAYS" # } # }' \ # https://www.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id # Use this online tool to generate code from sample JSON: # Generate Code to Create JSON # The following JSON is sent in the request body. # { # "settings": { # "activationPolicy": "ALWAYS" # } # } # Use "ALWAYS" to start an instance. Use "NEVER" to stop an instance. json = chilkat.CkJsonObject() json.UpdateString("settings.activationPolicy","ALWAYS") # Causes the "Authorization: Bearer "$(gcloud auth print-access-token)" header to be added. http.put_AuthToken(sbToken.getAsString()) http.SetRequestHeader("Content-Type","application/json; charset=utf-8") sbRequestBody = chilkat.CkStringBuilder() json.EmitSb(sbRequestBody) # Replace "project-id" with your actual Google project ID. # Replace "instance-id" with your database instance ID, which is the name of your database. (For example, when I created my test database I named it "chilkat", and therefore my instance-id is "chilkat".) # resp is a CkHttpResponse resp = http.PTextSb("PATCH","https://www.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id",sbRequestBody,"utf-8","application/json",False,False) if (http.get_LastMethodSuccess() == False): print(http.lastErrorText()) sys.exit() sbResponseBody = chilkat.CkStringBuilder() resp.GetBodySb(sbResponseBody) jResp = chilkat.CkJsonObject() jResp.LoadSb(sbResponseBody) jResp.put_EmitCompact(False) print("Response Body:") print(jResp.emit()) respStatusCode = resp.get_StatusCode() print("Response Status Code = " + str(respStatusCode)) if (respStatusCode == 401): print("It may be that your access token expired.") print("Try refreshing the access token by re-fetching it.") if (respStatusCode >= 400): print("Response Header:") print(resp.header()) print("Failed.") sys.exit() # Sample JSON response: # (Sample code for parsing the JSON response is shown below) # { # "kind": "sql#operation", # "targetLink": "https://www.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id", # "status": "PENDING", # "user": "user@example.com", # "insertTime": "2020-01-20T21:30:35.667Z", # "operationType": "UPDATE", # "name": "operation-id", # "targetId": "instance-id", # "selfLink": "https://www.googleapis.com/sql/v1beta4/projects/project-id/operations/operation-id", # "targetProject": "project-id" # } # Sample code for parsing the JSON response... # Use the following online tool to generate parsing code from sample JSON: # Generate Parsing Code from JSON kind = jResp.stringOf("kind") targetLink = jResp.stringOf("targetLink") status = jResp.stringOf("status") user = jResp.stringOf("user") insertTime = jResp.stringOf("insertTime") operationType = jResp.stringOf("operationType") name = jResp.stringOf("name") targetId = jResp.stringOf("targetId") selfLink = jResp.stringOf("selfLink") targetProject = jResp.stringOf("targetProject") |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.