forked from linickx/rsdns
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrsdns-mx.sh
executable file
·140 lines (114 loc) · 2.31 KB
/
rsdns-mx.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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
#!/bin/bash
#
# rsdns-mx.sh - Used to create/delete MX records hosted on rackspace cloud dns
#
# config file for variables.
if [ -e ~/.rsdns_config ]
then
. ~/.rsdns_config
fi
# load up our auth & funct library
if [ -n "$RSPATH" ]
then
. $RSPATH/lib/auth.sh
. $RSPATH/lib/func.sh
else
. lib/auth.sh
. lib/func.sh
fi
#prints out the usage information on error or request.
function usage () {
printf "\n"
printf "rsdns mx -u username -a apiKey -d domain -n name -D data -p priority -t TTL\n"
printf "\t-k Use London/UK Servers.\n"
printf "\t-x Delete record.\n"
printf "\t-h Show this.\n"
printf "\n"
}
function create_mx () {
# { "id" : "MX-123", "priority" : 10, "type" : "MX", "name" : "example.foo.com", "data" : "mail.example.foo.com", "ttl" : 3600 }
if [ -z $DATA ]
then
usage
exit 1
fi
check_domain
if [ $FOUND -eq 1 ]
then
RSPOST=`echo '{"records":[{ "priority" : '$PRIORITY',"type" : "MX", "name" : "'$NAME'", "data" : "'$DATA'", "ttl" : '$TTL' }]}'`
create_record
fi
}
function delete_mx() {
get_domain $NAME
RECORDTYPE="MX"
delete_record
}
#prints words for master rsdns script output
function words () {
printf "Manage mail exchange (MX) records \n"
}
#Get options from the command line.
while getopts "u:a:c:d:n:D:p::hkqxw" option
do
case $option in
u ) RSUSER=$OPTARG ;;
a ) RSAPIKEY=$OPTARG ;;
c ) USERID=$OPTARG ;;
d ) DOMAIN=$OPTARG ;;
n ) NAME=$OPTARG ;;
D ) DATA=$OPTARG ;;
p ) PRIORITY=$OPTARG ;;
t ) TTL=$OPTARG ;;
h ) usage;exit 0 ;;
q ) QUIET=1 ;;
k ) UKAUTH=1 ;;
x ) DEL=1 ;;
w ) words;exit 0 ;;
esac
done
#Check for enough variables, print usage if not enough.
if [ $# -lt 3 ]
then
usage
exit 1
fi
if [ -z $PRIORITY ]
then
PRIORITY="10"
fi
if [ -z $NAME ]
then
usage
exit 1
fi
if [ -z $DOMAIN ]
then
usage
exit 1
fi
#All actions require authentication, get it done first.
#If the authentication works this will return $TOKEN and $MGMTSVR for use by everything else.
get_auth $RSUSER $RSAPIKEY
if test -z $TOKEN
then
if [[ $QUIET -eq 0 ]]; then
echo Auth Token does not exist.
fi
exit 98
fi
if test -z $MGMTSVR
then
if [[ $QUIET -eq 0 ]]; then
echo Management Server does not exist.
fi
exit 98
fi
if [ -n "$DEL" ]
then
delete_mx
else
create_mx
fi
#done
exit 0