async = require('async') _ = require('lodash-contrib') resin = require('resin-sdk') visuals = require('resin-cli-visuals') commandOptions = require('./command-options') exports.list = signature: 'envs' description: 'list all environment variables' help: ''' Use this command to list all environment variables for a particular application or device. This command lists all custom environment variables. If you want to see all environment variables, including private ones used by resin, use the verbose option. Example: $ resin envs --application MyApp $ resin envs --application MyApp --verbose $ resin envs --device MyDevice ''' options: [ commandOptions.optionalApplication commandOptions.optionalDevice { signature: 'verbose' description: 'show private environment variables' boolean: true alias: 'v' } ] permission: 'user' action: (params, options, done) -> async.waterfall([ (callback) -> if options.application? resin.models.environmentVariables.getAllByApplication(options.application, callback) else if options.device? resin.models.environmentVariables.device.getAll(options.device, callback) else return callback(new Error('You must specify an application or device')) (environmentVariables, callback) -> if not options.verbose isSystemVariable = resin.models.environmentVariables.isSystemVariable environmentVariables = _.reject(environmentVariables, isSystemVariable) console.log visuals.widgets.table.horizontal environmentVariables, [ 'id' 'name' 'value' ] return callback() ], done) exports.remove = signature: 'env rm ' description: 'remove an environment variable' help: ''' Use this command to remove an environment variable from an application. Don't remove resin specific variables, as things might not work as expected. Notice this command asks for confirmation interactively. You can avoid this by passing the `--yes` boolean option. If you want to eliminate a device environment variable, pass the `--device` boolean option. Examples: $ resin env rm 215 $ resin env rm 215 --yes $ resin env rm 215 --device ''' options: [ commandOptions.yes commandOptions.booleanDevice ] permission: 'user' action: (params, options, done) -> visuals.patterns.remove 'environment variable', options.yes, (callback) -> if options.device resin.models.environmentVariables.device.remove(params.id, callback) else resin.models.environmentVariables.remove(params.id, callback) , done exports.add = signature: 'env add [value]' description: 'add an environment variable' help: ''' Use this command to add an enviroment variable to an application. If value is omitted, the tool will attempt to use the variable's value as defined in your host machine. Use the `--device` option if you want to assign the environment variable to a specific device. If the value is grabbed from the environment, a warning message will be printed. Use `--quiet` to remove it. Examples: $ resin env add EDITOR vim --application MyApp $ resin env add TERM --application MyApp $ resin env add EDITOR vim --device MyDevice ''' options: [ commandOptions.optionalApplication commandOptions.optionalDevice ] permission: 'user' action: (params, options, done) -> if not params.value? params.value = process.env[params.key] if not params.value? return done(new Error("Environment value not found for key: #{params.key}")) else console.info("Warning: using #{params.key}=#{params.value} from host environment") if options.application? resin.models.environmentVariables.create(options.application, params.key, params.value, done) else if options.device? resin.models.environmentVariables.device.create(options.device, params.key, params.value, done) else return done(new Error('You must specify an application or device')) exports.rename = signature: 'env rename ' description: 'rename an environment variable' help: ''' Use this command to rename an enviroment variable from an application. Pass the `--device` boolean option if you want to rename a device environment variable. Examples: $ resin env rename 376 emacs $ resin env rename 376 emacs --device ''' permission: 'user' options: [ commandOptions.booleanDevice ] action: (params, options, done) -> if options.device resin.models.environmentVariables.device.update(params.id, params.value, done) else resin.models.environmentVariables.update(params.id, params.value, done)