2015-06-08 00:36:07 +00:00
package main
import (
"log"
"os"
2015-06-12 21:34:49 +00:00
"path"
2015-06-08 00:36:07 +00:00
"github.com/codegangsta/cli"
)
// Logger is used to log errors; if nil, the default log.Logger is used.
var Logger * log . Logger
// logger is an helper function to retrieve the available logger
func logger ( ) * log . Logger {
if Logger == nil {
Logger = log . New ( os . Stderr , "" , log . LstdFlags )
}
return Logger
}
func main ( ) {
app := cli . NewApp ( )
app . Name = "lego"
app . Usage = "Let's encrypt client to go!"
app . Version = "0.0.1"
2015-06-12 21:34:49 +00:00
cwd , err := os . Getwd ( )
if err != nil {
logger ( ) . Fatal ( "Could not determine current working directory. Please pass --path." )
}
defaultPath := path . Join ( cwd , ".lego" )
2015-06-08 00:36:07 +00:00
app . Commands = [ ] cli . Command {
{
Name : "run" ,
Usage : "Create and install a certificate" ,
Action : run ,
} ,
{
Name : "auth" ,
Usage : "Create a certificate" ,
Action : func ( c * cli . Context ) {
logger ( ) . Fatal ( "Not implemented" )
} ,
} ,
{
Name : "install" ,
Usage : "Install a certificate" ,
Action : func ( c * cli . Context ) {
logger ( ) . Fatal ( "Not implemented" )
} ,
} ,
{
Name : "revoke" ,
Usage : "Revoke a certificate" ,
Action : func ( c * cli . Context ) {
logger ( ) . Fatal ( "Not implemented" )
} ,
Flags : [ ] cli . Flag {
cli . StringFlag {
Name : "certificate" ,
Usage : "Revoke a specific certificate" ,
} ,
cli . StringFlag {
Name : "key" ,
Usage : "Revoke all certs generated by the provided authorized key." ,
} ,
} ,
} ,
{
Name : "rollback" ,
Usage : "Rollback a certificate" ,
Action : func ( c * cli . Context ) {
logger ( ) . Fatal ( "Not implemented" )
} ,
Flags : [ ] cli . Flag {
cli . IntFlag {
Name : "checkpoints" ,
Usage : "Revert configuration N number of checkpoints" ,
} ,
} ,
} ,
}
app . Flags = [ ] cli . Flag {
cli . StringSliceFlag {
Name : "domains, d" ,
Usage : "Add domains to the process" ,
} ,
cli . StringFlag {
Name : "server, s" ,
2015-07-09 18:18:24 +00:00
Value : "https://acme-staging.api.letsencrypt.org/acme/new-reg" ,
2015-06-08 00:36:07 +00:00
Usage : "CA hostname (and optionally :port). The server certificate must be trusted in order to avoid further modifications to the client." ,
} ,
cli . StringFlag {
Name : "email, m" ,
Usage : "Email used for registration and recovery contact." ,
} ,
cli . IntFlag {
Name : "rsa-key-size, B" ,
Value : 2048 ,
Usage : "Size of the RSA key." ,
} ,
cli . BoolFlag {
Name : "no-confirm" ,
Usage : "Turn off confirmation screens." ,
} ,
cli . BoolFlag {
Name : "agree-tos, e" ,
Usage : "Skip the end user license agreement screen." ,
} ,
cli . StringFlag {
2015-06-12 21:34:49 +00:00
Name : "path" ,
Usage : "Directory to use for storing the data" ,
Value : defaultPath ,
2015-06-08 00:36:07 +00:00
} ,
2015-06-12 22:16:49 +00:00
cli . StringFlag {
Name : "port" ,
Usage : "Challenges will use this port to listen on. Please make sure to forward port 443 to this port on your machine. Otherwise use setcap on the binary" ,
} ,
2015-06-08 00:36:07 +00:00
}
app . Run ( os . Args )
}