Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dstdfx/go-gcore
Unofficial Go library for accessing the G-Core CDN API
https://github.com/dstdfx/go-gcore
cdn-api gcore go http-client
Last synced: about 2 months ago
JSON representation
Unofficial Go library for accessing the G-Core CDN API
- Host: GitHub
- URL: https://github.com/dstdfx/go-gcore
- Owner: dstdfx
- License: mit
- Created: 2018-04-11T14:16:25.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2019-07-23T08:22:54.000Z (over 5 years ago)
- Last Synced: 2024-08-03T23:23:56.622Z (5 months ago)
- Topics: cdn-api, gcore, go, http-client
- Language: Go
- Size: 911 KB
- Stars: 6
- Watchers: 2
- Forks: 2
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-golang-repositories - go-gcore - Core CDN API (Repositories)
README
# go-gcore
[![Build Status](https://travis-ci.org/dstdfx/go-gcore.svg?branch=master)](https://travis-ci.org/dstdfx/go-gcore)
[![Go Report Card](https://goreportcard.com/badge/github.com/dstdfx/go-gcore)](https://goreportcard.com/report/github.com/dstdfx/go-gcore)
[![Coverage Status](https://coveralls.io/repos/github/dstdfx/go-gcore/badge.svg?branch=master)](https://coveralls.io/github/dstdfx/go-gcore?branch=master)Unofficial Go library for accessing the G-Core CDN API
It contains some parts of common and reseller G-Core CDN API.
Official docs are outdated, but anyway it's good to take a look at:
- https://docs.gcorelabs.com/cdn/## Authentication ##
Before you start you need to have a G-Core account, you can sign in [here](https://gcorelabs.com).
To use a common G-Core API (basic account) construct a new Common client, then use the various services on the client to
access different parts of the G-Core API. For example, authenticate as a common user and get account info:```go
// Your registration credentials
authOpts := gcore.AuthOptions{
Username: "username",
Password: "password",
}// Create a new Common client instance
client := gcore.NewCommonClient()// Get a token
// Empty context just for the sake of simplicity here
if err := client.Authenticate(context.Background(), authOpts); err != nil {
panic(err)
}
// Get account details
account, _, err := client.Account.Details(context.Background())
if err != nil {
panic(err)
}
fmt.Printf("%+v\n", account)
```To use a reseller G-Core API construct a new Reseller client, then use the various services on the client to
access different parts of the G-Core Reseller API. For example, authenticate as a reseller and get a list of activated clients:```go
// Your reseller registration credentials
authOpts := gcore.AuthOptions{
Username: "username",
Password: "password",
}// Create a new Reseller client instance
client := gcore.NewResellerClient()// Get a token
// Empty context just for the sake of simplicity here
if err := client.Authenticate(context.Background(), authOpts); err != nil {
panic(err)
}listOpts := gcore.ListOpts{
Activated: true,
}// Get a list of activated clients assigned to this reseller account
clients, _, err := client.Clients.List(context.Background(), listOpts)
if err != nil {
panic(err)
}
fmt.Printf("%+v\n", clients)
```## License ##
This library is distributed under the MIT license found in the [LICENSE](./LICENSE) file.