2021-03-19 09:30:42 +01:00
|
|
|
// Package ooapi contains a client for the OONI API. We
|
|
|
|
// automatically generate the code in this package from the
|
|
|
|
// apimodel and internal/generator packages.
|
2021-03-04 11:51:07 +01:00
|
|
|
//
|
2021-03-19 09:30:42 +01:00
|
|
|
// Usage
|
2021-03-04 11:51:07 +01:00
|
|
|
//
|
2021-03-19 09:30:42 +01:00
|
|
|
// You need to create a Client. Make sure you set all
|
|
|
|
// the mandatory fields. You will then have a function
|
|
|
|
// for every supported OONI API. This function will
|
|
|
|
// take in input a context and a request. You need to
|
|
|
|
// fill the request, of course. The return value is
|
|
|
|
// either a response or an error.
|
2021-03-04 11:51:07 +01:00
|
|
|
//
|
2021-03-19 09:30:42 +01:00
|
|
|
// If an API requires login, we will automatically
|
|
|
|
// perform the login. If an API uses caching, we will
|
|
|
|
// automatically use the cache.
|
2021-03-04 11:51:07 +01:00
|
|
|
//
|
|
|
|
// See the example describing auto-login for more information
|
|
|
|
// on how to use auto-login.
|
|
|
|
//
|
|
|
|
// Design
|
|
|
|
//
|
|
|
|
// Most of the code in this package is auto-generated from the
|
|
|
|
// data model in ./apimodel and the definition of APIs provided
|
|
|
|
// by ./internal/generator/spec.go.
|
|
|
|
//
|
|
|
|
// We keep the generated files up-to-date by running
|
|
|
|
//
|
|
|
|
// go generate ./...
|
|
|
|
//
|
|
|
|
// We have tests that ensure that the definition of the API
|
|
|
|
// used here is reasonably close to the server's one.
|
|
|
|
//
|
|
|
|
// Testing
|
|
|
|
//
|
|
|
|
// The following command
|
|
|
|
//
|
|
|
|
// go test ./...
|
|
|
|
//
|
|
|
|
// will, among other things, ensure that the our API spec
|
|
|
|
// is consistent with the server's one. Running
|
|
|
|
//
|
|
|
|
// go test -short ./...
|
|
|
|
//
|
|
|
|
// will exclude most (slow) integration tests.
|
|
|
|
//
|
|
|
|
// Architecture
|
|
|
|
//
|
|
|
|
// The ./apimodel package contains the definition of request
|
|
|
|
// and response messages. We rely on tagging to specify how
|
|
|
|
// we should encode and decode messages.
|
|
|
|
//
|
|
|
|
// The ./internal/generator contains code to generate most
|
|
|
|
// code in this package. In particular, the spec.go file is
|
|
|
|
// the specification of the APIs.
|
|
|
|
package ooapi
|