This repository has been archived by the owner on Oct 27, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 21
/
Copy pathlocks.go
121 lines (99 loc) · 2.8 KB
/
locks.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
package main
import (
"sync"
"time"
"github.com/Sirupsen/logrus"
)
var (
certDomainsObtaining = make(map[string]bool)
certDomainsObtainingMutex = &sync.Mutex{}
skipDomainMap = make(map[string]time.Time)
skipDomainMapMutex = &sync.Mutex{}
)
/*
Check for all of domains doesn't in obtaining process. If ok - lock all domains and return true.
If any of domains already in obtaining process - return false and lock nothing.
*/
func obtainDomainsLock(domains []string) bool {
certDomainsObtainingMutex.Lock()
defer certDomainsObtainingMutex.Unlock()
var alreadyObtaining bool
for _, domain := range domains {
alreadyObtaining = certDomainsObtaining[domain]
if alreadyObtaining {
return false
}
}
for _, domain := range domains {
certDomainsObtaining[domain] = true
}
return true
}
/*
Unlock all domains from obtaining lock without any check
*/
func obtainDomainsUnlock(domains []string) {
certDomainsObtainingMutex.Lock()
defer certDomainsObtainingMutex.Unlock()
if logrus.GetLevel() >= logrus.DebugLevel {
for _, domain := range domains {
if !certDomainsObtaining[domain] {
logrus.Debugf("Release from obtain cert not locked domain: %v", domain)
}
}
}
for _, domain := range domains {
delete(certDomainsObtaining, domain)
}
}
func skipDomainsAdd(domains []string) {
if *blockBadDomainDuration == 0 {
logrus.Debugf("Skip add domains to bad list, becouse bad list is disabled: '%v'", domains)
return
}
skipDomainMapMutex.Lock()
defer skipDomainMapMutex.Unlock()
deadline := time.Now().Add(*blockBadDomainDuration)
for _, domain := range domains {
skipDomainMap[domain] = deadline
}
logrus.Debugf("Add domains to block '%v', dedline: '%v'", domains, deadline)
}
// return true if some of domains is bad domain
func skipDomainsCheck(domains []string) bool {
skipDomainMapMutex.Lock()
defer skipDomainMapMutex.Unlock()
now := time.Now()
for _, domain := range domains {
if deadline, ok := skipDomainMap[domain]; ok && now.Before(deadline) {
return true
}
}
return false
}
func skipDomainsFlush() {
logrus.Debug("Flush skip domains set")
skipDomainMapMutex.Lock()
skipDomainMap = make(map[string]time.Time)
skipDomainMapMutex.Unlock()
}
func skipDomainsStartCleaner() {
if *blockBadDomainDuration == 0 {
logrus.Debugf("Bad domain cleaner doesn't start becouse block domains is disabled")
return
}
skipDomainMapMutex.Lock()
defer skipDomainMapMutex.Unlock()
now := time.Now()
toClean := make([]string, 0, len(skipDomainMap))
for domain, deadline := range skipDomainMap {
if deadline.Before(now) {
toClean = append(toClean, domain)
}
}
for _, domain := range toClean {
delete(skipDomainMap, domain)
}
logrus.Debugf("Clean blocked domains list, remove domains: '%v'", toClean)
time.AfterFunc(*blockBadDomainDuration, skipDomainsStartCleaner)
}