Allows you to define environment variables to be used in config of future grunt tasks in the chain. Variables can be a JSON/String stored in external file, hard-coded or can be the result of a function.
This plugin requires Grunt ~0.4.x
If you haven't used Grunt before, be sure to check out the Getting Started guide, as it explains how to create a Gruntfile as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:
npm install grunt-set-env --save-dev
Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:
grunt.loadNpmTasks('grunt-set-env');
In your project's Gruntfile, add a section named setenv
to the data object passed into grunt.initConfig()
.
grunt.initConfig({
setenv: {
options: {
envFolder: "config/env"
},
dev: {
envTarget:"env"
},
prod:{
env:{ root_folder : "production"}
},
test:{
envKey:"test",
env:function(){
return "test"
}
}
},
});
Type: String
Default value: 'env'
A string value that is used to determine the folder from where json configuration will be read from.
Type: String
Default value: 'dev'
A string value that is used to recognize the specific json config file which will be read
Type: String
Default value: 'env'
A string value that is used as key for grunt.config. To recover the environment values <%=key.whatever%> or grunt.config.get("key");
Type: String
,Object
,Function
Default value: 'undefined'
An environment variable which will be used instead of reading from a json. It can be the result of a function, a String or an Object.
In this example if you run grunt setenv:dev
it will search for the dev.json file in config/env folder. If found
it will set in grunt.config the env key with the json object. Considering the json {deploy_root:'path'}
for all the tasks runned after setenv:dev
grunt.initConfig({
setenv: {
options: {
envFolder: "config/env"
},
dev:{
envTarget:"dev.json" // this is also default
}
},
someothertask:{
options:{
dest:"<%=env.deploy_root%>/",
src: function(){
var envObject = grunt.config.get("env");
}
}
}
});
grunt.registerTask('build','setenv:dev','someothertask')
In this example, I am creating 3 environments.
- dev : will have json stored in the config/env/env.json
- prod: will have json hardcoded
- test: will have custom key: test and the environment variable from function
grunt.initConfig({
setenv: {
options: {
envFolder: "config/env"
},
dev: {
envTarget:"env"
},
prod:{
env:{ root_folder : "production"}
},
test:{
envKey:"test",
env:function(){
return "test"
}
}
},
});
In this example I will be able to deploy on different environments:
- grunt deploy:dev
- grunt deploy:testOne
- grunt deploy:testTwo
module.exports = function (grunt) {
grunt.initConfig({
pkg: grunt.file.readJSON('package.json')
});
grunt.config('setenv', {
dev: {
options: {
envFolder: "grunt-tasks/env"
}
}
});
grunt.registerTask('deploy', function (env) {
grunt.task.run([
'setenv:' + env,
"clean",
'jshint',
'copy:static',
'less',
'useminPrepare',
'requirejs',
'concat',
'usemin',
'processhtml',
'uglify',
'cssmin'
]);
});
};
grunt.config('copy', {
static: {
files: [
{expand: true, cwd: 'src/', src: ['index.html'], dest: '<%=env.folder%>/'},
/* boostrap fonts and images*/
{expand: true, cwd: 'src/static/vendor/bootstrap/fonts', src: ['**'], dest: '<%=env.folder%>/static/fonts'},
/** img stuff */
{expand: true, cwd: 'src/static/img', src: ['**'], dest: '<%=env.folder%>/static/img'}
]
}
);
};
Example of environment config file: grunt-tasks/env/dev.json
It can contain other variables as well. (eg: pkg)
{
"type": "deployment",
"folder": "deploy/<%=pkg.name%>-<%=pkg.version%>"
}
https://github.com/mikibrv/grunt-set-env
- 0.1.2 Initial release + readme changes
##Author Miklos Csere