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
(Perl) 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
use 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->new(); $sbToken->LoadFile("qa_data/tokens/google_cloud_sql_access_token.txt","utf-8"); $http = chilkat::CkHttp->new(); # 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->new(); $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->new(); $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 HttpResponse $resp = $http->PTextSb("PATCH","https://www.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id",$sbRequestBody,"utf-8","application/json",0,0); if ($http->get_LastMethodSuccess() == 0) { print $http->lastErrorText() . "\r\n"; exit; } $sbResponseBody = chilkat::CkStringBuilder->new(); $resp->GetBodySb($sbResponseBody); $jResp = chilkat::CkJsonObject->new(); $jResp->LoadSb($sbResponseBody); $jResp->put_EmitCompact(0); print "Response Body:" . "\r\n"; print $jResp->emit() . "\r\n"; $respStatusCode = $resp->get_StatusCode(); print "Response Status Code = " . $respStatusCode . "\r\n"; if ($respStatusCode == 401) { print "It may be that your access token expired." . "\r\n"; print "Try refreshing the access token by re-fetching it." . "\r\n"; } if ($respStatusCode >= 400) { print "Response Header:" . "\r\n"; print $resp->header() . "\r\n"; print "Failed." . "\r\n"; 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.