PHP Extension
PHP Extension
Google Cloud SQL - Stop Database Instance
See more Google Cloud SQL Examples
Demonstrates how to stop a Google Cloud SQL database instance.Chilkat PHP Extension Downloads
<?php
include("chilkat.php");
$success = false;
// 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 = new CkStringBuilder();
$sbToken->LoadFile('qa_data/tokens/google_cloud_sql_access_token.txt','utf-8');
$http = new 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": "NEVER"
// }
// }' \
// 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": "NEVER"
// }
// }
$json = new CkJsonObject();
$json->UpdateString('settings.activationPolicy','NEVER');
// 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 = new 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 = new CkHttpResponse();
$success = $http->HttpSb('PATCH','https://www.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id',$sbRequestBody,'utf-8','application/json',$resp);
if ($success == false) {
print $http->lastErrorText() . "\n";
exit;
}
$sbResponseBody = new CkStringBuilder();
$resp->GetBodySb($sbResponseBody);
$jResp = new CkJsonObject();
$jResp->LoadSb($sbResponseBody);
$jResp->put_EmitCompact(false);
print 'Response Body:' . "\n";
print $jResp->emit() . "\n";
$respStatusCode = $resp->get_StatusCode();
print 'Response Status Code = ' . $respStatusCode . "\n";
if ($respStatusCode == 401) {
print 'It may be that your access token expired.' . "\n";
print 'Try refreshing the access token by re-fetching it.' . "\n";
}
if ($respStatusCode >= 400) {
print 'Response Header:' . "\n";
print $resp->header() . "\n";
print 'Failed.' . "\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');
?>