summaryrefslogtreecommitdiff
path: root/delete.go
blob: aa59105f938c4e27c942b7a6f07a37d84101c96d (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
61
62
63
64
/*
	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 {
	// CFdialog.emailNode.SetText(os.Getenv("CF_API_EMAIL"))
	// CFdialog.apiNode.SetText(os.Getenv("CF_API_KEY"))

	log.Info("cloudflare.Delete() START", zone, hostname, value)
	key := os.Getenv("CF_API_KEY")
	email := os.Getenv("CF_API_EMAIL")

	if (key == "") {
		log.Warn("cloudflare.Delete() MISSING environment variable CF_API_KEY")
		return false
	}
	if (email == "") {
		log.Warn("cloudflare.Delete() MISSING environment variable CF_API_EMAIL")
		return false
	}

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

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

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