# Golang CloudFlare® API v4 client [![GoDoc](https://godoc.org/github.com/crackcomm/cloudflare?status.svg)](https://godoc.org/github.com/crackcomm/cloudflare) [![Circle CI](https://img.shields.io/circleci/project/crackcomm/cloudflare.svg)](https://circleci.com/gh/crackcomm/cloudflare) Golang API Client for CloudFlare® API v4. ## Command Line Tool ```sh $ go install github.com/crackcomm/cloudflare/cf $ cf NAME: cf - CloudFlare command line tool USAGE: cf [global options] command [command options] [arguments...] VERSION: 1.0.0 COMMANDS: zones zones management records zone records management help, h Shows a list of commands or help for one command GLOBAL OPTIONS: --email CloudFlare user email [$CLOUDFLARE_EMAIL] --key CloudFlare user key [$CLOUDFLARE_KEY] --help, -h show help --version, -v print the version $ cf zones list +----------------------------------+-------------------+--------+---------+ | ID | NAME | PAUSED | STATUS | +----------------------------------+-------------------+--------+---------+ | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx | xxxxxxxxxxx.com | no | pending | | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx | xxxxxxxxxxx.com | no | pending | | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx | xxxxxxxxxxx.com | no | active | | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx | xxxxxxxxxxx.com | no | active | +----------------------------------+-------------------+--------+---------+ $ cf records list 5xxxxxcxxxxxxxxxxxxxxxxxxxxxxxx2 +----------------------------------+------+------------------+-------------+-----------+---------+--------+-----+---------------------+---------------------+ | ID | TYPE | NAME | CONTENT | PROXIABLE | PROXIED | LOCKED | TTL | CREATED ON | MODIFIED ON | +----------------------------------+------+------------------+-------------+-----------+---------+--------+-----+---------------------+---------------------+ | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx | A | xxxxxxxxx.pl | xx.xx.xx.xx | yes | yes | no | 1 | 2015/01/13 15:53:59 | 2015/01/13 15:53:59 | | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx | A | www.xxxxxxxxx.pl | xx.xx.xx.xx | yes | yes | no | 1 | 2015/01/13 15:53:59 | 2015/01/13 15:53:59 | +----------------------------------+------+------------------+-------------+-----------+---------+--------+-----+---------------------+---------------------+ ``` ## Usage ```go package main import ( "log" "time" "github.com/crackcomm/cloudflare" "golang.org/x/net/context" ) func main() { client := cloudflare.New(&cloudflare.Options{ Email: "example@email.com", Key: "example-key", }) ctx := context.Background() ctx, _ = context.WithTimeout(ctx, time.Second*30) zones, err := client.Zones.List(ctx) if err != nil { log.Fatal(err) } else if len(zones) == 0 { log.Fatal("No zones were found") } records, err := client.Records.List(ctx, zones[0].ID) if err != nil { log.Fatal(err) } for _, record := range records { log.Printf("%#v", record) } } ``` ## CloudFlare® CloudFlare is a registered trademark of [CloudFlare, Inc](https://cloudflare.com). ## License Apache 2.0 License.