Strapi beta version set default file upload provider to AWS S3 / Google Cloud Storage (GCS) /…
Jul 11, 2020

Strapi beta version set default file upload provider to AWS S3 / Google Cloud Storage (GCS) /…

For Strapi version 3.0.0-beta.19.5 or before

Recently I am exploring the features of one of the most famous headless CMS open-source platforms — Strapi. In case you are new to Strapi, here is a short description of them

Strapi comes from the word Bootstrap, and helps Bootstrap your API

Strapi is a flexible, open-source Headless CMS that allows you to create content-type with several clicks and it will prepare all the needed schema, ORM and generated some handy predefined APIs for you.

Set default file upload provider as Cloudinary

By default, Strapi will use a plugin called strapi-plugin-upload-local which will upload files to your local file system.

If you are deploying your Strapi application to Heroku and looking for a workaround for its ephemeral file system nature which doesn’t persist your files after restarting the server, you can change your file upload provider to some other cloud storage providers.

Currently, there are 3 options available from the official Strapi team:

  1. Cloudinary

  2. AWS S3

  3. Rackspace

You can also check out other community plugins here.

After you have installed the plugin and follow through the guide. You would be able to change your file plugin provider by using the admin panel UI.

But in case you don’t want to do it manually and instead, you would like to change the default provider, this article will go through the process using Cloudinary as an example

Steps

  1. Install the plugin using npm or yarn
yarn add strapi-provider-upload-cloudinary  
// OR  
npm install --save strapi-provider-upload-cloudinary
  1. Copy below code snippet to your config/functions/bootstrap.js
"use strict";  
  
const isFirstRun = async () => {  
  const pluginStore = strapi.store({  
    environment: strapi.config.environment,  
    type: "type",  
    name: "setup",  
  });  
  const initHasRun = await pluginStore.get({ key: "initHasRun" });  
  await pluginStore.set({ key: "initHasRun", value: true });  
  return !initHasRun;  
};  
  
const setDefaultFileUploader = async () => {  
  if (strapi.config.environment !== "production") {  
    return;  
  }  
  const pluginStore = strapi.store({  
    environment: strapi.config.environment,  
    type: "plugin",  
    name: "upload",  
  });  
  const config = await pluginStore.get({ key: "provider" });  
  await pluginStore.set({  
    key: "provider",  
    value: {  
      ...config,  
      ...{  
        provider: "cloudinary",  
        name: "Cloudinary",  
        cloud_name: process.env.CLOUDINARY_CLOUD_NAME,  
        api_key: process.env.CLOUDINARY_API_KEY,  
        api_secret: process.env.CLOUDINARY_API_SECRET,  
      },  
    },  
  });  
};  
  
module.exports = async () => {  
  const shouldInit = await isFirstRun();  
  if (shouldInit) {  
    await setDefaultFileUploader();  
  }  
};

Let me explain a bit the code here.

Strapi will run the bootstrap.js whenever the application is started.

The isFirstRun method here will detect whether it is the first time running your Strapi application. This method is shared by Maxime Castres’s article here.

It is a good place to set the default file upload provider!

The setDefaultFileUploader method here will check if the current running environment is production, and then get the existing file upload config and override it with the settings required for Cloudinary.

cloud_name: process.env.CLOUDINARY_CLOUD_NAME,  
api_key: process.env.CLOUDINARY_API_KEY,  
api_secret: process.env.CLOUDINARY_API_SECRET,

You can set this Node environment variables with dotenv or if you are deploying it to Heroku, you can set environment variables using

heroku config:set CLOUDINARY_CLOUD_NAME=YOUR_CLOUD_NAME  
heroku config:set CLOUDINARY_API_KEY=YOUR_API_KEY  
heroku config:set CLOUDINARY_API_SECRET=YOUR_API_SECRET

And that’s it! Enjoy!

Photo by Drew Coffman on Unsplash

Kwinten
Written by: Kwinten
Node.js, JavaScript, Cloud computing, Serverless and more
Back