Compare commits

...

2 Commits

6 changed files with 72 additions and 25 deletions

2
.gitignore vendored
View File

@ -5,3 +5,5 @@
tmp/
export/
secrets/
.rucksack
.rucksack.toc

View File

@ -40,11 +40,11 @@ shards:
git: https://github.com/kemalcr/kemal.git
version: 1.5.0
kemal-basic-auth:
git: https://github.com/kemalcr/kemal-basic-auth.git
version: 1.0.0
radix:
git: https://github.com/luislavena/radix.git
version: 0.4.1
rucksack:
git: https://github.com/busyloop/rucksack.git
version: 2.0.0

View File

@ -28,3 +28,8 @@ dependencies:
branch: add_exposed_ports
kemal:
github: kemalcr/kemal
rucksack:
github: busyloop/rucksack
scripts:
postinstall: cat .rucksack >> bin/faaso

26
src/commands/new.cr Normal file
View File

@ -0,0 +1,26 @@
require "rucksack"
module Faaso
module Commands
# Creates a new empty funko out of a given runtime
struct New
@@known : Array(String) = {{`find ./runtimes -type d -mindepth 1`.split('\n').reject(&.empty?)}}
def run(options, folder)
if options["-r"].as(String) == "list"
Log.info { "Crystal has some included runtimes:\n" }
@@known.each do |runtime|
Log.info { " * #{Path[runtime].basename}" }
end
Log.info { "\nOr if you have your own, use a folder name" }
return 0
end
end
end
end
end
# Embed runtimes in the binary using rucksack
{% for name in `find ./runtimes -type f`.split('\n') %}
rucksack({{name}})
{% end %}

View File

@ -1,5 +1,6 @@
require "./commands/build.cr"
require "./commands/export.cr"
require "./commands/new.cr"
require "./commands/scale.cr"
require "./commands/secret.cr"
require "./commands/status.cr"

View File

@ -18,17 +18,26 @@ struct LogFormat < Log::StaticFormatter
end
def self.setup(verbosity)
_verbosity = [
Log::Severity::Fatal,
Log::Severity::Error,
Log::Severity::Warn,
Log::Severity::Info,
Log::Severity::Debug,
Log::Severity::Trace,
][[verbosity, 5].min]
Colorize.on_tty_only!
if verbosity < 3
_verbosity = [
Log::Severity::Fatal,
Log::Severity::Error,
Log::Severity::Warn,
][[verbosity, 2].min]
Log.setup(
_verbosity,
Log::IOBackend.new(io: STDERR, formatter: LogFormat)
)
end
_verbosity = [Log::Severity::Info,
Log::Severity::Debug,
Log::Severity::Trace,
][[verbosity - 3, 3].min]
Log.setup(
_verbosity,
Log::IOBackend.new(io: STDERR, formatter: LogFormat)
Log::IOBackend.new(io: STDOUT, formatter: LogFormat)
)
end
end
@ -37,19 +46,21 @@ doc = <<-DOC
FaaSO CLI tool.
Usage:
faaso build FOLDER ... [-v=<level>] [-l]
faaso scale FUNKO [SCALE] [-v=<level>] [-l]
faaso status FUNKO [-v=<level>] [-l]
faaso export SOURCE DESTINATION [-v=<level>]
faaso secret [-d|-a] FUNKO SECRET [-v=<level>] [-l]
faaso build FOLDER ... [-v <level>] [-l]
faaso export SOURCE DESTINATION [-v <level>]
faaso new -r runtime FOLDER [-v <level>]
faaso scale FUNKO [SCALE] [-v <level>] [-l]
faaso secret (-d|-a) FUNKO SECRET [-v <level>] [-l]
faaso status FUNKO [-v <level>] [-l]
faaso version
Options:
-l --local Run commands locally instead of against a FaaSO server.
-h --help Show this screen.
-d --delete Delete
-a --add Add
--version Show version.
-v=level Control the logging verbosity, 0 to 5 [default: 3]
-d --delete Delete
-h --help Show this screen
-l --local Run commands locally instead of against a FaaSO server
-r runtime Runtime for the new funko (use -r list for examples)
-v level Control the logging verbosity, 0 to 5 [default: 3]
DOC
ans = Docopt.docopt(doc, ARGV)
@ -61,10 +72,12 @@ when .fetch("build", false)
Faaso::Commands::Build.new.run(ans, ans["FOLDER"].as(Array(String)))
when .fetch("export", false)
Faaso::Commands::Export.new.run(ans, ans["SOURCE"].as(String), ans["DESTINATION"].as(String))
when .fetch("new", false)
Faaso::Commands::New.new.run(ans, ans["FOLDER"].as(Array(String))[0])
when .fetch("scale", false)
Faaso::Commands::Scale.new.run(ans, ans["FUNKO"].as(String), ans["SCALE"])
when .fetch("status", false)
Faaso::Commands::Status.new.run(ans, ans["FUNKO"].as(String))
when .fetch("secret", false)
Faaso::Commands::Secret.new.run(ans, ans["FUNKO"].as(String), ans["SECRET"].as(String))
when .fetch("status", false)
Faaso::Commands::Status.new.run(ans, ans["FUNKO"].as(String))
end