2017-03-24 09:48:14 +00:00
|
|
|
###
|
2017-06-14 21:20:15 +00:00
|
|
|
Copyright 2016-2017 Resin.io
|
2017-03-24 09:48:14 +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.
|
|
|
|
###
|
|
|
|
|
|
|
|
# These are internal commands we want to be runnable from the outside
|
|
|
|
# One use-case for this is spawning the minimal operation with root priviledges
|
|
|
|
|
|
|
|
exports.osInit =
|
|
|
|
signature: 'internal osinit <image> <type> <config>'
|
|
|
|
description: 'do actual init of the device with the preconfigured os image'
|
|
|
|
help: '''
|
|
|
|
Don't use this command directly! Use `resin os initialize <image>` instead.
|
|
|
|
'''
|
|
|
|
hidden: true
|
|
|
|
root: true
|
|
|
|
action: (params, options, done) ->
|
|
|
|
Promise = require('bluebird')
|
|
|
|
init = require('resin-device-init')
|
|
|
|
helpers = require('../utils/helpers')
|
|
|
|
|
|
|
|
return Promise.try ->
|
|
|
|
config = JSON.parse(params.config)
|
|
|
|
init.initialize(params.image, params.type, config)
|
|
|
|
.then(helpers.osProgressHandler)
|
|
|
|
.nodeify(done)
|