mirror of
https://github.com/balena-io/balena-cli.git
synced 2024-12-23 23:42:24 +00:00
4907fccf48
Change-type: major
75 lines
2.4 KiB
CoffeeScript
75 lines
2.4 KiB
CoffeeScript
###
|
|
Copyright 2016-2017 Balena
|
|
|
|
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.wizard =
|
|
signature: 'quickstart [name]'
|
|
description: 'getting started with balena'
|
|
help: '''
|
|
Use this command to run a friendly wizard to get started with balena.
|
|
|
|
The wizard will guide you through:
|
|
|
|
- Create an application.
|
|
- Initialise an SDCard with the balena operating system.
|
|
- Associate an existing project directory with your balena application.
|
|
- Push your project to your devices.
|
|
|
|
Examples:
|
|
|
|
$ balena quickstart
|
|
$ balena quickstart MyApp
|
|
'''
|
|
primary: true
|
|
action: (params, options, done) ->
|
|
balena = require('balena-sdk').fromSharedOptions()
|
|
patterns = require('../utils/patterns')
|
|
{ runCommand } = require('../utils/helpers')
|
|
|
|
balena.auth.isLoggedIn().then (isLoggedIn) ->
|
|
return if isLoggedIn
|
|
console.info('Looks like you\'re not logged in yet!')
|
|
console.info("Let's go through a quick wizard to get you started.\n")
|
|
return runCommand('login')
|
|
.then ->
|
|
return if params.name?
|
|
patterns.selectOrCreateApplication().tap (applicationName) ->
|
|
balena.models.application.has(applicationName).then (hasApplication) ->
|
|
return applicationName if hasApplication
|
|
runCommand("app create #{applicationName}")
|
|
.then (applicationName) ->
|
|
params.name = applicationName
|
|
.then ->
|
|
return runCommand("device init --application #{params.name}")
|
|
.tap(patterns.awaitDevice)
|
|
.then (uuid) ->
|
|
return runCommand("device #{uuid}")
|
|
.then ->
|
|
return balena.models.application.get(params.name)
|
|
.then (application) ->
|
|
console.log """
|
|
Your device is ready to start pushing some code!
|
|
|
|
Check our official documentation for more information:
|
|
|
|
http://balena.io/docs/#/pages/introduction/introduction.md
|
|
|
|
Clone an example or go to an existing application directory and run:
|
|
|
|
$ git remote add balena #{application.git_repository}
|
|
$ git push balena master
|
|
"""
|
|
.nodeify(done)
|