| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 | /* * Copyright (c)2019 ZeroTier, Inc. * * Use of this software is governed by the Business Source License included * in the LICENSE.TXT file in the project's root directory. * * Change Date: 2023-01-01 * * On the date above, in accordance with the Business Source License, use * of this software will be governed by version 2.0 of the Apache License. *//****/package cliimport (	"encoding/hex"	"fmt"	"io/ioutil"	"os"	"strings"	"zerotier/pkg/zerotier")// Identity commandfunc Identity(args []string) {	if len(args) > 0 {		switch args[0] {		case "new":			idType := zerotier.IdentityTypeC25519			if len(args) > 1 {				if len(args) > 2 {					Help()					os.Exit(1)				}				switch args[1] {				case "c25519":				case "p384":					idType = zerotier.IdentityTypeP384				default:					Help()					os.Exit(1)				}			}			id, err := zerotier.NewIdentity(idType)			if err != nil {				fmt.Printf("ERROR: internal error generating identity: %s\n", err.Error())				os.Exit(1)			}			fmt.Println(id.PrivateKeyString())			os.Exit(0)		case "getpublic":			if len(args) == 2 {				fmt.Println(readIdentity(args[1]).String())				os.Exit(0)			}		case "validate":			if len(args) == 2 {				if readIdentity(args[1]).LocallyValidate() {					fmt.Println("OK")					os.Exit(0)				}				fmt.Println("FAILED")				os.Exit(1)			}		case "sign", "verify":			if len(args) > 2 {				id := readIdentity(args[1])				msg, err := ioutil.ReadFile(args[2])				if err != nil {					fmt.Printf("ERROR: unable to read input file: %s\n", err.Error())					os.Exit(1)				}				if args[0] == "verify" {					if len(args) == 4 {						sig, err := hex.DecodeString(strings.TrimSpace(args[3]))						if err != nil {							fmt.Println("FAILED")							os.Exit(1)						}						if id.Verify(msg, sig) {							fmt.Println("OK")							os.Exit(0)						}					}					fmt.Println("FAILED")					os.Exit(1)				} else {					sig, err := id.Sign(msg)					if err != nil {						fmt.Printf("ERROR: internal error signing message: %s\n", err.Error())						os.Exit(1)					}					fmt.Println(hex.EncodeToString(sig))					os.Exit(0)				}			}		}	}	Help()	os.Exit(1)}
 |