Skip to content

Commit

Permalink
feat(secretmanager): add regional secrets samples (#2065)
Browse files Browse the repository at this point in the history
  • Loading branch information
kapishps authored Dec 12, 2024
1 parent 2405523 commit 0a13650
Show file tree
Hide file tree
Showing 18 changed files with 1,355 additions and 3 deletions.
2 changes: 1 addition & 1 deletion secretmanager/composer.json
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"require": {
"google/cloud-secret-manager": "^1.13"
"google/cloud-secret-manager": "^1.15.2"
}
}
71 changes: 71 additions & 0 deletions secretmanager/src/access_regional_secret_version.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
<?php
/*
* Copyright 2024 Google LLC.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

/*
* For instructions on how to run the full sample:
*
* @see https://github.com/GoogleCloudPlatform/php-docs-samples/tree/main/secretmanager/README.md
*/

declare(strict_types=1);

namespace Google\Cloud\Samples\SecretManager;

// [START secretmanager_access_regional_secret_version]
// Import the Secret Manager client library.
use Google\Cloud\SecretManager\V1\Client\SecretManagerServiceClient;
use Google\Cloud\SecretManager\V1\AccessSecretVersionRequest;

/**
* @param string $projectId Your Google Cloud Project ID (e.g. 'my-project')
* @param string $locationId Your secret Location (e.g. "us-central1")
* @param string $secretId Your secret ID (e.g. 'my-secret')
* @param string $versionId Your version ID (e.g. 'latest' or '5');
*/
function access_regional_secret_version(
string $projectId,
string $locationId,
string $secretId,
string $versionId
): void {
// Specify regional endpoint.
$options = ['apiEndpoint' => "secretmanager.$locationId.rep.googleapis.com"];

// Create the Secret Manager client.
$client = new SecretManagerServiceClient($options);

// Build the resource name of the secret version.
$name = $client->projectLocationSecretSecretVersionName($projectId, $locationId, $secretId, $versionId);

// Build the request.
$request = AccessSecretVersionRequest::build($name);

// Access the secret version.
$response = $client->accessSecretVersion($request);

// Print the secret payload.
//
// WARNING: Do not print the secret in a production environment - this
// snippet is showing how to access the secret material.
$payload = $response->getPayload()->getData();
printf('Plaintext: %s', $payload);
}
// [END secretmanager_access_regional_secret_version]

// The following 2 lines are only needed to execute the samples on the CLI
require_once __DIR__ . '/../../testing/sample_helpers.php';
\Google\Cloud\Samples\execute_sample(__FILE__, __NAMESPACE__, $argv);
66 changes: 66 additions & 0 deletions secretmanager/src/add_regional_secret_version.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
<?php
/*
* Copyright 2024 Google LLC.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

/*
* For instructions on how to run the full sample:
*
* @see https://github.com/GoogleCloudPlatform/php-docs-samples/tree/main/secretmanager/README.md
*/

declare(strict_types=1);

namespace Google\Cloud\Samples\SecretManager;

// [START secretmanager_add_regional_secret_version]
// Import the Secret Manager client library.
use Google\Cloud\SecretManager\V1\Client\SecretManagerServiceClient;
use Google\Cloud\SecretManager\V1\AddSecretVersionRequest;
use Google\Cloud\SecretManager\V1\SecretPayload;

/**
* @param string $projectId Your Google Cloud Project ID (e.g. 'my-project')
* @param string $locationId Your secret Location (e.g. "us-central1")
* @param string $secretId Your secret ID (e.g. 'my-secret')
*/
function add_regional_secret_version(string $projectId, string $locationId, string $secretId): void
{
// Specify regional endpoint.
$options = ['apiEndpoint' => "secretmanager.$locationId.rep.googleapis.com"];

// Create the Secret Manager client.
$client = new SecretManagerServiceClient($options);

// Build the resource name of the parent secret and the payload.
$parent = $client->projectLocationSecretName($projectId, $locationId, $secretId);
$secretPayload = new SecretPayload([
'data' => 'my super secret data',
]);

// Build the request.
$request = AddSecretVersionRequest::build($parent, $secretPayload);

// Access the secret version.
$response = $client->addSecretVersion($request);

// Print the new secret version name.
printf('Added secret version: %s', $response->getName());
}
// [END secretmanager_add_regional_secret_version]

// The following 2 lines are only needed to execute the samples on the CLI
require_once __DIR__ . '/../../testing/sample_helpers.php';
\Google\Cloud\Samples\execute_sample(__FILE__, __NAMESPACE__, $argv);
65 changes: 65 additions & 0 deletions secretmanager/src/create_regional_secret.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
<?php
/*
* Copyright 2024 Google LLC.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

/*
* For instructions on how to run the full sample:
*
* @see https://github.com/GoogleCloudPlatform/php-docs-samples/tree/main/secretmanager/README.md
*/

declare(strict_types=1);

namespace Google\Cloud\Samples\SecretManager;

// [START secretmanager_create_regional_secret]
// Import the Secret Manager client library.
use Google\Cloud\SecretManager\V1\CreateSecretRequest;
use Google\Cloud\SecretManager\V1\Secret;
use Google\Cloud\SecretManager\V1\Client\SecretManagerServiceClient;

/**
* @param string $projectId Your Google Cloud Project ID (e.g. 'my-project')
* @param string $locationId Your secret Location (e.g. "us-central1")
* @param string $secretId Your secret ID (e.g. 'my-secret')
*/
function create_regional_secret(string $projectId, string $locationId, string $secretId): void
{
// Specify regional endpoint.
$options = ['apiEndpoint' => "secretmanager.$locationId.rep.googleapis.com"];

// Create the Secret Manager client.
$client = new SecretManagerServiceClient($options);

// Build the resource name of the parent project.
$parent = $client->locationName($projectId, $locationId);

$secret = new Secret();

// Build the request.
$request = CreateSecretRequest::build($parent, $secretId, $secret);

// Create the secret.
$newSecret = $client->createSecret($request);

// Print the new secret name.
printf('Created secret: %s', $newSecret->getName());
}
// [END secretmanager_create_regional_secret]

// The following 2 lines are only needed to execute the samples on the CLI
require_once __DIR__ . '/../../testing/sample_helpers.php';
\Google\Cloud\Samples\execute_sample(__FILE__, __NAMESPACE__, $argv);
Original file line number Diff line number Diff line change
Expand Up @@ -38,8 +38,11 @@
* @param string $secretId Your secret ID (e.g. 'my-secret')
* @param array $locations Replication locations (e.g. array('us-east1', 'us-east4'))
*/
function create_secret_with_user_managed_replication(string $projectId, string $secretId, array $locations): void
{
function create_secret_with_user_managed_replication(
string $projectId,
string $secretId,
array $locations
): void {
// Create the Secret Manager client.
$client = new SecretManagerServiceClient();

Expand Down
60 changes: 60 additions & 0 deletions secretmanager/src/delete_regional_secret.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
<?php
/*
* Copyright 2024 Google LLC.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

/*
* For instructions on how to run the full sample:
*
* @see https://github.com/GoogleCloudPlatform/php-docs-samples/tree/main/secretmanager/README.md
*/

declare(strict_types=1);

namespace Google\Cloud\Samples\SecretManager;

// [START secretmanager_delete_regional_secret]
// Import the Secret Manager client library.
use Google\Cloud\SecretManager\V1\Client\SecretManagerServiceClient;
use Google\Cloud\SecretManager\V1\DeleteSecretRequest;

/**
* @param string $projectId Your Google Cloud Project ID (e.g. 'my-project')
* @param string $locationId Your secret Location (e.g. "us-central1")
* @param string $secretId Your secret ID (e.g. 'my-secret')
*/
function delete_regional_secret(string $projectId, string $locationId, string $secretId): void
{
// Specify regional endpoint.
$options = ['apiEndpoint' => "secretmanager.$locationId.rep.googleapis.com"];

// Create the Secret Manager client.
$client = new SecretManagerServiceClient($options);

// Build the resource name of the secret.
$name = $client->projectLocationSecretName($projectId, $locationId, $secretId);

// Build the request.
$request = DeleteSecretRequest::build($name);

// Delete the secret.
$client->deleteSecret($request);
printf('Deleted secret %s', $secretId);
}
// [END secretmanager_delete_regional_secret]

// The following 2 lines are only needed to execute the samples on the CLI
require_once __DIR__ . '/../../testing/sample_helpers.php';
\Google\Cloud\Samples\execute_sample(__FILE__, __NAMESPACE__, $argv);
67 changes: 67 additions & 0 deletions secretmanager/src/destroy_regional_secret_version.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
<?php
/*
* Copyright 2024 Google LLC.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

/*
* For instructions on how to run the full sample:
*
* @see https://github.com/GoogleCloudPlatform/php-docs-samples/tree/main/secretmanager/README.md
*/

declare(strict_types=1);

namespace Google\Cloud\Samples\SecretManager;

// [START secretmanager_destroy_regional_secret_version]
// Import the Secret Manager client library.
use Google\Cloud\SecretManager\V1\Client\SecretManagerServiceClient;
use Google\Cloud\SecretManager\V1\DestroySecretVersionRequest;

/**
* @param string $projectId Your Google Cloud Project ID (e.g. 'my-project')
* @param string $locationId Your secret Location (e.g. "us-central1")
* @param string $secretId Your secret ID (e.g. 'my-secret')
* @param string $versionId Your version ID (e.g. 'latest' or '5');
*/
function destroy_regional_secret_version(
string $projectId,
string $locationId,
string $secretId,
string $versionId
): void {
// Specify regional endpoint.
$options = ['apiEndpoint' => "secretmanager.$locationId.rep.googleapis.com"];

// Create the Secret Manager client.
$client = new SecretManagerServiceClient($options);

// Build the resource name of the secret version.
$name = $client->projectLocationSecretSecretVersionName($projectId, $locationId, $secretId, $versionId);

// Build the request.
$request = DestroySecretVersionRequest::build($name);

// Destroy the secret version.
$response = $client->destroySecretVersion($request);

// Print a success message.
printf('Destroyed secret version: %s', $response->getName());
}
// [END secretmanager_destroy_regional_secret_version]

// The following 2 lines are only needed to execute the samples on the CLI
require_once __DIR__ . '/../../testing/sample_helpers.php';
\Google\Cloud\Samples\execute_sample(__FILE__, __NAMESPACE__, $argv);
Loading

0 comments on commit 0a13650

Please sign in to comment.