-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathdoc.go
39 lines (38 loc) · 2.08 KB
/
doc.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
// package fastlike is a Go implementation of the Fastly Compute@Edge XQD ABI.
//
// It is designed to be used as an `http.Handler`, and has a `ServeHTTP` method to accomodate.
// The ABI is designed around a single instance handling a single request and response pair. This
// package is thus designed accordingly, with each incoming HTTP request being passed to a fresh
// wasm instance.
// The public surface area of this package is intentionally small, as it is designed to operate on
// a single (request, response) pair and any fiddling with the internals can cause serious
// side-effects.
//
// XQD ABI
// The XQD ABI is the interface between a Compute wasm program and the host. In production, the
// host is Fastly's Compute platform. Fastlike is an alternative implementation of the host.
//
// At time of writing, the ABI is not a public, documented spec. This implementation was done by
// looking at the source code of the fastly rust crate, particularly [abi.rs] and [lib.rs] for
// some constants.
//
// Our implementation of the ABI is in xqd*.go, and it's linked to your wasm program via the `linker`
// method of the Instance type, implemented in instance.go.
//
// Each ABI method purposefully follows the signatures defined on the guest-side to make it easy to
// compare. It's not idiomatic Go by design.
//
// BACKENDS / ORIGINS
//
// In Fastly, you are expected to configure origins. These origins define where your requests will
// go once they pass through the Fastly data plane, and you cannot send requests to any origin not
// defined in your Fastly configuration. Compute programs have this same limitation. In order to
// issue a request, a Compute program must select a backend to send it to.
//
// In Fastlike, the caller is expected to provide a function which takes the name of a backend and
// an http.Request and returns an (http.Response, error) pair. The default implementation of this
// function is to return a 502 Bad Gateway.
//
// [abi.rs]: https://docs.rs/crate/fastly/0.3.2/source/src/abi.rs
// [lib.rs]: https://docs.rs/crate/fastly-shared/0.3.2/source/src/lib.rs
package fastlike