This repository has been archived by the owner on Jan 15, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathcheck-blacklisted-fields.go
135 lines (110 loc) · 2.67 KB
/
check-blacklisted-fields.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
122
123
124
125
126
127
128
129
130
131
132
133
134
135
//
// Check for blacklisted fields.
//
// We load a file for each possible field in our input, which means it
// is simple to blacklist regular expressions against particular fields.
//
// For example we have a plugin which looks for hyperlinks in the name
// field. We could replicate that here via:
//
// echo ^https?:// >> ./blacklist.d/name
//
// Simple.
//
//
package main
import (
"bufio"
"fmt"
"io/ioutil"
"os"
"reflect"
"regexp"
"strings"
)
//
// We store blacklisted field-data here
//
var blacklisted map[string][]string
//
// Store the data from the specified file into our blacklisted-map
//
func readData(path string, name string) error {
file, err := os.Open(path)
if err != nil {
return err
}
defer file.Close()
scanner := bufio.NewScanner(file)
for scanner.Scan() {
blacklisted[name] = append(blacklisted[name], scanner.Text())
}
return scanner.Err()
}
//
// Process the given configuration-directory
//
func processDirectory(dir string) {
files, err := ioutil.ReadDir(dir)
if err == nil {
for _, f := range files {
readData(fmt.Sprintf("%s/%s", dir, f.Name()), f.Name())
}
}
}
//
// Register ourselves as a plugin, after setting up our config-files.
//
func init() {
//
// Create a map to hold our per-field lists
//
blacklisted = make(map[string][]string)
//
// Look for a set of field-based config-files.
//
processDirectory("./blacklist.d/")
processDirectory("/etc/blogspam/blacklist.d/")
registerPlugin(BlogspamPlugin{Name: "05-blacklisted-fields.js",
Description: "Look for blacklisted patterns in fields",
Author: "Steve Kemp <[email protected]>",
Test: checkBlacklistedFields})
}
//
// Test the incoming submission against our blacklist.
//
func checkBlacklistedFields(x Submission) (PluginResult, string) {
//
// We've got a list of fields, and a map of blacklists.
//
// Get all the fields of the structure, via reflection
//
s := reflect.ValueOf(&x).Elem()
typeOfT := s.Type()
//
// Iterate over the fields.
//
for i := 0; i < s.NumField(); i++ {
// The specific field
f := s.Field(i)
// The name/value of the field
fieldName := typeOfT.Field(i).Name
fieldVal := fmt.Sprintf("%s", f.Interface())
// Now we have an array of blacklisted items
items := blacklisted[strings.ToLower(fieldName)]
// We'll iterate over them.
for _, val := range items {
//
// Each item is a regular expression.
//
// We make them case-insensitive with the "(?i)" prefix
//
re := regexp.MustCompile("(?i)" + val)
match := re.FindStringSubmatch(fieldVal)
if len(match) > 0 {
return Spam, fmt.Sprintf("Blacklisted value in %s-field", fieldName)
}
}
}
return Undecided, ""
}