Deploy Strapi V4 (CMS) in Google Cloud Run using GitHub, Google Cloud Build and integrate Google Cloud SQL (MySQL) and Google Cloud Storage — Part 2
We have already integrated Strapi with Github, Cloud Build Cloud Run and Cloud SQL. Now we are going to integrate Cloud Storage.
data:image/s3,"s3://crabby-images/3c932/3c932b0716971acf6f7dfae24591e19367520dc4" alt=""
Step 1 — Create Google Cloud Storage Bucket
Go to Cloud Storage and click Create Button
data:image/s3,"s3://crabby-images/20567/2056727bf7346579359115bf20bbe2a7555c43f6" alt=""
Give bucket name and select region and then in Choose how to control access to objects section select the Fine-grained option.
data:image/s3,"s3://crabby-images/38e4f/38e4fed6c097b3cb8ba9295c956521406d80cbbc" alt=""
Create Bucket.
data:image/s3,"s3://crabby-images/c5720/c5720febe0dc4d29449afe2aade9531ae6d23ae5" alt=""
Select PERMISSIONS and click on ADD
data:image/s3,"s3://crabby-images/02c25/02c25c266bfe4e32f675dcda1c55b464c2c35901" alt=""
Select New Principals as allUsers and Role as Storage Object Viewer
data:image/s3,"s3://crabby-images/06ca6/06ca654e76170efc873a4e2b50843bb3af6d3ab3" alt=""
Save and ALLOW PUBLIC ACCESS.
data:image/s3,"s3://crabby-images/f7422/f7422cd3afc913310b33f3279694d139b467e231" alt=""
Step 2 — Update Environment Variable
Go to your Cloud Run Instance and click on Edit & Deploy New Version.
data:image/s3,"s3://crabby-images/fc239/fc239b03afa856859b49581f581f0741959044dc" alt=""
Add new Environment Variables.
GCS_BUCKET_NAME (value = your bucket name in my case it is strapi-cbt-bucket-prod)
GCS_PUBLIC_FILES (value = false)
GCS_UNIFORM (value = false)
Click Deploy.
Step 3 — Configure Strapi
Open the terminal in your Strapi project root folder and execute.
yarn add @strapi-community/strapi-provider-upload-google-cloud-storage
Create the following files in the production folder
File path =./config/env/production/middlewares.js
module.exports = \[
'strapi::errors',
{
name: 'strapi::security',
config: {
contentSecurityPolicy: {
useDefaults: true,
directives: {
'connect-src': \["'self'", 'https:'\],
'img-src': \["'self'", 'data:', 'blob:', 'storage.googleapis.com'\],
'media-src': \["'self'", 'data:', 'blob:', 'storage.googleapis.com'\],
upgradeInsecureRequests: null,
},
},
},
},
'strapi::cors',
'strapi::poweredBy',
'strapi::logger',
'strapi::query',
'strapi::body',
'strapi::session',
'strapi::favicon',
'strapi::public',
\];
File path =./config/env/production/plugins.js
module.exports = ({ env }) => ({
upload: {
config: {
provider: '[@strapi](http://twitter.com/strapi)\-community/strapi-provider-upload-google-cloud-storage',
providerOptions: {
bucketName: env('GCS\_BUCKET\_NAME'),
publicFiles: env('GCS\_PUBLIC\_FILES'),
uniform: env('GCS\_UNIFORM'),
basePath: '',
},
},
},
//...
});
data:image/s3,"s3://crabby-images/23bf6/23bf6e6544271ed1fe2e047f0cddb6a28fd0fff7" alt=""
Commit changes and Push them to your Github repository.
Step 4 —Party 🎉
Once your cloud build is deployed.
Launch your URL and log in to your Strapi account.
Upload an image in Media Library
data:image/s3,"s3://crabby-images/1ca15/1ca15df69ff230e04d3b48031686a8ab9067b3b1" alt=""
See the uploaded image in your Google Cloud Storage bucket.
data:image/s3,"s3://crabby-images/06140/06140196c4339cf9154ed6f925d045f45c878895" alt=""
Great! our image is stored successfully.
Thank you so much for coming this far, if you have liked the post don’t hesitate to give me a clap! that matters a lot.