resgen / lumen-gcp
v1.0.2
2020-03-25 18:01 UTC
Requires
- php: >=7.3
- laravel/lumen-framework: >=5.8
Requires (Dev)
- mockery/mockery: ^1.0
- phpunit/phpunit: ^7.0
This package is auto-updated.
Last update: 2024-10-18 23:45:44 UTC
README
GCP Service Account authentication provider powered by ENV vars. Base64 decodes Json service account from ENV and puts it down as a usable service account file. Works with multiple GCP service accounts in the ENV aswell.
Requirements
- Lumen 5.8+
- ENV var APP_GCP_SERVICE_ACCOUNT with base64 encoded GCP Service Account JSON
Install
With composer:
composer require resgen/lumen-gcp:1.0.*
Why base64 Json?
Env vars with JSON values are more system universal when they are base64 encoded values. Some systems work fine with json values in ENV vars, some do not.
Kubernetes
If you are using kubernetes secrets, be sure to double base64 encode the value. This will ensure that the env var will still be base64 encoded inside your pod's ENV.
Basic Example
Env:
# base64 service account json text. example is encoded {'foo':'bar'}
APP_GCP_SERVICE_ACCOUNT=e2ZvbzpiYXJ9
Example Code:
use Google\Cloud\Storage\StorageClient; use Resgen\Common\Gcp\GoogleServiceAccountProvider; use Resgen\Common\Gcp\GoogleServiceAccount; // omitting Lumen app init...follow their examples // Register service account in your app $app->register(GoogleServiceAccountProvider::class); // Example GCP Storage client usage $gcpStorageClient = new StorageClient([ 'keyFilePath' => app(GoogleServiceAccount::class)->getFilePath() ]);
Multiple Service Accounts Example
Env:
APP_GCP_ACCOUNTS=APP_GCP_SERVICE_ACCOUNT_ONE,APP_GCP_SERVICE_ACCOUNT_TWO,APP_GCP_SERVICE_ACCOUNT_THREE
# base64 service account json text. example is encoded {'foo':'bar'}
GCP_ACCOUNT_ONE=e2ZvbzpiYXJ9
GCP_ACCOUNT_TWO=e2ZvbzpiYXJ9
GCP_ACCOUNT_THREE=e2ZvbzpiYXJ9
Example Code:
use Google\Cloud\Storage\StorageClient; use Resgen\Common\Gcp\GoogleServiceAccountProvider; use Resgen\Common\Gcp\GoogleServiceAccountBundle; // omitting Lumen app init...follow their examples // Register service account in your app $app->register(GoogleServiceAccountProvider::class); $gcpAccountBundle = app(GoogleServiceAccountBundle::class); // Example GCP Storage client usage $storageAccountOne = new StorageClient([ 'keyFilePath' => $gcpAccountBundle->get('GCP_ACCOUNT_ONE')->getFilePath() ]); $storageAccountTwo = new StorageClient([ 'keyFilePath' => $gcpAccountBundle->get('GCP_ACCOUNT_TWO')->getFilePath() ]); $storageAccountThree = new StorageClient([ 'keyFilePath' => $gcpAccountBundle->get('GCP_ACCOUNT_THREE')->getFilePath() ]);