123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153 |
- package access
- import (
- "encoding/json"
- "errors"
- "net"
- "os"
- "path/filepath"
- )
- func (s *AccessRule) AllowIpAccess(ipaddr string) bool {
- if s.IsBlacklisted(ipaddr) {
- return false
- }
- return s.IsWhitelisted(ipaddr)
- }
- func (s *AccessRule) AllowConnectionAccess(conn net.Conn) bool {
- if addr, ok := conn.RemoteAddr().(*net.TCPAddr); ok {
- return s.AllowIpAccess(addr.IP.String())
- }
- return true
- }
- func (s *AccessRule) ToggleBlacklist(enabled bool) {
- s.BlacklistEnabled = enabled
- s.SaveChanges()
- }
- func (s *AccessRule) ToggleWhitelist(enabled bool) {
- s.WhitelistEnabled = enabled
- s.SaveChanges()
- }
- func (s *AccessRule) IsBlacklisted(ipAddr string) bool {
- if !s.BlacklistEnabled {
-
- return false
- }
- if ipAddr == "" {
-
- return false
- }
- countryCode, err := s.parent.Options.GeoDB.ResolveCountryCodeFromIP(ipAddr)
- if err != nil {
- return false
- }
- if s.IsCountryCodeBlacklisted(countryCode.CountryIsoCode) {
- return true
- }
- if s.IsIPBlacklisted(ipAddr) {
- return true
- }
- return false
- }
- func (s *AccessRule) IsWhitelisted(ipAddr string) bool {
- if !s.WhitelistEnabled {
-
- return true
- }
- if ipAddr == "" {
-
- return true
- }
- countryCode, err := s.parent.Options.GeoDB.ResolveCountryCodeFromIP(ipAddr)
- if err != nil {
- return true
- }
- if s.IsCountryCodeWhitelisted(countryCode.CountryIsoCode) {
- return true
- }
- if s.IsIPWhitelisted(ipAddr) {
- return true
- }
- return false
- }
- func (s *AccessRule) SaveChanges() error {
- if s.parent == nil {
- return errors.New("save failed: access rule detached from controller")
- }
- saveTarget := filepath.Join(s.parent.Options.ConfigFolder, s.ID+".json")
- js, err := json.MarshalIndent(s, "", " ")
- if err != nil {
- return err
- }
- err = os.WriteFile(saveTarget, js, 0775)
- return err
- }
- func (s *AccessRule) DeleteConfigFile() error {
- saveTarget := filepath.Join(s.parent.Options.ConfigFolder, s.ID+".json")
- return os.Remove(saveTarget)
- }
- func (c *Controller) DeleteAccessRuleByID(accessRuleID string) error {
- targetAccessRule, err := c.GetAccessRuleByID(accessRuleID)
- if err != nil {
- return err
- }
-
- err = targetAccessRule.DeleteConfigFile()
- if err != nil {
- return err
- }
-
- c.ProxyAccessRule.Delete(accessRuleID)
- return nil
- }
- func deepCopy(valueList map[string]string) map[string]string {
- result := map[string]string{}
- js, _ := json.Marshal(valueList)
- json.Unmarshal(js, &result)
- return result
- }
|