C
C
Google Cloud SQL - Stop Database Instance
See more Google Cloud SQL Examples
Demonstrates how to stop a Google Cloud SQL database instance.Chilkat C Downloads
#include <C_CkStringBuilder.h>
#include <C_CkHttp.h>
#include <C_CkJsonObject.h>
#include <C_CkHttpResponse.h>
void ChilkatSample(void)
{
BOOL success;
HCkStringBuilder sbToken;
HCkHttp http;
HCkJsonObject json;
HCkStringBuilder sbRequestBody;
HCkHttpResponse resp;
HCkStringBuilder sbResponseBody;
HCkJsonObject jResp;
int respStatusCode;
const char *kind;
const char *targetLink;
const char *status;
const char *user;
const char *insertTime;
const char *operationType;
const char *name;
const char *targetId;
const char *selfLink;
const char *targetProject;
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 = CkStringBuilder_Create();
CkStringBuilder_LoadFile(sbToken,"qa_data/tokens/google_cloud_sql_access_token.txt","utf-8");
http = CkHttp_Create();
// 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 = CkJsonObject_Create();
CkJsonObject_UpdateString(json,"settings.activationPolicy","NEVER");
// Causes the "Authorization: Bearer "$(gcloud auth print-access-token)" header to be added.
CkHttp_putAuthToken(http,CkStringBuilder_getAsString(sbToken));
CkHttp_SetRequestHeader(http,"Content-Type","application/json; charset=utf-8");
sbRequestBody = CkStringBuilder_Create();
CkJsonObject_EmitSb(json,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 = CkHttpResponse_Create();
success = CkHttp_HttpSb(http,"PATCH","https://www.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id",sbRequestBody,"utf-8","application/json",resp);
if (success == FALSE) {
printf("%s\n",CkHttp_lastErrorText(http));
CkStringBuilder_Dispose(sbToken);
CkHttp_Dispose(http);
CkJsonObject_Dispose(json);
CkStringBuilder_Dispose(sbRequestBody);
CkHttpResponse_Dispose(resp);
return;
}
sbResponseBody = CkStringBuilder_Create();
CkHttpResponse_GetBodySb(resp,sbResponseBody);
jResp = CkJsonObject_Create();
CkJsonObject_LoadSb(jResp,sbResponseBody);
CkJsonObject_putEmitCompact(jResp,FALSE);
printf("Response Body:\n");
printf("%s\n",CkJsonObject_emit(jResp));
respStatusCode = CkHttpResponse_getStatusCode(resp);
printf("Response Status Code = %d\n",respStatusCode);
if (respStatusCode == 401) {
printf("It may be that your access token expired.\n");
printf("Try refreshing the access token by re-fetching it.\n");
}
if (respStatusCode >= 400) {
printf("Response Header:\n");
printf("%s\n",CkHttpResponse_header(resp));
printf("Failed.\n");
CkStringBuilder_Dispose(sbToken);
CkHttp_Dispose(http);
CkJsonObject_Dispose(json);
CkStringBuilder_Dispose(sbRequestBody);
CkHttpResponse_Dispose(resp);
CkStringBuilder_Dispose(sbResponseBody);
CkJsonObject_Dispose(jResp);
return;
}
// 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
// Chilkat functions returning "const char *" return a pointer to temporary internal memory owned and managed by Chilkat.
// See this example explaining how this memory should be used: const char * functions.
kind = CkJsonObject_stringOf(jResp,"kind");
targetLink = CkJsonObject_stringOf(jResp,"targetLink");
status = CkJsonObject_stringOf(jResp,"status");
user = CkJsonObject_stringOf(jResp,"user");
insertTime = CkJsonObject_stringOf(jResp,"insertTime");
operationType = CkJsonObject_stringOf(jResp,"operationType");
name = CkJsonObject_stringOf(jResp,"name");
targetId = CkJsonObject_stringOf(jResp,"targetId");
selfLink = CkJsonObject_stringOf(jResp,"selfLink");
targetProject = CkJsonObject_stringOf(jResp,"targetProject");
CkStringBuilder_Dispose(sbToken);
CkHttp_Dispose(http);
CkJsonObject_Dispose(json);
CkStringBuilder_Dispose(sbRequestBody);
CkHttpResponse_Dispose(resp);
CkStringBuilder_Dispose(sbResponseBody);
CkJsonObject_Dispose(jResp);
}