2017-07-27 11:07:05 +00:00
// Generated by CoffeeScript 1.12.7
2016-01-11 19:58:35 +00:00
/ *
2017-06-14 21:20:15 +00:00
Copyright 2016 - 2017 Resin . io
2016-01-11 19:58:35 +00:00
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 .
* /
2017-06-12 08:42:08 +00:00
var INIT _WARNING _MESSAGE , _ , buildConfig , commandOptions , formatVersion , resolveVersion ;
2016-01-11 19:58:35 +00:00
2017-03-22 09:46:06 +00:00
commandOptions = require ( './command-options' ) ;
2015-09-29 17:36:29 +00:00
2017-06-09 10:44:58 +00:00
_ = require ( 'lodash' ) ;
2017-03-22 10:50:06 +00:00
formatVersion = function ( v , isRecommended ) {
var result ;
result = "v" + v ;
if ( isRecommended ) {
result += ' (recommended)' ;
}
return result ;
} ;
resolveVersion = function ( deviceType , version ) {
var form , resin ;
if ( version !== 'menu' ) {
2017-10-17 15:28:40 +00:00
if ( version [ 0 ] === 'v' ) {
version = version . slice ( 1 ) ;
}
2017-03-22 10:50:06 +00:00
return Promise . resolve ( version ) ;
}
form = require ( 'resin-cli-form' ) ;
resin = require ( 'resin-sdk-preconfigured' ) ;
return resin . models . os . getSupportedVersions ( deviceType ) . then ( function ( arg ) {
var choices , recommended , versions ;
versions = arg . versions , recommended = arg . recommended ;
choices = versions . map ( function ( v ) {
return {
value : v ,
name : formatVersion ( v , v === recommended )
} ;
} ) ;
return form . ask ( {
message : 'Select the OS version:' ,
type : 'list' ,
choices : choices ,
"default" : recommended
} ) ;
} ) ;
} ;
2017-06-08 19:58:37 +00:00
exports . versions = {
signature : 'os versions <type>' ,
description : 'show the available resinOS versions for the given device type' ,
help : 'Use this command to show the available resinOS versions for a certain device type.\nCheck available types with `resin devices supported`\n\nExample:\n\n $ resin os versions raspberrypi3' ,
action : function ( params , options , done ) {
var resin ;
resin = require ( 'resin-sdk-preconfigured' ) ;
return resin . models . os . getSupportedVersions ( params . type ) . then ( function ( arg ) {
var recommended , versions ;
versions = arg . versions , recommended = arg . recommended ;
return versions . forEach ( function ( v ) {
return console . log ( formatVersion ( v , v === recommended ) ) ;
} ) ;
} ) ;
}
} ;
2017-03-22 09:46:06 +00:00
exports . download = {
signature : 'os download <type>' ,
description : 'download an unconfigured os image' ,
2017-05-12 10:01:37 +00:00
help : 'Use this command to download an unconfigured os image for a certain device type.\nCheck available types with `resin devices supported`\n\nIf version is not specified the newest stable (non-pre-release) version of OS\nis downloaded if available, or the newest version otherwise (if all existing\nversions for the given device type are pre-release).\n\nYou can pass `--version menu` to pick the OS version from the interactive menu\nof all available versions.\n\nExamples:\n\n $ resin os download raspberrypi3 -o ../foo/bar/raspberry-pi.img\n $ resin os download raspberrypi3 -o ../foo/bar/raspberry-pi.img --version 1.24.1\n $ resin os download raspberrypi3 -o ../foo/bar/raspberry-pi.img --version ^1.20.0\n $ resin os download raspberrypi3 -o ../foo/bar/raspberry-pi.img --version latest\n $ resin os download raspberrypi3 -o ../foo/bar/raspberry-pi.img --version default\n $ resin os download raspberrypi3 -o ../foo/bar/raspberry-pi.img --version menu' ,
2017-03-22 09:46:06 +00:00
permission : 'user' ,
options : [
{
signature : 'output' ,
description : 'output path' ,
parameter : 'output' ,
alias : 'o' ,
required : 'You have to specify the output location'
2017-06-08 19:58:37 +00:00
} , commandOptions . osVersion
2017-03-22 09:46:06 +00:00
] ,
action : function ( params , options , done ) {
2017-03-22 10:50:06 +00:00
var Promise , displayVersion , fs , manager , rindle , unzip , visuals ;
Promise = require ( 'bluebird' ) ;
2017-03-22 09:46:06 +00:00
unzip = require ( 'unzip2' ) ;
fs = require ( 'fs' ) ;
2015-12-07 14:32:24 +00:00
rindle = require ( 'rindle' ) ;
2017-03-22 09:46:06 +00:00
manager = require ( 'resin-image-manager' ) ;
2015-12-07 14:32:24 +00:00
visuals = require ( 'resin-cli-visuals' ) ;
2017-03-22 09:46:06 +00:00
console . info ( "Getting device operating system for " + params . type ) ;
2017-03-22 10:50:06 +00:00
displayVersion = '' ;
return Promise [ "try" ] ( function ( ) {
if ( ! options . version ) {
console . warn ( 'OS version is not specified, using the default version: the newest stable (non-pre-release) version if available, or the newest version otherwise (if all existing versions for the given device type are pre-release).' ) ;
return 'default' ;
}
return resolveVersion ( params . type , options . version ) ;
} ) . then ( function ( version ) {
if ( version !== 'default' ) {
displayVersion = " " + version ;
}
return manager . get ( params . type , version ) ;
} ) . then ( function ( stream ) {
2017-03-22 09:46:06 +00:00
var bar , output , spinner ;
2017-03-22 10:28:46 +00:00
bar = new visuals . Progress ( "Downloading Device OS" + displayVersion ) ;
spinner = new visuals . Spinner ( "Downloading Device OS" + displayVersion + " (size unknown)" ) ;
2017-03-22 09:46:06 +00:00
stream . on ( 'progress' , function ( state ) {
if ( state != null ) {
return bar . update ( state ) ;
} else {
return spinner . start ( ) ;
}
} ) ;
stream . on ( 'end' , function ( ) {
return spinner . stop ( ) ;
} ) ;
if ( stream . mime === 'application/zip' ) {
output = unzip . Extract ( {
path : options . output
} ) ;
} else {
output = fs . createWriteStream ( options . output ) ;
2015-09-29 17:36:29 +00:00
}
2017-03-22 09:46:06 +00:00
return rindle . wait ( stream . pipe ( output ) ) [ "return" ] ( options . output ) ;
} ) . tap ( function ( output ) {
return console . info ( 'The image was downloaded successfully' ) ;
} ) . nodeify ( done ) ;
}
} ;
2015-09-29 17:36:29 +00:00
2017-06-12 08:42:08 +00:00
buildConfig = function ( image , deviceType , advanced ) {
var form , helpers ;
if ( advanced == null ) {
advanced = false ;
}
form = require ( 'resin-cli-form' ) ;
helpers = require ( '../utils/helpers' ) ;
return helpers . getManifest ( image , deviceType ) . get ( 'options' ) . then ( function ( questions ) {
var advancedGroup , override ;
if ( ! advanced ) {
2017-08-16 16:16:21 +00:00
advancedGroup = _ . find ( questions , {
2017-06-12 08:42:08 +00:00
name : 'advanced' ,
isGroup : true
} ) ;
if ( advancedGroup != null ) {
override = helpers . getGroupDefaults ( advancedGroup ) ;
}
}
return form . run ( questions , {
override : override
} ) ;
} ) ;
} ;
exports . buildConfig = {
signature : 'os build-config <image> <device-type>' ,
description : 'build the OS config and save it to the JSON file' ,
help : 'Use this command to prebuild the OS config once and skip the interactive part of `resin os configure`.\n\nExamples:\n\n $ resin os build-config ../path/rpi3.img raspberrypi3 --output rpi3-config.json\n $ resin os configure ../path/rpi3.img 7cf02a6 --config "$(cat rpi3-config.json)"' ,
permission : 'user' ,
options : [
2017-06-14 21:51:56 +00:00
commandOptions . advancedConfig , {
2017-06-12 08:42:08 +00:00
signature : 'output' ,
description : 'the path to the output JSON file' ,
alias : 'o' ,
required : 'the output path is required' ,
parameter : 'output'
}
] ,
action : function ( params , options , done ) {
var Promise , fs , writeFileAsync ;
fs = require ( 'fs' ) ;
Promise = require ( 'bluebird' ) ;
writeFileAsync = Promise . promisify ( fs . writeFile ) ;
return buildConfig ( params . image , params [ 'device-type' ] , options . advanced ) . then ( function ( answers ) {
return writeFileAsync ( options . output , JSON . stringify ( answers , null , 4 ) ) ;
} ) . nodeify ( done ) ;
}
} ;
2017-03-22 09:46:06 +00:00
exports . configure = {
2017-04-19 03:22:43 +00:00
signature : 'os configure <image> <uuid> [deviceApiKey]' ,
2017-03-22 09:46:06 +00:00
description : 'configure an os image' ,
2017-10-13 18:29:47 +00:00
help : 'Use this command to configure a previously downloaded operating system image for the specific device.\n\nNote that device api keys are only supported on ResinOS 2.0.3+\n\nExamples:\n\n $ resin os configure ../path/rpi.img 7cf02a6\n $ resin os configure ../path/rpi.img 7cf02a6 <existingDeviceKey>' ,
2017-03-22 09:46:06 +00:00
permission : 'user' ,
options : [
2017-06-14 21:51:56 +00:00
commandOptions . advancedConfig , {
2017-06-12 08:42:08 +00:00
signature : 'config' ,
2017-06-14 21:23:39 +00:00
description : 'path to the config JSON file, see `resin os build-config`' ,
2017-06-12 08:42:08 +00:00
parameter : 'config'
2017-03-22 09:46:06 +00:00
}
] ,
action : function ( params , options , done ) {
2017-10-13 18:23:19 +00:00
var Promise , fs , generateDeviceConfig , helpers , init , readFileAsync , resin ;
2017-06-14 21:23:39 +00:00
fs = require ( 'fs' ) ;
Promise = require ( 'bluebird' ) ;
readFileAsync = Promise . promisify ( fs . readFile ) ;
2017-03-22 09:46:06 +00:00
resin = require ( 'resin-sdk-preconfigured' ) ;
init = require ( 'resin-device-init' ) ;
helpers = require ( '../utils/helpers' ) ;
2017-10-13 18:23:19 +00:00
generateDeviceConfig = require ( '../utils/config' ) . generateDeviceConfig ;
2017-03-22 09:46:06 +00:00
console . info ( 'Configuring operating system image' ) ;
2017-10-13 18:23:19 +00:00
return resin . models . device . get ( params . uuid ) . then ( function ( device ) {
return Promise [ "try" ] ( function ( ) {
2017-04-19 03:22:43 +00:00
if ( options . config ) {
return readFileAsync ( options . config , 'utf8' ) . then ( JSON . parse ) ;
}
return buildConfig ( params . image , device . device _type , options . advanced ) ;
2017-10-13 18:23:19 +00:00
} ) . then ( function ( answers ) {
return generateDeviceConfig ( device , params . deviceApiKey , answers ) . then ( function ( config ) {
return init . configure ( params . image , device . device _type , config , answers ) ;
} ) ;
} ) ;
2017-04-19 03:22:43 +00:00
} ) . then ( helpers . osProgressHandler ) . nodeify ( done ) ;
2017-03-22 09:46:06 +00:00
}
} ;
2015-09-29 18:52:34 +00:00
2017-06-12 08:42:08 +00:00
INIT _WARNING _MESSAGE = 'Note: Initializing the device may ask for administrative permissions\nbecause we need to access the raw devices directly.' ;
2017-03-22 09:46:06 +00:00
exports . initialize = {
signature : 'os initialize <image>' ,
description : 'initialize an os image' ,
2017-06-12 08:42:08 +00:00
help : "Use this command to initialize a device with previously configured operating system image.\n\n" + INIT _WARNING _MESSAGE + "\n\nExamples:\n\n $ resin os initialize ../path/rpi.img --type 'raspberry-pi'" ,
2017-03-22 09:46:06 +00:00
permission : 'user' ,
options : [
commandOptions . yes , {
signature : 'type' ,
2017-05-12 10:01:37 +00:00
description : 'device type (Check available types with `resin devices supported`)' ,
2017-03-22 09:46:06 +00:00
parameter : 'type' ,
alias : 't' ,
required : 'You have to specify a device type'
2017-06-14 21:51:56 +00:00
} , commandOptions . drive
2017-03-22 09:46:06 +00:00
] ,
action : function ( params , options , done ) {
2017-03-27 09:14:55 +00:00
var Promise , form , helpers , patterns , umountAsync ;
2017-03-22 09:46:06 +00:00
Promise = require ( 'bluebird' ) ;
2017-03-27 09:14:55 +00:00
umountAsync = Promise . promisify ( require ( 'umount' ) . umount ) ;
2017-03-22 09:46:06 +00:00
form = require ( 'resin-cli-form' ) ;
patterns = require ( '../utils/patterns' ) ;
helpers = require ( '../utils/helpers' ) ;
2017-06-12 08:42:08 +00:00
console . info ( "Initializing device\n\n" + INIT _WARNING _MESSAGE ) ;
2017-03-22 09:46:06 +00:00
return helpers . getManifest ( params . image , options . type ) . then ( function ( manifest ) {
var ref ;
return ( ref = manifest . initialization ) != null ? ref . options : void 0 ;
} ) . then ( function ( questions ) {
return form . run ( questions , {
override : {
drive : options . drive
}
} ) ;
} ) . tap ( function ( answers ) {
if ( answers . drive == null ) {
return ;
}
2017-06-09 09:32:28 +00:00
return patterns . confirm ( options . yes , "This will erase " + answers . drive + ". Are you sure?" , "Going to erase " + answers . drive + "." ) [ "return" ] ( answers . drive ) . then ( umountAsync ) ;
2017-03-22 09:46:06 +00:00
} ) . tap ( function ( answers ) {
2017-03-24 09:48:14 +00:00
return helpers . sudo ( [ 'internal' , 'osinit' , params . image , options . type , JSON . stringify ( answers ) ] ) ;
2017-03-22 09:46:06 +00:00
} ) . then ( function ( answers ) {
if ( answers . drive == null ) {
return ;
}
2017-03-27 09:14:55 +00:00
return umountAsync ( answers . drive ) . tap ( function ( ) {
2017-03-22 09:46:06 +00:00
return console . info ( "You can safely remove " + answers . drive + " now" ) ;
} ) ;
} ) . nodeify ( done ) ;
}
} ;