// This file is part of the happyDomain (R) project. // Copyright (c) 2020-2024 happyDomain // Authors: David Dernoncourt, et al. // // This program is offered under a commercial and under the AGPL license. // For commercial licensing, contact us at . // // For AGPL licensing: // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU Affero General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Affero General Public License for more details. // // You should have received a copy of the GNU Affero General Public License // along with this program. If not, see . package providers // import "git.happydns.org/happyDomain/providers" import ( "github.com/StackExchange/dnscontrol/v4/providers" _ "github.com/StackExchange/dnscontrol/v4/providers/mythicbeasts" "git.happydns.org/happyDomain/model" ) type MythicBeastsAPI struct { KeyID string `json:"keyID,omitempty" happydomain:"label=API key ID,placeholder=xxxxxxxx,required,description=Your API key ID."` Secret string `json:"secret,omitempty" happydomain:"label=Secret,placeholder=xxxxxxxx,required,description=Your API secret."` } func (s *MythicBeastsAPI) NewDNSServiceProvider() (providers.DNSServiceProvider, error) { config := map[string]string{ "keyID": s.KeyID, "secret": s.Secret, } return providers.CreateDNSProvider(s.DNSControlName(), config, nil) } func (s *MythicBeastsAPI) DNSControlName() string { return "MYTHICBEASTS" } func init() { RegisterProvider(func() happydns.Provider { return &MythicBeastsAPI{} }, ProviderInfos{ Name: "Mythic Beasts", Description: "UK-based internet infrastructure company specializing in domain registration, web hosting, and virtual & dedicated servers.", }) }