mirror of
https://github.com/balena-io/balena-cli.git
synced 2024-12-29 18:18:50 +00:00
170 lines
4.4 KiB
CoffeeScript
170 lines
4.4 KiB
CoffeeScript
###
|
|
Copyright 2016 Resin.io
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
###
|
|
|
|
exports.read =
|
|
signature: 'config read'
|
|
description: 'read a device configuration'
|
|
help: '''
|
|
Use this command to read the config.json file from a provisioned device
|
|
|
|
Examples:
|
|
|
|
$ resin config read --type raspberry-pi
|
|
$ resin config read --type raspberry-pi --drive /dev/disk2
|
|
'''
|
|
options: [
|
|
{
|
|
signature: 'type'
|
|
description: 'device type'
|
|
parameter: 'type'
|
|
alias: 't'
|
|
required: 'You have to specify a device type'
|
|
}
|
|
{
|
|
signature: 'drive'
|
|
description: 'drive'
|
|
parameter: 'drive'
|
|
alias: 'd'
|
|
}
|
|
]
|
|
permission: 'user'
|
|
root: true
|
|
action: (params, options, done) ->
|
|
Promise = require('bluebird')
|
|
config = require('resin-config-json')
|
|
visuals = require('resin-cli-visuals')
|
|
umount = Promise.promisifyAll(require('umount'))
|
|
prettyjson = require('prettyjson')
|
|
|
|
Promise.try ->
|
|
return options.drive or visuals.drive('Select the device drive')
|
|
.tap(umount.umountAsync)
|
|
.then (drive) ->
|
|
return config.read(drive, options.type)
|
|
.tap (configJSON) ->
|
|
console.info(prettyjson.render(configJSON))
|
|
.nodeify(done)
|
|
|
|
exports.write =
|
|
signature: 'config write <key> <value>'
|
|
description: 'write a device configuration'
|
|
help: '''
|
|
Use this command to write the config.json file of a provisioned device
|
|
|
|
Examples:
|
|
|
|
$ resin config write --type raspberry-pi username johndoe
|
|
$ resin config write --type raspberry-pi --drive /dev/disk2 username johndoe
|
|
$ resin config write --type raspberry-pi files.network/settings "..."
|
|
'''
|
|
options: [
|
|
{
|
|
signature: 'type'
|
|
description: 'device type'
|
|
parameter: 'type'
|
|
alias: 't'
|
|
required: 'You have to specify a device type'
|
|
}
|
|
{
|
|
signature: 'drive'
|
|
description: 'drive'
|
|
parameter: 'drive'
|
|
alias: 'd'
|
|
}
|
|
]
|
|
permission: 'user'
|
|
root: true
|
|
action: (params, options, done) ->
|
|
Promise = require('bluebird')
|
|
_ = require('lodash')
|
|
config = require('resin-config-json')
|
|
visuals = require('resin-cli-visuals')
|
|
umount = Promise.promisifyAll(require('umount'))
|
|
|
|
Promise.try ->
|
|
return options.drive or visuals.drive('Select the device drive')
|
|
.tap(umount.umountAsync)
|
|
.then (drive) ->
|
|
config.read(drive, options.type).then (configJSON) ->
|
|
console.info("Setting #{params.key} to #{params.value}")
|
|
_.set(configJSON, params.key, params.value)
|
|
return configJSON
|
|
.tap ->
|
|
return umount.umountAsync(drive)
|
|
.then (configJSON) ->
|
|
return config.write(drive, options.type, configJSON)
|
|
.tap ->
|
|
console.info('Done')
|
|
.nodeify(done)
|
|
|
|
exports.reconfigure =
|
|
signature: 'config reconfigure'
|
|
description: 'reconfigure a provisioned device'
|
|
help: '''
|
|
Use this command to reconfigure a provisioned device
|
|
|
|
Examples:
|
|
|
|
$ resin config reconfigure --type raspberry-pi
|
|
$ resin config reconfigure --type raspberry-pi --advanced
|
|
$ resin config reconfigure --type raspberry-pi --drive /dev/disk2
|
|
'''
|
|
options: [
|
|
{
|
|
signature: 'type'
|
|
description: 'device type'
|
|
parameter: 'type'
|
|
alias: 't'
|
|
required: 'You have to specify a device type'
|
|
}
|
|
{
|
|
signature: 'drive'
|
|
description: 'drive'
|
|
parameter: 'drive'
|
|
alias: 'd'
|
|
}
|
|
{
|
|
signature: 'advanced'
|
|
description: 'show advanced commands'
|
|
boolean: true
|
|
alias: 'v'
|
|
}
|
|
]
|
|
permission: 'user'
|
|
root: true
|
|
action: (params, options, done) ->
|
|
Promise = require('bluebird')
|
|
config = require('resin-config-json')
|
|
visuals = require('resin-cli-visuals')
|
|
capitano = Promise.promisifyAll(require('capitano'))
|
|
umount = Promise.promisifyAll(require('umount'))
|
|
|
|
Promise.try ->
|
|
return options.drive or visuals.drive('Select the device drive')
|
|
.tap(umount.umountAsync)
|
|
.then (drive) ->
|
|
config.read(drive, options.type).get('uuid')
|
|
.tap ->
|
|
umount.umountAsync(drive)
|
|
.then (uuid) ->
|
|
configureCommand = "os configure #{drive} #{uuid}"
|
|
if options.advanced
|
|
configureCommand += ' --advanced'
|
|
return capitano.runAsync(configureCommand)
|
|
.then ->
|
|
console.info('Done')
|
|
.nodeify(done)
|