github.com/mysteriumnetwork/node@v0.0.0-20240516044423-365054f76801/market/access_policy.go (about)

     1  /*
     2   * Copyright (C) 2020 The "MysteriumNetwork/node" Authors.
     3   *
     4   * This program is free software: you can redistribute it and/or modify
     5   * it under the terms of the GNU General Public License as published by
     6   * the Free Software Foundation, either version 3 of the License, or
     7   * (at your option) any later version.
     8   *
     9   * This program is distributed in the hope that it will be useful,
    10   * but WITHOUT ANY WARRANTY; without even the implied warranty of
    11   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    12   * GNU General Public License for more details.
    13   *
    14   * You should have received a copy of the GNU General Public License
    15   * along with this program.  If not, see <http://www.gnu.org/licenses/>.
    16   */
    17  
    18  package market
    19  
    20  const (
    21  	// AccessPolicyTypeIdentity Explicitly allow just specific identities ("0xd1faed693fec75389c3d1e59b863e4835ac6f5d1")
    22  	AccessPolicyTypeIdentity = "identity"
    23  	// AccessPolicyTypeDNSHostname Explicitly allow just specific hostname ("ipinfo.io")
    24  	AccessPolicyTypeDNSHostname = "dns_hostname"
    25  	// AccessPolicyTypeDNSZone Explicitly allow just specific DNS zone ("example.com" matches "example.com" and all of its subdomains)
    26  	AccessPolicyTypeDNSZone = "dns_zone"
    27  )
    28  
    29  // AccessPolicy represents the access controls for proposal
    30  type AccessPolicy struct {
    31  	ID     string `json:"id"`
    32  	Source string `json:"source"`
    33  }
    34  
    35  // AccessPolicyRuleSet represents named list with rules specifying whether access is allowed
    36  type AccessPolicyRuleSet struct {
    37  	ID          string       `json:"id"`
    38  	Title       string       `json:"title"`
    39  	Description string       `json:"description"`
    40  	Allow       []AccessRule `json:"allow"`
    41  }
    42  
    43  // AccessRule represents rule specifying whether connection should be allowed
    44  type AccessRule struct {
    45  	Type  string `json:"type"`
    46  	Value string `json:"value"`
    47  }