123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- package cli
- import (
- "errors"
- "fmt"
- "io"
- "net/http"
- "strings"
- )
- type RmCmd struct {
- Token string `short:"t" help:"Bearer token (SHORTY_TOKEN)" default:"${token}"`
- URL string `short:"u" help:"Shorty URL (SHORTY_URL)" default:"${url}"`
- Path string `arg:"" help:"Redirect path"`
- }
- func (c *RmCmd) Run(ctx *Context) error {
- url := strings.Join([]string{c.URL, c.Path}, "")
- req, err := http.NewRequest(http.MethodDelete, url, nil)
- if err != nil {
- return err
- }
- if c.Token != "" {
- req.Header.Add("authorization", fmt.Sprintf("bearer %s", c.Token))
- }
- res, err := http.DefaultClient.Do(req)
- if err != nil {
- return err
- }
- if res.StatusCode != http.StatusOK {
- body, err := io.ReadAll(res.Body)
- if err != nil {
- return err
- }
- if len(body) > 0 {
- return errors.New(string(body))
- }
- return errors.New(res.Status)
- }
- return nil
- }
- func (c *RmCmd) Validate() error {
- if len(c.Path) < 1 || c.Path[0] != '/' {
- return errors.New("invalid <path>")
- }
- return nil
- }
|