// Copyright 2012 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// Crypt is a simple password-based encryption program,
// demonstrating how to use github.com/mattermost/rsc/crypt.
//
// Encrypt input to output using password:
// crypt password output
//
// Decrypt input to output using password:
// crypt -d password output
//
// Yes, the password is a command-line argument. This is a demo of the
// github.com/mattermost/rsc/crypt package. It's not intended for real use.
//
package main
import (
"encoding/base64"
"fmt"
"io/ioutil"
"os"
"strings"
"github.com/mattermost/rsc/crypt"
)
func main() {
args := os.Args[1:]
encrypt := true
if len(args) >= 1 && args[0] == "-d" {
encrypt = false
args = args[1:]
}
if len(args) != 1 || strings.HasPrefix(args[0], "-") {
fmt.Fprintf(os.Stderr, "usage: crypt [-d] password < input > output\n")
os.Exit(2)
}
password := args[0]
data, err := ioutil.ReadAll(os.Stdin)
if err != nil {
fmt.Fprintf(os.Stderr, "reading stdin: %v\n", err)
os.Exit(1)
}
if encrypt {
pkt, err := crypt.Encrypt(password, data)
if err != nil {
fmt.Fprintf(os.Stderr, "%v\n", err)
os.Exit(1)
}
str := base64.StdEncoding.EncodeToString(pkt)
for len(str) > 60 {
fmt.Printf("%s\n", str[:60])
str = str[60:]
}
fmt.Printf("%s\n", str)
} else {
pkt, err := base64.StdEncoding.DecodeString(strings.Map(noSpace, string(data)))
if err != nil {
fmt.Fprintf(os.Stderr, "decoding input: %v\n", err)
os.Exit(1)
}
dec, err := crypt.Decrypt(password, pkt)
if err != nil {
fmt.Fprintf(os.Stderr, "%v\n", err)
os.Exit(1)
}
os.Stdout.Write(dec)
}
}
func noSpace(r rune) rune {
if r == ' ' || r == '\t' || r == '\n' {
return -1
}
return r
}