67 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package cli
 | |
| 
 | |
| import (
 | |
| 	"errors"
 | |
| 	"fmt"
 | |
| 
 | |
| 	"gopkg.in/urfave/cli.v2"
 | |
| 
 | |
| 	"github.com/filecoin-project/lotus/api/apistruct"
 | |
| )
 | |
| 
 | |
| var authCmd = &cli.Command{
 | |
| 	Name:  "auth",
 | |
| 	Usage: "Manage RPC permissions",
 | |
| 	Subcommands: []*cli.Command{
 | |
| 		authCreateAdminToken,
 | |
| 	},
 | |
| }
 | |
| 
 | |
| var authCreateAdminToken = &cli.Command{
 | |
| 	Name:  "create-token",
 | |
| 	Usage: "Create token",
 | |
| 	Flags: []cli.Flag{
 | |
| 		&cli.StringFlag{
 | |
| 			Name:  "perm",
 | |
| 			Usage: "permission to assign to the token, one of: read, write, sign, admin",
 | |
| 		},
 | |
| 	},
 | |
| 
 | |
| 	Action: func(cctx *cli.Context) error {
 | |
| 		napi, closer, err := GetAPI(cctx)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 		defer closer()
 | |
| 
 | |
| 		ctx := ReqContext(cctx)
 | |
| 
 | |
| 		if !cctx.IsSet("perm") {
 | |
| 			return errors.New("--perm flag not set")
 | |
| 		}
 | |
| 
 | |
| 		perm := cctx.String("perm")
 | |
| 		idx := 0
 | |
| 		for i, p := range apistruct.AllPermissions {
 | |
| 			if perm == p {
 | |
| 				idx = i + 1
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		if idx == 0 {
 | |
| 			return fmt.Errorf("--perm flag has to be one of: %s", apistruct.AllPermissions)
 | |
| 		}
 | |
| 
 | |
| 		// slice on [:idx] so for example: 'sign' gives you [read, write, sign]
 | |
| 		token, err := napi.AuthNew(ctx, apistruct.AllPermissions[:idx])
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 
 | |
| 		// TODO: Log in audit log when it is implemented
 | |
| 
 | |
| 		fmt.Println(string(token))
 | |
| 		return nil
 | |
| 	},
 | |
| }
 |