From 1d75bf7489527925217bd5611ba7910c0ffe077c Mon Sep 17 00:00:00 2001 From: Elizabeth Date: Tue, 9 Apr 2024 18:39:14 -0400 Subject: profiles (#7) Reviewed-on: https://git.hatecomputers.club/hatecomputers/hatecomputers.club/pulls/7 Co-authored-by: Elizabeth Co-committed-by: Elizabeth --- adapters/cloudflare/cloudflare.go | 76 -------------------------- adapters/external_dns.go | 8 --- adapters/external_dns/cloudflare/cloudflare.go | 76 ++++++++++++++++++++++++++ adapters/external_dns/external_dns.go | 8 +++ adapters/files/files_adapter.go | 8 +++ adapters/files/filesystem/filesystem.go | 37 +++++++++++++ 6 files changed, 129 insertions(+), 84 deletions(-) delete mode 100644 adapters/cloudflare/cloudflare.go delete mode 100644 adapters/external_dns.go create mode 100644 adapters/external_dns/cloudflare/cloudflare.go create mode 100644 adapters/external_dns/external_dns.go create mode 100644 adapters/files/files_adapter.go create mode 100644 adapters/files/filesystem/filesystem.go (limited to 'adapters') diff --git a/adapters/cloudflare/cloudflare.go b/adapters/cloudflare/cloudflare.go deleted file mode 100644 index c302037..0000000 --- a/adapters/cloudflare/cloudflare.go +++ /dev/null @@ -1,76 +0,0 @@ -package cloudflare - -import ( - "encoding/json" - "fmt" - "io" - "net/http" - "strings" - - "git.hatecomputers.club/hatecomputers/hatecomputers.club/database" -) - -type CloudflareDNSResponse struct { - Result database.DNSRecord `json:"result"` -} - -type CloudflareExternalDNSAdapter struct { - ZoneId string - APIToken string -} - -func (adapter *CloudflareExternalDNSAdapter) CreateDNSRecord(record *database.DNSRecord) (string, error) { - url := fmt.Sprintf("https://api.cloudflare.com/client/v4/zones/%s/dns_records", adapter.ZoneId) - - reqBody := fmt.Sprintf(`{"type":"%s","name":"%s","content":"%s","ttl":%d,"proxied":false}`, record.Type, record.Name, record.Content, record.TTL) - payload := strings.NewReader(reqBody) - - req, _ := http.NewRequest("POST", url, payload) - - req.Header.Add("Authorization", "Bearer "+adapter.APIToken) - req.Header.Add("Content-Type", "application/json") - - res, err := http.DefaultClient.Do(req) - if err != nil { - return "", err - } - - defer res.Body.Close() - body, _ := io.ReadAll(res.Body) - - if res.StatusCode != 200 { - return "", fmt.Errorf("error creating dns record: %s", body) - } - - var response CloudflareDNSResponse - err = json.Unmarshal(body, &response) - if err != nil { - return "", err - } - - result := &response.Result - - return result.ID, nil -} - -func (adapter *CloudflareExternalDNSAdapter) DeleteDNSRecord(id string) error { - url := fmt.Sprintf("https://api.cloudflare.com/client/v4/zones/%s/dns_records/%s", adapter.ZoneId, id) - - req, _ := http.NewRequest("DELETE", url, nil) - - req.Header.Add("Authorization", "Bearer "+adapter.APIToken) - - res, err := http.DefaultClient.Do(req) - if err != nil { - return err - } - - defer res.Body.Close() - body, _ := io.ReadAll(res.Body) - - if res.StatusCode != 200 { - return fmt.Errorf("error deleting dns record: %s", body) - } - - return nil -} diff --git a/adapters/external_dns.go b/adapters/external_dns.go deleted file mode 100644 index c861283..0000000 --- a/adapters/external_dns.go +++ /dev/null @@ -1,8 +0,0 @@ -package external_dns - -import "git.hatecomputers.club/hatecomputers/hatecomputers.club/database" - -type ExternalDNSAdapter interface { - CreateDNSRecord(record *database.DNSRecord) (string, error) - DeleteDNSRecord(id string) error -} diff --git a/adapters/external_dns/cloudflare/cloudflare.go b/adapters/external_dns/cloudflare/cloudflare.go new file mode 100644 index 0000000..c302037 --- /dev/null +++ b/adapters/external_dns/cloudflare/cloudflare.go @@ -0,0 +1,76 @@ +package cloudflare + +import ( + "encoding/json" + "fmt" + "io" + "net/http" + "strings" + + "git.hatecomputers.club/hatecomputers/hatecomputers.club/database" +) + +type CloudflareDNSResponse struct { + Result database.DNSRecord `json:"result"` +} + +type CloudflareExternalDNSAdapter struct { + ZoneId string + APIToken string +} + +func (adapter *CloudflareExternalDNSAdapter) CreateDNSRecord(record *database.DNSRecord) (string, error) { + url := fmt.Sprintf("https://api.cloudflare.com/client/v4/zones/%s/dns_records", adapter.ZoneId) + + reqBody := fmt.Sprintf(`{"type":"%s","name":"%s","content":"%s","ttl":%d,"proxied":false}`, record.Type, record.Name, record.Content, record.TTL) + payload := strings.NewReader(reqBody) + + req, _ := http.NewRequest("POST", url, payload) + + req.Header.Add("Authorization", "Bearer "+adapter.APIToken) + req.Header.Add("Content-Type", "application/json") + + res, err := http.DefaultClient.Do(req) + if err != nil { + return "", err + } + + defer res.Body.Close() + body, _ := io.ReadAll(res.Body) + + if res.StatusCode != 200 { + return "", fmt.Errorf("error creating dns record: %s", body) + } + + var response CloudflareDNSResponse + err = json.Unmarshal(body, &response) + if err != nil { + return "", err + } + + result := &response.Result + + return result.ID, nil +} + +func (adapter *CloudflareExternalDNSAdapter) DeleteDNSRecord(id string) error { + url := fmt.Sprintf("https://api.cloudflare.com/client/v4/zones/%s/dns_records/%s", adapter.ZoneId, id) + + req, _ := http.NewRequest("DELETE", url, nil) + + req.Header.Add("Authorization", "Bearer "+adapter.APIToken) + + res, err := http.DefaultClient.Do(req) + if err != nil { + return err + } + + defer res.Body.Close() + body, _ := io.ReadAll(res.Body) + + if res.StatusCode != 200 { + return fmt.Errorf("error deleting dns record: %s", body) + } + + return nil +} diff --git a/adapters/external_dns/external_dns.go b/adapters/external_dns/external_dns.go new file mode 100644 index 0000000..c861283 --- /dev/null +++ b/adapters/external_dns/external_dns.go @@ -0,0 +1,8 @@ +package external_dns + +import "git.hatecomputers.club/hatecomputers/hatecomputers.club/database" + +type ExternalDNSAdapter interface { + CreateDNSRecord(record *database.DNSRecord) (string, error) + DeleteDNSRecord(id string) error +} diff --git a/adapters/files/files_adapter.go b/adapters/files/files_adapter.go new file mode 100644 index 0000000..bf3ea5f --- /dev/null +++ b/adapters/files/files_adapter.go @@ -0,0 +1,8 @@ +package files + +import "io" + +type FilesAdapter interface { + CreateFile(path string, content io.Reader) (string, error) + DeleteFile(path string) error +} diff --git a/adapters/files/filesystem/filesystem.go b/adapters/files/filesystem/filesystem.go new file mode 100644 index 0000000..726a588 --- /dev/null +++ b/adapters/files/filesystem/filesystem.go @@ -0,0 +1,37 @@ +package filesystem + +import ( + "io" + "os" + "path/filepath" +) + +type FilesystemAdapter struct { + BasePath string + Permissions os.FileMode +} + +func (f *FilesystemAdapter) CreateFile(path string, content io.Reader) (string, error) { + fullPath := f.BasePath + path + dir := filepath.Dir(fullPath) + if _, err := os.Stat(dir); os.IsNotExist(err) { + os.MkdirAll(dir, f.Permissions) + } + + file, err := os.Create(f.BasePath + path) + if err != nil { + return "", err + } + defer file.Close() + + _, err = io.Copy(file, content) + if err != nil { + return "", err + } + + return path, nil +} + +func (f *FilesystemAdapter) DeleteFile(path string) error { + return os.Remove(f.BasePath + path) +} -- cgit v1.2.3-70-g09d2