1 import { join } from 'path'
2 import config = require('config')
3 import { each, series } from 'async'
4 import mkdirp = require('mkdirp')
5 import passwordGenerator = require('password-generator')
7 const db = require('./database')
8 import { USER_ROLES, CONFIG, LAST_MIGRATION_VERSION } from './constants'
9 import { clientsExist, usersExist } from './checker'
10 import { logger, createCertsIfNotExist } from '../helpers'
12 function installApplication (callback) {
14 function createDatabase (callbackAsync) {
15 db.sequelize.sync().asCallback(callbackAsync)
16 // db.sequelize.sync({ force: true }).asCallback(callbackAsync)
19 function createDirectories (callbackAsync) {
20 createDirectoriesIfNotExist(callbackAsync)
23 function createCertificates (callbackAsync) {
24 createCertsIfNotExist(callbackAsync)
27 function createOAuthClient (callbackAsync) {
28 createOAuthClientIfNotExist(callbackAsync)
31 function createOAuthUser (callbackAsync) {
32 createOAuthAdminIfNotExist(callbackAsync)
37 // ---------------------------------------------------------------------------
43 // ---------------------------------------------------------------------------
45 function createDirectoriesIfNotExist (callback) {
46 const storages = config.get('storage')
48 each(Object.keys(storages), function (key, callbackEach) {
49 const dir = storages[key]
50 mkdirp(join(__dirname, '..', '..', dir), callbackEach)
54 function createOAuthClientIfNotExist (callback) {
55 clientsExist(function (err, exist) {
56 if (err) return callback(err)
58 // Nothing to do, clients already exist
59 if (exist === true) return callback(null)
61 logger.info('Creating a default OAuth Client.')
63 const id = passwordGenerator(32, false, /[a-z0-9]/)
64 const secret = passwordGenerator(32, false, /[a-zA-Z0-9]/)
65 const client = db.OAuthClient.build({
68 grants: [ 'password', 'refresh_token' ]
71 client.save().asCallback(function (err, createdClient) {
72 if (err) return callback(err)
74 logger.info('Client id: ' + createdClient.clientId)
75 logger.info('Client secret: ' + createdClient.clientSecret)
82 function createOAuthAdminIfNotExist (callback) {
83 usersExist(function (err, exist) {
84 if (err) return callback(err)
86 // Nothing to do, users already exist
87 if (exist === true) return callback(null)
89 logger.info('Creating the administrator.')
91 const username = 'root'
92 const role = USER_ROLES.ADMIN
93 const email = CONFIG.ADMIN.EMAIL
94 const createOptions: { validate?: boolean } = {}
97 // Do not generate a random password for tests
98 if (process.env.NODE_ENV === 'test') {
101 if (process.env.NODE_APP_INSTANCE) {
102 password += process.env.NODE_APP_INSTANCE
105 // Our password is weak so do not validate it
106 createOptions.validate = false
108 password = passwordGenerator(8, true)
118 db.User.create(userData, createOptions).asCallback(function (err, createdUser) {
119 if (err) return callback(err)
121 logger.info('Username: ' + username)
122 logger.info('User password: ' + password)
124 logger.info('Creating Application table.')
125 db.Application.create({ migrationVersion: LAST_MIGRATION_VERSION }).asCallback(callback)