Skip to content

Commit f65d03a

Browse files
feat(Storage): Dual-Region Sample (#1618)
1 parent b57070f commit f65d03a

File tree

3 files changed

+77
-2
lines changed

3 files changed

+77
-2
lines changed
Lines changed: 53 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
1+
<?php
2+
/**
3+
* Copyright 2022 Google LLC
4+
*
5+
* Licensed under the Apache License, Version 2.0 (the "License");
6+
* you may not use this file except in compliance with the License.
7+
* You may obtain a copy of the License at
8+
*
9+
* http://www.apache.org/licenses/LICENSE-2.0
10+
*
11+
* Unless required by applicable law or agreed to in writing, software
12+
* distributed under the License is distributed on an "AS IS" BASIS,
13+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14+
* See the License for the specific language governing permissions and
15+
* limitations under the License.
16+
*/
17+
18+
/**
19+
* For instructions on how to run the full sample:
20+
*
21+
* @see https://github.com/GoogleCloudPlatform/php-docs-samples/tree/master/storage/README.md
22+
*/
23+
24+
namespace Google\Cloud\Samples\Storage;
25+
26+
# [START storage_create_bucket_dual_region]
27+
use Google\Cloud\Storage\StorageClient;
28+
29+
/**
30+
* Create a new bucket with a custom default storage class and location.
31+
*
32+
* @param string $bucketName The name of your Cloud Storage bucket.
33+
* @param string $location1 First location for the bucket's regions. Case-insensitive.
34+
* @param string $location2 Second location for the bucket's regions. Case-insensitive.
35+
*/
36+
function create_bucket_dual_region($bucketName, $location1, $location2)
37+
{
38+
// $bucketName = 'my-bucket';
39+
// $location1 = 'US-EAST1';
40+
// $location2 = 'US-WEST1';
41+
42+
$storage = new StorageClient();
43+
$bucket = $storage->createBucket($bucketName, [
44+
'location' => "${location1}+${location2}",
45+
]);
46+
47+
printf("Created dual-region bucket '%s' in '%s+%s'", $bucket->name(), $location1, $location2);
48+
}
49+
# [END storage_create_bucket_dual_region]
50+
51+
// The following 2 lines are only needed to run the samples
52+
require_once __DIR__ . '/../../testing/sample_helpers.php';
53+
\Google\Cloud\Samples\execute_sample(__FILE__, __NAMESPACE__, $argv);

storage/src/create_bucket_turbo_replication.php

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,8 @@
3131
* The bucket must be a dual-region bucket for this setting to take effect.
3232
*
3333
* @param string $bucketName The name of your Cloud Storage bucket.
34-
* @param string $location The Dual Region location where you want your bucket to reside. (Read more at https://cloud.google.com/storage/docs/locations#location-dr)
34+
* @param string $location The Dual-Region location where you want your bucket to reside (e.g. "US-CENTRAL1+US-WEST1").
35+
Read more at https://cloud.google.com/storage/docs/locations#location-dr
3536
*/
3637
function create_bucket_turbo_replication($bucketName, $location = 'nam4')
3738
{
@@ -40,7 +41,7 @@ function create_bucket_turbo_replication($bucketName, $location = 'nam4')
4041
$storage = new StorageClient();
4142
$rpo = 'ASYNC_TURBO';
4243

43-
// providing a location which is a dual region location
44+
// providing a location which is a dual-region location
4445
// makes sure the locationType is set to 'dual-region' implicitly
4546
// we can pass 'locationType' => 'dual-region'
4647
// to make it explicit

storage/test/storageTest.php

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -672,6 +672,27 @@ public function testCreateBucketClassLocation()
672672
$this->assertStringContainsString('Created bucket', $output);
673673
}
674674

675+
public function testCreateBucketDualRegion()
676+
{
677+
$location1 = 'US-EAST1';
678+
$location2 = 'US-WEST1';
679+
680+
$bucketName = uniqid('samples-create-bucket-dual-region-');
681+
$output = self::runFunctionSnippet('create_bucket_dual_region', [
682+
$bucketName,
683+
$location1,
684+
$location2
685+
]);
686+
687+
$bucket = self::$storage->bucket($bucketName);
688+
$exists = $bucket->exists();
689+
$bucket->delete();
690+
691+
$this->assertTrue($exists);
692+
$this->assertStringContainsString('Created dual-region bucket', $output);
693+
$this->assertStringContainsString("${location1}+${location2}", $output);
694+
}
695+
675696
public function testObjectCsekToCmek()
676697
{
677698
$objectName = uniqid('samples-object-csek-to-cmek-');

0 commit comments

Comments
 (0)