Resolve key issue
continuous-integration/drone/push Build is passing Details
continuous-integration/drone/tag Build is passing Details

This commit is contained in:
Tyler 2021-03-27 00:07:32 -04:00
parent e2da267c47
commit 68b03407e7
4 changed files with 107 additions and 100 deletions

View File

@ -10,14 +10,14 @@ steps:
path: /build
commands:
- mkdir -p /build
- GOOS=linux GOARCH=386 go build -ldflags="-X 'cmd.Key=$API_KEY'" -o /build/pastee_linux_i386
- GOOS=linux GOARCH=amd64 go build -ldflags="-X 'cmd.Key=$API_KEY'" -o /build/pastee_linux_amd64
- GOOS=linux GOARCH=arm GOARM=7 go build -ldflags="-X 'cmd.Key=$API_KEY'" -o /build/pastee_linux_armv7
- GOOS=linux GOARCH=arm64 go build -ldflags="-X 'cmd.Key=$API_KEY'" -o /build/pastee_linux_arm64
- GOOS=windows GOARCH=386 go build -ldflags="-X 'cmd.Key=$API_KEY'" -o /build/pastee_windows_i386.exe
- GOOS=windows GOARCH=amd64 go build -ldflags="-X 'cmd.Key=$API_KEY'" -o /build/pastee_windows_amd64.exe
- GOOS=darwin GOARCH=arm64 go build -ldflags="-X 'cmd.Key=$API_KEY'" -o /build/pastee_macos_arm64
- GOOS=darwin GOARCH=amd64 go build -ldflags="-X 'cmd.Key=$API_KEY'" -o /build/pastee_macos_amd64
- GOOS=linux GOARCH=386 go build -ldflags="-X 'paste.ee/cli/cmd.Key=$API_KEY'" -o /build/pastee_linux_i386
- GOOS=linux GOARCH=amd64 go build -ldflags="-X 'paste.ee/cli/cmd.Key=$API_KEY'" -o /build/pastee_linux_amd64
- GOOS=linux GOARCH=arm GOARM=7 go build -ldflags="-X 'paste.ee/cli/cmd.Key=$API_KEY'" -o /build/pastee_linux_armv7
- GOOS=linux GOARCH=arm64 go build -ldflags="-X 'paste.ee/cli/cmd.Key=$API_KEY'" -o /build/pastee_linux_arm64
- GOOS=windows GOARCH=386 go build -ldflags="-X 'paste.ee/cli/cmd.Key=$API_KEY'" -o /build/pastee_windows_i386.exe
- GOOS=windows GOARCH=amd64 go build -ldflags="-X 'paste.ee/cli/cmd.Key=$API_KEY'" -o /build/pastee_windows_amd64.exe
- GOOS=darwin GOARCH=arm64 go build -ldflags="-X 'paste.ee/cli/cmd.Key=$API_KEY'" -o /build/pastee_macos_arm64
- GOOS=darwin GOARCH=amd64 go build -ldflags="-X 'paste.ee/cli/cmd.Key=$API_KEY'" -o /build/pastee_macos_amd64
environment:
API_KEY:
from_secret: api_key

View File

@ -1,72 +1,66 @@
package cmd
import (
"fmt"
"github.com/mitchellh/go-homedir"
"github.com/spf13/cobra"
"github.com/spf13/viper"
"os"
)
const (
Key = ""
"fmt"
"github.com/mitchellh/go-homedir"
"github.com/spf13/cobra"
"github.com/spf13/viper"
"os"
)
var rootCmd = &cobra.Command{
Use: "pastee",
Short: "A quick and easy to use Command-Line Paste Interface",
Long: `Fast, ad-free, secure, and feature filled! Submit pastes to Paste.ee from any operating system, anywhere!`,
Args: cobra.ArbitraryArgs,
Run: uploadCommandHandler,
Use: "pastee",
Short: "A quick and easy to use Command-Line Paste Interface",
Long: `Fast, ad-free, secure, and feature filled! Submit pastes to Paste.ee from any operating system, anywhere!`,
Args: cobra.ArbitraryArgs,
Run: uploadCommandHandler,
}
var (
cfgFile string
cfgFile string
Key = ""
)
func Execute() {
if err := rootCmd.Execute(); err != nil {
fmt.Fprintln(os.Stderr, err)
os.Exit(1)
}
if err := rootCmd.Execute(); err != nil {
fmt.Fprintln(os.Stderr, err)
os.Exit(1)
}
}
func init() {
cobra.OnInitialize(initConfig)
cobra.OnInitialize(initConfig)
rootCmd.PersistentFlags().BoolP("encrypt", "e", true, "Encrypt uploaded contents")
rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.cobra.yaml)")
rootCmd.PersistentFlags().Bool("viper", true, "use Viper for configuration")
viper.BindPFlag("author", rootCmd.PersistentFlags().Lookup("author"))
viper.BindPFlag("useViper", rootCmd.PersistentFlags().Lookup("viper"))
viper.SetDefault("author", "NAME HERE <EMAIL ADDRESS>")
viper.SetDefault("license", "apache")
viper.SetDefault("apiKey", Key)
rootCmd.PersistentFlags().BoolP("encrypt", "e", false, "Encrypt uploaded contents")
rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.cobra.yaml)")
rootCmd.PersistentFlags().Bool("viper", true, "use Viper for configuration")
viper.BindPFlag("encrypt", rootCmd.PersistentFlags().Lookup("encrypt"))
viper.SetDefault("apiKey", Key)
rootCmd.AddCommand(loginCmd)
rootCmd.AddCommand(loginCmd)
}
func initConfig() {
if cfgFile != "" {
// Use config file from the flag.
viper.SetConfigFile(cfgFile)
} else {
home, err := homedir.Dir()
cobra.CheckErr(err)
if cfgFile != "" {
// Use config file from the flag.
viper.SetConfigFile(cfgFile)
} else {
home, err := homedir.Dir()
cobra.CheckErr(err)
viper.SetConfigName(".pastee")
viper.SetConfigType("yaml")
viper.AddConfigPath(home)
viper.SetConfigName(".pastee")
viper.SetConfigType("yaml")
viper.AddConfigPath(home)
if err := viper.ReadInConfig(); err != nil {
if _, ok := err.(viper.ConfigFileNotFoundError); ok {
if err := viper.ReadInConfig(); err != nil {
if _, ok := err.(viper.ConfigFileNotFoundError); ok {
} else {
fmt.Println("Error: Configuration file was unable to be read -", err)
os.Exit(1)
}
}
}
} else {
fmt.Println("Error: Configuration file was unable to be read -", err)
os.Exit(1)
}
}
}
viper.AutomaticEnv()
}
viper.AutomaticEnv()
}

View File

@ -1,64 +1,77 @@
package cmd
import (
"github.com/spf13/cobra"
"github.com/spf13/viper"
"io/ioutil"
"math"
"os"
"paste.ee/go"
"path"
"errors"
"github.com/spf13/cobra"
"github.com/spf13/viper"
"io/ioutil"
"math"
"os"
"paste.ee/go"
"path"
)
// uploadCommandHandler handles the root command from Cobra
// The program takes two inputs, an arg list (files), or stdin.
// If args is empty, stdin will be used.
func uploadCommandHandler(cmd *cobra.Command, args []string) {
client := pastee.New(viper.GetString("apiKey"))
client := pastee.New(viper.GetString("apiKey"))
paste := &pastee.Paste{}
paste := &pastee.Paste{
Encrypted: viper.GetBool("encrypt"),
}
if len(args) > 0 && args[0] != "-" {
paste.Sections = make([]*pastee.Section, int(math.Min(float64(len(args)), 10)))
if len(args) > 0 && args[0] != "-" {
paste.Sections = make([]*pastee.Section, int(math.Min(float64(len(args)), 10)))
// File list
for i, filePath := range args {
if i >= 10 {
break
}
// File list
for i, filePath := range args {
if i >= 10 {
break
}
bytes, err := ioutil.ReadFile(filePath)
bytes, err := ioutil.ReadFile(filePath)
if err != nil {
cmd.PrintErrln("Unable to read file:", err)
os.Exit(1)
}
if err != nil {
cmd.PrintErrln("Unable to read file:", err)
os.Exit(1)
}
paste.Sections[i] = &pastee.Section{
Name: path.Base(filePath),
Contents: string(bytes),
}
}
} else {
// Stdin
stdinContents, err := ioutil.ReadAll(os.Stdin)
paste.Sections[i] = &pastee.Section{
Name: path.Base(filePath),
Contents: string(bytes),
}
}
} else {
// Stdin
stdinContents, err := ioutil.ReadAll(os.Stdin)
if err != nil {
cmd.PrintErrln("Error reading from stdin:", err)
os.Exit(1)
}
if err != nil {
cmd.PrintErrln("Error reading from stdin:", err)
os.Exit(1)
}
paste.Sections = []*pastee.Section{
{Contents: string(stdinContents)},
}
}
paste.Sections = []*pastee.Section{
{Contents: string(stdinContents)},
}
}
res, err := client.Submit(paste)
res, err := client.Submit(paste)
if err != nil {
cmd.PrintErrln("Unable to upload paste:", err)
os.Exit(1)
}
if err != nil || res.Link == "" {
if err == nil {
err = errors.New("unknown error")
}
cmd.Println(res.Link)
}
cmd.PrintErrln("Unable to upload paste:", err)
os.Exit(1)
}
link := res.Link
if res.Key != "" {
link += "#" + res.Key
}
cmd.Println(link)
}

BIN
pastee

Binary file not shown.