123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 |
- package teamnet
- import (
- "fmt"
- "net"
- "net/url"
- "time"
- "github.com/google/uuid"
- "github.com/pkg/errors"
- "github.com/urfave/cli/v2"
- )
- var (
- filterDeleted = cli.BoolFlag{
- Name: "filter-is-deleted",
- Usage: "If false (default), only show non-deleted routes. If true, only show deleted routes.",
- }
- filterTunnelID = cli.StringFlag{
- Name: "filter-tunnel-id",
- Usage: "Show only routes with the given tunnel ID.",
- }
- filterSubset = cli.StringFlag{
- Name: "filter-network-is-subset-of",
- Aliases: []string{"nsub"},
- Usage: "Show only routes whose network is a subset of the given network.",
- }
- filterSuperset = cli.StringFlag{
- Name: "filter-network-is-superset-of",
- Aliases: []string{"nsup"},
- Usage: "Show only routes whose network is a superset of the given network.",
- }
- filterComment = cli.StringFlag{
- Name: "filter-comment-is",
- Usage: "Show only routes with this comment.",
- }
- // Flags contains all filter flags.
- FilterFlags = []cli.Flag{
- &filterDeleted,
- &filterTunnelID,
- &filterSubset,
- &filterSuperset,
- &filterComment,
- }
- )
- // Filter which routes get queried.
- type Filter struct {
- queryParams url.Values
- }
- // NewFromCLI parses CLI flags to discover which filters should get applied.
- func NewFromCLI(c *cli.Context) (*Filter, error) {
- f := &Filter{
- queryParams: url.Values{},
- }
- // Set deletion filter
- if flag := filterDeleted.Name; c.IsSet(flag) && c.Bool(flag) {
- f.deleted()
- } else {
- f.notDeleted()
- }
- if subset, err := cidrFromFlag(c, filterSubset); err != nil {
- return nil, err
- } else if subset != nil {
- f.networkIsSupersetOf(*subset)
- }
- if superset, err := cidrFromFlag(c, filterSuperset); err != nil {
- return nil, err
- } else if superset != nil {
- f.networkIsSupersetOf(*superset)
- }
- if comment := c.String(filterComment.Name); comment != "" {
- f.commentIs(comment)
- }
- if tunnelID := c.String(filterTunnelID.Name); tunnelID != "" {
- u, err := uuid.Parse(tunnelID)
- if err != nil {
- return nil, errors.Wrap(err, "Couldn't parse UUID from --filter-tunnel-id")
- }
- f.tunnelID(u)
- }
- return f, nil
- }
- // Parses a CIDR from the flag. If the flag was unset, returns (nil, nil).
- func cidrFromFlag(c *cli.Context, flag cli.StringFlag) (*net.IPNet, error) {
- if !c.IsSet(flag.Name) {
- return nil, nil
- }
- _, subset, err := net.ParseCIDR(c.String(flag.Name))
- if err != nil {
- return nil, err
- } else if subset == nil {
- return nil, fmt.Errorf("Invalid CIDR supplied for %s", flag.Name)
- }
- return subset, nil
- }
- func (f *Filter) commentIs(comment string) {
- f.queryParams.Set("comment", comment)
- }
- func (f *Filter) notDeleted() {
- f.queryParams.Set("is_deleted", "false")
- }
- func (f *Filter) deleted() {
- f.queryParams.Set("is_deleted", "true")
- }
- func (f *Filter) networkIsSubsetOf(superset net.IPNet) {
- f.queryParams.Set("network_subset", superset.String())
- }
- func (f *Filter) networkIsSupersetOf(subset net.IPNet) {
- f.queryParams.Set("network_superset", subset.String())
- }
- func (f *Filter) existedAt(existedAt time.Time) {
- f.queryParams.Set("existed_at", existedAt.Format(time.RFC3339))
- }
- func (f *Filter) tunnelID(id uuid.UUID) {
- f.queryParams.Set("tunnel_id", id.String())
- }
- func (f Filter) Encode() string {
- return f.queryParams.Encode()
- }
|