forked from spf-tools/spf-tools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmkblocks.sh
executable file
·114 lines (100 loc) · 2.96 KB
/
mkblocks.sh
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
#!/bin/sh
##############################################################################
#
# Copyright 2015 spf-tools team (see AUTHORS)
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
##############################################################################
#
# Usage: ./mkblocks.sh <domain> <prefix> <policy>
# E.g.: ./mkblocks.sh microsoft.com _spf
for cmd in awk grep sed cut
do
type $cmd >/dev/null || exit 1
done
# Default values
domain=${DOMAIN:-"energystan.com"}
prefix="spf"
policy="~all"
delim="^"
header="v=spf1"
length=257
usage() {
cat <<-EOF
Usage: mkblocks.sh [OPTION]... [DOMAIN]
Make blocks out of decomposed SPF records.
Available options:
-h HEADER set SPF header
-l LENGTH set desired packet length
-p PREFIX set SPF prefix
-o POLICY set default SPF policy
-d DELIM set delimiter of output
Default values:
HEADER = $header
LENGTH = $length
PREFIX = $prefix
POLICY = $policy
DELIM = $delim
EOF
exit 1
}
while getopts "h:l:p:o:d:-" opt; do
case $opt in
h) test -n "$OPTARG" && header=$OPTARG;;
l) test -n "$OPTARG" && length=$OPTARG;;
p) test -n "$OPTARG" && prefix=$OPTARG;;
o) test -n "$OPTARG" && policy=$OPTARG;;
d) test -n "$OPTARG" && delim=$OPTARG;;
*) usage;;
esac
done
shift $((OPTIND-1))
# For backward compatibility the options are also positional
domain=${1:-"$domain"}
prefix=${2:-"$prefix"}
policy=${3:-"$policy"}
# One-char placeholder substitued for number later
MYX=#
incldomain="${prefix}${MYX}.$domain"
footer="include:$incldomain $policy"
counter=$((1))
mysed() {
sed "s/$MYX/$1/"
}
myout() {
local mycounter=${3:-'1'}
rrlabel=$1
if [ $mycounter -eq 1 ]; then
#first resource label of chain is bare domain
rrlabel="$domain"
fi
mystart=$(echo $rrlabel | mysed $((mycounter-1)))
myrest=$(echo $2 | mysed $((mycounter)))
echo ${mystart}${delim}\"$header $myrest\"
}
while
read block
do
blocksprev=$blocks
test -n "$blocks" && blocks="${blocks} ${block}" || blocks=$block
compare="$header $blocks $footer"
test $(echo $compare | wc -c) -ge $length && {
myout $incldomain "${blocksprev} ${footer}" $counter
blocks=$block
counter=$((counter+1))
test $counter -gt 10 && { echo "Too many DNS look-ups!" 1>&2; exit 1; }
}
done
# Corner case for last entry not containing any include
test -n "$blocks" && myout $incldomain "$blocks $policy" $counter