summaryrefslogtreecommitdiff
path: root/delete.go
blob: 157229fdf57c7b828b850517d1df4b4b0e30eca1 (plain)
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
/*
	This will attempt to delete a RR in a DNS zone file.

	Delete("wit.com", "test.wit.com", "1.1.1.1"
*/

package cloudflare

import 	(
	"os"
	"go.wit.com/log"
)

func Delete(zone string, hostname string, value string) (bool, string) {
	log.Info(INFO, "Delete() START", zone, hostname, value)
	key := os.Getenv("CF_API_KEY")
	email := os.Getenv("CF_API_EMAIL")

	if (key == "") {
		log.Log(WARN, "Delete() MISSING environment variable CF_API_KEY")
		return false, ""
	}
	if (email == "") {
		log.Log(WARN, "Delete() MISSING environment variable CF_API_EMAIL")
		return false, ""
	}

	GetZones(key, email)
	var z *ConfigT
	for d, v := range Config {
		log.Log(INFO, "Delete() zone =", d, "value =", v)
		if (zone == d) {
			z = Config[zone]
			log.Log(INFO, "Delete() FOUND ZONE", zone, "ID =", z.ZoneID)
		}
	}
	if (z == nil) {
		log.Log(WARN, "Delete() COULD NOT FIND ZONE", zone)
		return false, ""
	}
	log.Log(INFO, "Delete() FOUND ZONE", z)

	records := GetZonefile(z)
	for i, record := range records.Result {
		if (record.Name == hostname) {
			log.Log(INFO, "Delete() FOUND hostname:", i, record.ID, record.Type, record.Name, record.Content)
		}
		if (record.Content == value) {
			log.Log(INFO, "Delete() FOUND CONTENT:", i, record.ID, record.Type, record.Name, record.Content)
			log.Log(INFO, "Delete() DO THE ACTUAL cloudflare DELETE here")
			result := doCurlDelete(key, email, z.ZoneID, record.ID)
			pretty, _ := FormatJSON(result)
			log.Log(INFO, "Delete() result =", pretty)
			return true, pretty
		}
	}

	log.Log(WARN, "Delete() NEVER FOUND cloudflare value:", value)
	return false, ""
}