mirror of
				https://github.com/strapi/strapi.git
				synced 2025-11-04 11:54:10 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			162 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			162 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
'use strict';
 | 
						||
 | 
						||
/**
 | 
						||
 * An asynchronous bootstrap function that runs before
 | 
						||
 * your application gets started.
 | 
						||
 *
 | 
						||
 * This gives you an opportunity to set up your data model,
 | 
						||
 * run jobs, or perform some special logic.
 | 
						||
 */
 | 
						||
const _ = require('lodash');
 | 
						||
const uuid = require('uuid/v4');
 | 
						||
 | 
						||
module.exports = async () => {
 | 
						||
  if (!_.get(strapi.plugins['users-permissions'], 'config.jwtSecret')) {
 | 
						||
    const jwtSecret = uuid();
 | 
						||
    _.set(strapi.plugins['users-permissions'], 'config.jwtSecret', jwtSecret);
 | 
						||
 | 
						||
    await strapi.fs.writePluginFile(
 | 
						||
      'users-permissions',
 | 
						||
      'config/jwt.json',
 | 
						||
      JSON.stringify({ jwtSecret }, null, 2)
 | 
						||
    );
 | 
						||
  }
 | 
						||
 | 
						||
  const pluginStore = strapi.store({
 | 
						||
    environment: '',
 | 
						||
    type: 'plugin',
 | 
						||
    name: 'users-permissions',
 | 
						||
  });
 | 
						||
 | 
						||
  const grantConfig = {
 | 
						||
    email: {
 | 
						||
      enabled: true,
 | 
						||
      icon: 'envelope',
 | 
						||
    },
 | 
						||
    discord: {
 | 
						||
      enabled: false,
 | 
						||
      icon: 'comments',
 | 
						||
      key: '',
 | 
						||
      secret: '',
 | 
						||
      callback: '/auth/discord/callback',
 | 
						||
      scope: ['identify', 'email'],
 | 
						||
    },
 | 
						||
    facebook: {
 | 
						||
      enabled: false,
 | 
						||
      icon: 'facebook-official',
 | 
						||
      key: '',
 | 
						||
      secret: '',
 | 
						||
      callback: '/auth/facebook/callback',
 | 
						||
      scope: ['email'],
 | 
						||
    },
 | 
						||
    google: {
 | 
						||
      enabled: false,
 | 
						||
      icon: 'google',
 | 
						||
      key: '',
 | 
						||
      secret: '',
 | 
						||
      callback: '/auth/google/callback',
 | 
						||
      scope: ['email'],
 | 
						||
    },
 | 
						||
    github: {
 | 
						||
      enabled: false,
 | 
						||
      icon: 'github',
 | 
						||
      key: '',
 | 
						||
      secret: '',
 | 
						||
      redirect_uri: '/auth/github/callback',
 | 
						||
      scope: ['user', 'user:email'],
 | 
						||
    },
 | 
						||
    microsoft: {
 | 
						||
      enabled: false,
 | 
						||
      icon: 'windows',
 | 
						||
      key: '',
 | 
						||
      secret: '',
 | 
						||
      callback: '/auth/microsoft/callback',
 | 
						||
      scope: ['user.read'],
 | 
						||
    },
 | 
						||
    twitter: {
 | 
						||
      enabled: false,
 | 
						||
      icon: 'twitter',
 | 
						||
      key: '',
 | 
						||
      secret: '',
 | 
						||
      callback: '/auth/twitter/callback',
 | 
						||
    },
 | 
						||
  };
 | 
						||
  const prevGrantConfig = (await pluginStore.get({ key: 'grant' })) || {};
 | 
						||
  // store grant auth config to db
 | 
						||
  // when plugin_users-permissions_grant is not existed in db
 | 
						||
  // or we have added/deleted provider here.
 | 
						||
  if (
 | 
						||
    !prevGrantConfig ||
 | 
						||
    !_.isEqual(_.keys(prevGrantConfig), _.keys(grantConfig))
 | 
						||
  ) {
 | 
						||
    // merge with the previous provider config.
 | 
						||
    _.keys(grantConfig).forEach(key => {
 | 
						||
      if (key in prevGrantConfig) {
 | 
						||
        grantConfig[key] = _.merge(grantConfig[key], prevGrantConfig[key]);
 | 
						||
      }
 | 
						||
    });
 | 
						||
    await pluginStore.set({ key: 'grant', value: grantConfig });
 | 
						||
  }
 | 
						||
 | 
						||
  if (!(await pluginStore.get({ key: 'email' }))) {
 | 
						||
    const value = {
 | 
						||
      reset_password: {
 | 
						||
        display: 'Email.template.reset_password',
 | 
						||
        icon: 'refresh',
 | 
						||
        options: {
 | 
						||
          from: {
 | 
						||
            name: 'Administration Panel',
 | 
						||
            email: 'no-reply@strapi.io',
 | 
						||
          },
 | 
						||
          response_email: '',
 | 
						||
          object: 'Reset password',
 | 
						||
          message: `<p>We heard that you lost your password. Sorry about that!</p>
 | 
						||
 | 
						||
<p>But don’t worry! You can use the following link to reset your password:</p>
 | 
						||
 | 
						||
<p><%= URL %>?code=<%= TOKEN %></p>
 | 
						||
 | 
						||
<p>Thanks.</p>`,
 | 
						||
        },
 | 
						||
      },
 | 
						||
      email_confirmation: {
 | 
						||
        display: 'Email.template.email_confirmation',
 | 
						||
        icon: 'check-square-o',
 | 
						||
        options: {
 | 
						||
          from: {
 | 
						||
            name: 'Administration Panel',
 | 
						||
            email: 'no-reply@strapi.io',
 | 
						||
          },
 | 
						||
          response_email: '',
 | 
						||
          object: 'Account confirmation',
 | 
						||
          message: `<p>Thank you for registering!</p>
 | 
						||
 | 
						||
<p>You have to confirm your email address. Please click on the link below.</p>
 | 
						||
 | 
						||
<p><%= URL %>?confirmation=<%= CODE %></p>
 | 
						||
 | 
						||
<p>Thanks.</p>`,
 | 
						||
        },
 | 
						||
      },
 | 
						||
    };
 | 
						||
 | 
						||
    await pluginStore.set({ key: 'email', value });
 | 
						||
  }
 | 
						||
 | 
						||
  if (!(await pluginStore.get({ key: 'advanced' }))) {
 | 
						||
    const value = {
 | 
						||
      unique_email: true,
 | 
						||
      allow_register: true,
 | 
						||
      email_confirmation: false,
 | 
						||
      email_confirmation_redirection: `http://${strapi.config.currentEnvironment.server.host}:${strapi.config.currentEnvironment.server.port}/admin`,
 | 
						||
      default_role: 'authenticated',
 | 
						||
    };
 | 
						||
 | 
						||
    await pluginStore.set({ key: 'advanced', value });
 | 
						||
  }
 | 
						||
 | 
						||
  return strapi.plugins[
 | 
						||
    'users-permissions'
 | 
						||
  ].services.userspermissions.initialize();
 | 
						||
};
 |