ooapi

package
v3.11.0-beta.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 15, 2021 License: GPL-3.0 Imports: 18 Imported by: 0

Documentation

Overview

Package ooapi contains a client for the OONI API. We automatically generate the code in this package from the apimodel and internal/generator packages.

Usage

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.

If an API requires login, we will automatically perform the login. If an API uses caching, we will automatically use the cache.

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 sub-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 sub-package contains code to generate most code in this package. In particular, the spec.go file is the specification of the APIs.

Index

Examples

Constants

This section is empty.

Variables

View Source
var (
	ErrAPICallFailed   = errors.New("ooapi: API call failed")
	ErrEmptyField      = errors.New("ooapi: empty field")
	ErrHTTPFailure     = errors.New("ooapi: http request failed")
	ErrJSONLiteralNull = errors.New("ooapi: server returned us a literal null")
	ErrMissingToken    = errors.New("ooapi: missing auth token")
	ErrUnauthorized    = errors.New("ooapi: not authorized")
)

Errors defined by this package.

Functions

This section is empty.

Types

type Client

type Client struct {
	// KVStore is the MANDATORY key-value store. You can use
	// the kvstore.Memory{} struct for an in-memory store.
	KVStore KVStore

	// The following fields are optional. When they are empty
	// we will fallback to sensible defaults.
	BaseURL      string
	GobCodec     GobCodec
	HTTPClient   HTTPClient
	JSONCodec    JSONCodec
	RequestMaker RequestMaker
	UserAgent    string
}

Client is a client for speaking with the OONI API. Make sure you fill in the mandatory fields.

Example
package main

import (
	"context"
	"fmt"
	"log"

	"github.com/ooni/probe-cli/v3/internal/kvstore"
	"github.com/ooni/probe-cli/v3/internal/ooapi"
	"github.com/ooni/probe-cli/v3/internal/ooapi/apimodel"
)

func main() {
	clnt := &ooapi.Client{
		KVStore: &kvstore.Memory{},
	}
	ctx := context.Background()
	resp, err := clnt.CheckIn(ctx, &apimodel.CheckInRequest{
		Charging:        false,
		OnWiFi:          false,
		Platform:        "linux",
		ProbeASN:        "AS30722",
		ProbeCC:         "IT",
		RunType:         "timed",
		SoftwareName:    "miniooni",
		SoftwareVersion: "0.1.0-dev",
		WebConnectivity: apimodel.CheckInRequestWebConnectivity{
			CategoryCodes: []string{"NEWS"},
		},
	})
	fmt.Printf("%+v\n", err)

	if resp == nil {
		log.Fatal("expected non-nil response")
	}
}
Output:

<nil>

func (*Client) CheckIn

CheckIn calls the CheckIn API.

func (*Client) CheckReportID

CheckReportID calls the CheckReportID API.

func (*Client) MeasurementMeta

MeasurementMeta calls the MeasurementMeta API.

func (*Client) OpenReport

OpenReport calls the OpenReport API.

func (*Client) PsiphonConfig

PsiphonConfig calls the PsiphonConfig API.

func (*Client) SubmitMeasurement

SubmitMeasurement calls the SubmitMeasurement API.

func (*Client) TestHelpers

TestHelpers calls the TestHelpers API.

func (*Client) TorTargets

TorTargets calls the TorTargets API.

func (*Client) URLs

URLs calls the URLs API.

type GobCodec

type GobCodec interface {
	// Encode encodes v as a serialized gob byte slice.
	Encode(v interface{}) ([]byte, error)

	// Decode decodes the serialized gob byte slice into v.
	Decode(b []byte, v interface{}) error
}

GobCodec is a Gob encoder and decoder. Generally, we use a default GobCodec in Client. This is the interface to implement if you want to override such a default.

type HTTPClient

type HTTPClient interface {
	// Do should work like http.Client.Do.
	Do(req *http.Request) (*http.Response, error)
}

HTTPClient is the interface of a generic HTTP client. The stdlib's http.Client implements this interface. We use http.DefaultClient as the default HTTPClient used by Client. Consumers of this package typically provide a custom HTTPClient with additional functionality (e.g., DoH, circumvention).

type JSONCodec

type JSONCodec interface {
	// Encode encodes v as a serialized JSON byte slice.
	Encode(v interface{}) ([]byte, error)

	// Decode decodes the serialized JSON byte slice into v.
	Decode(b []byte, v interface{}) error
}

JSONCodec is a JSON encoder and decoder. Generally, we use a default JSONCodec in Client. This is the interface to implement if you want to override such a default.

type KVStore

type KVStore interface {
	// Get gets a value from the key-value store.
	Get(key string) ([]byte, error)

	// Set stores a value into the key-value store.
	Set(key string, value []byte) error
}

KVStore is a key-value store. This is the interface the client expect for the key-value store used to save persistent state (typically on the file system).

type RequestMaker

type RequestMaker interface {
	// NewRequest creates a new HTTP request.
	NewRequest(ctx context.Context, method, URL string, body io.Reader) (*http.Request, error)
}

RequestMaker makes an HTTP request. Generally, we use a default RequestMaker in Client. This is the interface to implement if you want to override such a default.

Directories

Path Synopsis
Package apimodel describes the data types used by OONI's API.
Package apimodel describes the data types used by OONI's API.
internal
generator
Command generator generates code in the ooapi package.
Command generator generates code in the ooapi package.
openapi
Package openapi contains data structures for Swagger v2.0.
Package openapi contains data structures for Swagger v2.0.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL