mirror of
https://github.com/BoostIo/Boostnote
synced 2025-12-15 10:46:32 +00:00
cleanup code of gruntfile
This commit is contained in:
100
gruntfile.js
100
gruntfile.js
@@ -1,13 +1,21 @@
|
|||||||
const path = require('path')
|
const path = require('path')
|
||||||
const ChildProcess = require('child_process')
|
const ChildProcess = require('child_process')
|
||||||
const packager = require('electron-packager')
|
const packager = require('electron-packager')
|
||||||
const fs = require('fs')
|
const appdmg = process.platform === 'darwin'
|
||||||
if (process.platform === 'darwin') {
|
? require('appdmg')
|
||||||
const appdmg = require('appdmg')
|
: null
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = function (grunt) {
|
module.exports = function (grunt) {
|
||||||
if (process.platform === 'win32') auth_code = grunt.file.readJSON('secret/auth_code.json')
|
var auth_code
|
||||||
|
try {
|
||||||
|
auth_code = grunt.file.readJSON('secret/auth_code.json')
|
||||||
|
} catch (e) {
|
||||||
|
if (e.origError.code === 'ENOENT') {
|
||||||
|
console.warn('secret/auth_code.json is not found. CodeSigning is not available.')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const OSX_COMMON_NAME = auth_code != null ? auth_code.OSX_COMMON_NAME : ''
|
||||||
|
const WIN_CERT_PASSWORD = auth_code != null ? auth_code.WIN_CERT_PASSWORD : ''
|
||||||
|
|
||||||
var initConfig = {
|
var initConfig = {
|
||||||
pkg: grunt.file.readJSON('package.json'),
|
pkg: grunt.file.readJSON('package.json'),
|
||||||
@@ -21,23 +29,23 @@ module.exports = function (grunt) {
|
|||||||
iconUrl: path.join(__dirname, 'resources/app.ico'),
|
iconUrl: path.join(__dirname, 'resources/app.ico'),
|
||||||
setupIcon: path.join(__dirname, 'resources/dmg.ico'),
|
setupIcon: path.join(__dirname, 'resources/dmg.ico'),
|
||||||
certificateFile: path.join(__dirname, 'secret', 'authenticode_cer.p12'),
|
certificateFile: path.join(__dirname, 'secret', 'authenticode_cer.p12'),
|
||||||
certificatePassword: auth_code.win_cert_pw,
|
certificatePassword: WIN_CERT_PASSWORD,
|
||||||
noMsi: true
|
noMsi: true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
grunt.initConfig(initConfig)
|
grunt.initConfig(initConfig)
|
||||||
|
|
||||||
grunt.loadNpmTasks('grunt-electron-installer')
|
grunt.loadNpmTasks('grunt-electron-installer')
|
||||||
|
|
||||||
grunt.registerTask('compile', function () {
|
grunt.registerTask('compile', function () {
|
||||||
var done = this.async()
|
var done = this.async()
|
||||||
var execPath = path.join('node_modules', '.bin', 'webpack') + ' --config webpack.config.production.js'
|
var execPath = path.join('node_modules', '.bin', 'webpack') + ' --config webpack-production.config.js'
|
||||||
grunt.log.writeln(execPath)
|
grunt.log.writeln(execPath)
|
||||||
ChildProcess.exec(execPath,
|
ChildProcess.exec(execPath,
|
||||||
{
|
{
|
||||||
env: Object.assign({}, process.env, {
|
env: Object.assign({}, process.env, {
|
||||||
BABEL_ENV: 'production'
|
BABEL_ENV: 'production',
|
||||||
|
NODE_ENV: 'production'
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
function (err, stdout, stderr) {
|
function (err, stdout, stderr) {
|
||||||
@@ -54,32 +62,6 @@ module.exports = function (grunt) {
|
|||||||
)
|
)
|
||||||
})
|
})
|
||||||
|
|
||||||
grunt.registerTask('zip', function (platform) {
|
|
||||||
var done = this.async()
|
|
||||||
switch (platform) {
|
|
||||||
case 'osx':
|
|
||||||
var execPath = 'cd dist/Boostnote-darwin-x64 && zip -r -y -q ../Boostnote-mac.zip Boostnote.app'
|
|
||||||
grunt.log.writeln(execPath)
|
|
||||||
ChildProcess.exec(execPath,
|
|
||||||
function (err, stdout, stderr) {
|
|
||||||
grunt.log.writeln(stdout)
|
|
||||||
|
|
||||||
if (err) {
|
|
||||||
grunt.log.writeln(err)
|
|
||||||
grunt.log.writeln(stderr)
|
|
||||||
done(false)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
done()
|
|
||||||
}
|
|
||||||
)
|
|
||||||
break
|
|
||||||
default:
|
|
||||||
done()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
grunt.registerTask('pack', function (platform) {
|
grunt.registerTask('pack', function (platform) {
|
||||||
grunt.log.writeln(path.join(__dirname, 'dist'))
|
grunt.log.writeln(path.join(__dirname, 'dist'))
|
||||||
var done = this.async()
|
var done = this.async()
|
||||||
@@ -146,17 +128,17 @@ module.exports = function (grunt) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
ChildProcess.exec('codesign --verbose --deep --force --sign \"\" dist/Boostnote-darwin-x64/Boostnote.app', function (err, stdout, stderr) {
|
ChildProcess.exec(`codesign --verbose --deep --force --sign \"${OSX_COMMON_NAME}\" dist/Boostnote-darwin-x64/Boostnote.app`,
|
||||||
grunt.log.writeln(stdout)
|
function (err, stdout, stderr) {
|
||||||
|
grunt.log.writeln(stdout)
|
||||||
if (err) {
|
if (err) {
|
||||||
grunt.log.writeln(err)
|
grunt.log.writeln(err)
|
||||||
grunt.log.writeln(stderr)
|
grunt.log.writeln(stderr)
|
||||||
done(false)
|
done(false)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
grunt.registerTask('create-osx-installer', function () {
|
grunt.registerTask('create-osx-installer', function () {
|
||||||
@@ -186,6 +168,31 @@ module.exports = function (grunt) {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
grunt.registerTask('zip', function (platform) {
|
||||||
|
var done = this.async()
|
||||||
|
switch (platform) {
|
||||||
|
case 'osx':
|
||||||
|
var execPath = 'cd dist/Boostnote-darwin-x64 && zip -r -y -q ../Boostnote-mac.zip Boostnote.app'
|
||||||
|
grunt.log.writeln(execPath)
|
||||||
|
ChildProcess.exec(execPath,
|
||||||
|
function (err, stdout, stderr) {
|
||||||
|
grunt.log.writeln(stdout)
|
||||||
|
if (err) {
|
||||||
|
grunt.log.writeln(err)
|
||||||
|
grunt.log.writeln(stderr)
|
||||||
|
done(false)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
done()
|
||||||
|
}
|
||||||
|
)
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
done()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
grunt.registerTask('build', function (platform) {
|
grunt.registerTask('build', function (platform) {
|
||||||
if (!platform) {
|
if (!platform) {
|
||||||
platform = process.platform === 'darwin' ? 'osx' : process.platform === 'win32' ? 'win' : null
|
platform = process.platform === 'darwin' ? 'osx' : process.platform === 'win32' ? 'win' : null
|
||||||
@@ -200,6 +207,5 @@ module.exports = function (grunt) {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
// Default task(s).
|
|
||||||
grunt.registerTask('default', ['build'])
|
grunt.registerTask('default', ['build'])
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user