Documentation ¶
Overview ¶
Package webpackager implements the control flow of Web Packager.
The code below illustrates the usage of this package:
packager := webpackager.NewPackager(webpackager.Config{ ExchangeFactory: &exchange.Factory{ Version: version.Version1b3, MIRecordSize: 4096, // ... (you need to set other fields) }, ResourceCache: filewrite.NewFileWriteCache(&filewrite.Config{ BaseCache: cache.NewOnMemoryCache(), ExchangeMapping: filewrite.AddBaseDir( filewrite.AppendExt(filewrite.UsePhysicalURLPath(), *flagSXGExt), *flagSXGDir), }), }) for _, url := range urls { if err := packager.Run(url); err != nil { log.Print(err) } }
Config allows you to change some behaviors of the Packager. packager.Run(url) retrieves an HTTP response using FetchClient, processes it using Processor, and turns it into a signed exchange using ExchangeFactory. Processor inspects the HTTP response to see the eligibility for signed exchanges and manipulates it to optimize the page loading. The generated signed exchanges are stored in ResourceCache to prevent duplicates.
The code above sets just two parameters, ExchangeFactory and ResourceCache, and uses the defaults for other parameters. With this setup, the packager retrieves the content just through HTTP, applies the recommended set of optimizations, generates signed exchanges compliant with the version b3, and saves them in files named like "index.html.sxg" under "/tmp/sxg".
Config has a few more parameters. See its definition for the details.
You can also pass your own implementations to Config to inject custom logic into the packaging flow. You could write, for example, a custom FetchClient to retrieve the content from a database table instead of web servers, a custom Processor or HTMLTask to apply your optimization techniques, a ResourceCache to store the produced signed exchanges into another database table in addition to a local drive, and so on.
The cmd/webpackager package provides a command line interface to execute the packaging flow without writing the driver code on your own.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type Config ¶
type Config struct { // RequestTweaker specifies the mutation applied to every http.Request // before it is passed to FetchClient. RequestTweaker is applied // both to the http.Request instances passed to the Packager and those // generated internally (e.g. for subresources). Note that, however, // some RequestTweakers have effect only to subresource requests. // // nil implies fetch.DefaultRequestTweaker. RequestTweaker fetch.RequestTweaker // FetchClient specifies how to retrieve the resources which Packager // produces the signed exchanges for. // // nil implies fetch.DefaultFetchClient, which is just an http.Client // properly configured. FetchClient fetch.FetchClient // PhysicalURLRule specifies the rule(s) to simulate the URL rewriting // on the server side, such as appending "index.html" to the path when // it points to a directory. // // nil implies urlrewrite.DefaultRules, which contains a reasonable set // of rules to simulate static web servers. // // See package urlrewrite for details. PhysicalURLRule urlrewrite.Rule // ValidityURLRule specifies the rule to determine the validity URL, // where the validity data should be served. // // nil implies validity.DefaultURLRule, which appends ".validity" plus // the last modified time (in UNIX time) to the document URL. ValidityURLRule validity.URLRule // Processor specifies the processor(s) applied to each HTTP response // before turning it into a signed exchange. The processors make sure // the response can be distributed as signed exchanges and optionally // adjust the response for optimized page loading. // // nil implies complexproc.DefaultProcessor, a composite of relatively // conservative processors. // // See package processor for details. Processor processor.Processor // ValidPeriodRule specifies the rule to determine the validity period // of signed exchanges. // // nil implies vprule.DefaultRule. ValidPeriodRule vprule.Rule // ExchangeFactory specifies encoding parameters and signing materials // for producing signed exchanges. If you use the same certificate and // private key for the whole lifetime of the Packager, you can specify // an *exchange.Factory directly. // // ExchangeFactory must be set to non-nil. ExchangeFactory exchange.FactoryProvider // ResourceCache specifies the cache to store the signed exchanges and // the validity data. // // It is typically initialized with filewrite.NewFileWriteCache so the // signed exchanges are saved into files. See the package document for // sample usage. // // nil implies cache.NewOnMemoryCache(). It is not likely useful: // the process would produce signed exchanges and store them in memory, // then throw them away at the termination. ResourceCache cache.ResourceCache }
Config defines injection points to Packager.
type Error ¶
type Error struct { // Err represents the actual error. Err error // URL represents the URL that caused this Error. URL *url.URL }
Error represents an error from Packager.Run.
type Packager ¶
type Packager struct {
Config
}
Packager implements the control flow of Web Packager.
func NewPackager ¶
NewPackager creates and initializes a new Packager with the provided Config. It panics when config.ExchangeFactory is nil.
func (*Packager) Run ¶
Run runs the process to obtain the signed exchange for url: fetches the content from the server, processes it, and produces the signed exchange from it. Run also takes care of subresources (external resources referenced from the fetched content), such as stylesheets, provided they are good for preloading.
The process stops when it encounters any error with processing the main resource (specified by url), but keeps running and produces the signed exchange for the main resource if it just fails with the subresources. In either case, Run returns a multierror.Error (hashicorp/go-multierror), which consists of webpackager.Errors.
Run does not run the process when ResourceCache already has an entry for url.
func (*Packager) RunForRequest ¶
func (pkg *Packager) RunForRequest(req *http.Request, sxgDate time.Time) (*resource.Resource, error)
RunForRequest is like Run, but takes an http.Request instead of a URL thus provides more flexibility to the caller.
RunForRequest uses req directly: RequestTweaker mutates req; FetchClient sends req to retrieve the HTTP response.
Directories ¶
Path | Synopsis |
---|---|
Package certchain handles signed exchange certificates.
|
Package certchain handles signed exchange certificates. |
certchainutil
Package certchainutil complements the certchain package.
|
Package certchainutil complements the certchain package. |
certmanager
Package certmanager manages signed exchange certificates.
|
Package certmanager manages signed exchange certificates. |
certmanager/acmeclient
Package acmeclient provides a RawChainSource to acquire a signed exchange certificate using the ACME protocol.
|
Package acmeclient provides a RawChainSource to acquire a signed exchange certificate using the ACME protocol. |
certmanager/futureevent
Package futureevent defines interface to handle future events.
|
Package futureevent defines interface to handle future events. |
Package exchange provides high-level interface to generate signed exchanges.
|
Package exchange provides high-level interface to generate signed exchanges. |
exchangetest
Package exchangetest provides utilities for exchange testing.
|
Package exchangetest provides utilities for exchange testing. |
vprule
Package vprule defines how to determine the validity period of signed exchanges.
|
Package vprule defines how to determine the validity period of signed exchanges. |
Package fetch defines interface to retrieve contents to package.
|
Package fetch defines interface to retrieve contents to package. |
fetchtest
Package fetchtest provides FetchClient implementations for use in testing.
|
Package fetchtest provides FetchClient implementations for use in testing. |
internal
|
|
certchaintest
Package certchaintest provides utilities for certificate chain testing.
|
Package certchaintest provides utilities for certificate chain testing. |
customflag
Package customflag provides additional flag.Value implementations.
|
Package customflag provides additional flag.Value implementations. |
timeutil
Package timeutil provides time.Now that can be monkey-patched.
|
Package timeutil provides time.Now that can be monkey-patched. |
urlutil
Package urlutil provides URL-related utility functions.
|
Package urlutil provides URL-related utility functions. |
Package processor defines the Processor interface.
|
Package processor defines the Processor interface. |
commonproc
Package commonproc implements processors applicable to any HTTP responses.
|
Package commonproc implements processors applicable to any HTTP responses. |
complexproc
Package complexproc provides a factory of fully-featured processors, namely NewComprehensiveProcessor.
|
Package complexproc provides a factory of fully-featured processors, namely NewComprehensiveProcessor. |
htmlproc
Package htmlproc implements a Processor to process HTML documents.
|
Package htmlproc implements a Processor to process HTML documents. |
htmlproc/htmldoc
Package htmldoc provides interface to handle HTML documents.
|
Package htmldoc provides interface to handle HTML documents. |
htmlproc/htmltask
Package htmltask implements some optimization logic for HTML documents.
|
Package htmltask implements some optimization logic for HTML documents. |
preverify
Package preverify implements processors to verify that HTTP responses can be distributed as signed exchanges.
|
Package preverify implements processors to verify that HTTP responses can be distributed as signed exchanges. |
Package resource defines representations of resources to generate signed exchanges for.
|
Package resource defines representations of resources to generate signed exchanges for. |
cache
Package cache defines the ResourceCache interface and provides the most basic implementation.
|
Package cache defines the ResourceCache interface and provides the most basic implementation. |
cache/filewrite
Package filewrite provides ResourceCache that also saves signed exchanges to files on the Store operations to the cache.
|
Package filewrite provides ResourceCache that also saves signed exchanges to files on the Store operations to the cache. |
httplink
Package httplink defines a representation of Web Linkings.
|
Package httplink defines a representation of Web Linkings. |
preload
Package preload defines representations of preload links.
|
Package preload defines representations of preload links. |
preload/preloadtest
Package preloadtest provides utilities for preload link testing.
|
Package preloadtest provides utilities for preload link testing. |
Package server implements Web Packager HTTP Server (webpkgserver).
|
Package server implements Web Packager HTTP Server (webpkgserver). |
tomlconfig
Package tomlconfig defines the TOML config for Web Packager HTTP Server.
|
Package tomlconfig defines the TOML config for Web Packager HTTP Server. |
Package urlmatcher defines interface for URL matching.
|
Package urlmatcher defines interface for URL matching. |
Package urlrewrite reproduces server-side URL rewrite logic.
|
Package urlrewrite reproduces server-side URL rewrite logic. |
Package validity handles the validity data of signed exchanges.
|
Package validity handles the validity data of signed exchanges. |