Documentation ¶
Index ¶
- Constants
- Variables
- func AddContainerFilters(newFilters ...APITopologyOption)
- func NewVersion(version, downloadURL string)
- func NewnholuongutPublisher(nholuongutClient nholuongutClient, dockerClient DockerClient, ...) *nholuongutPublisher
- func RegisterControlRoutes(router *mux.Router, cr ControlRouter)
- func RegisterPipeRoutes(router *mux.Router, pr PipeRouter)
- func RegisterReportPostHandler(a Adder, router *mux.Router)
- func RegisterTopologyRoutes(router *mux.Router, r Reporter, capabilities map[string]bool)
- func RenderContextForReporter(rep Reporter, r report.Report) detailed.RenderContext
- func URLMatcher(pattern string) mux.MatcherFunc
- type APINode
- type APITopology
- type APITopologyDesc
- type APITopologyOption
- type APITopologyOptionGroup
- type Adder
- type Collector
- type ControlRouter
- type CtxHandlerFunc
- type DockerClient
- type End
- type Interface
- type InterfaceFunc
- type Merger
- type PipeRouter
- type Registry
- type Reporter
- type StaticCollector
- func (c StaticCollector) Add(context.Context, report.Report, []byte) error
- func (c StaticCollector) HasHistoricReports() bool
- func (c StaticCollector) HasReports(context.Context, time.Time) (bool, error)
- func (c StaticCollector) Report(context.Context, time.Time) (report.Report, error)
- func (c StaticCollector) UnWait(context.Context, chan struct{})
- func (c StaticCollector) WaitOn(context.Context, chan struct{})
- type WebReporter
Constants ¶
const ( UIEnd = iota ProbeEnd )
Valid values of type End
const ( DefaultHostname = "scope.nholuongut.local." DefaultnholuongutURL = "http://127.0.0.1:6784" DefaultContainerName = "nholuongutscope" )
Default values for nholuongut app integration
const RequestCtxKey contextKey = contextKey("request")
RequestCtxKey is key used for request entry in context
Variables ¶
var ( // Version - set at buildtime. Version = "dev" // UniqueID - set at runtime. UniqueID = "0" )
Functions ¶
func AddContainerFilters ¶
func AddContainerFilters(newFilters ...APITopologyOption)
AddContainerFilters adds to the default Registry (topologyRegistry)'s containerFilters
func NewVersion ¶
func NewVersion(version, downloadURL string)
NewVersion is called to expose new version information to /api
func NewnholuongutPublisher ¶
func NewnholuongutPublisher(nholuongutClient nholuongutClient, dockerClient DockerClient, interfaces InterfaceFunc, hostname, containerName string) *nholuongutPublisher
NewnholuongutPublisher makes a new nholuongut.
func RegisterControlRoutes ¶
func RegisterControlRoutes(router *mux.Router, cr ControlRouter)
RegisterControlRoutes registers the various control routes with a http mux.
func RegisterPipeRoutes ¶
func RegisterPipeRoutes(router *mux.Router, pr PipeRouter)
RegisterPipeRoutes registers the pipe routes
func RegisterReportPostHandler ¶
RegisterReportPostHandler registers the handler for report submission
func RegisterTopologyRoutes ¶
RegisterTopologyRoutes registers the various topology routes with a http mux.
func RenderContextForReporter ¶
func RenderContextForReporter(rep Reporter, r report.Report) detailed.RenderContext
RenderContextForReporter creates the rendering context for the given reporter.
func URLMatcher ¶
func URLMatcher(pattern string) mux.MatcherFunc
URLMatcher uses request.RequestURI (the raw, unparsed request) to attempt to match pattern. It does this as go's URL.Parse method is broken, and mistakenly unescapes the Path before parsing it. This breaks %2F (encoded forward slashes) in the paths.
Types ¶
type APITopology ¶
type APITopology struct {
Nodes detailed.NodeSummaries `json:"nodes"`
}
APITopology is returned by the /api/topology/{name} handler.
type APITopologyDesc ¶
type APITopologyDesc struct { Name string `json:"name"` Rank int `json:"rank"` HideIfEmpty bool `json:"hide_if_empty"` Options []APITopologyOptionGroup `json:"options"` URL string `json:"url"` SubTopologies []APITopologyDesc `json:"sub_topologies,omitempty"` Stats topologyStats `json:"stats,omitempty"` // contains filtered or unexported fields }
APITopologyDesc is returned in a list by the /api/topology handler.
type APITopologyOption ¶
type APITopologyOption struct { Value string `json:"value"` Label string `json:"label"` // contains filtered or unexported fields }
APITopologyOption describes a ¶m=value to a given topology.
func MakeAPITopologyOption ¶
func MakeAPITopologyOption(value string, label string, filterFunc render.FilterFunc, pseudo bool) APITopologyOption
MakeAPITopologyOption provides an external interface to the package for creating an APITopologyOption.
type APITopologyOptionGroup ¶
type APITopologyOptionGroup struct { ID string `json:"id"` // Default value for the option. Used if the value is omitted; not used if the value is "" Default string `json:"defaultValue"` Options []APITopologyOption `json:"options,omitempty"` // SelectType describes how options can be picked. Currently defined values: // "one": Default if empty. Exactly one option may be picked from the list. // "union": Any number of options may be picked. Nodes matching any option filter selected are displayed. // Value and Default should be a ","-separated list. SelectType string `json:"selectType,omitempty"` // For "union" type, this is the label the UI should use to represent the case where nothing is selected NoneLabel string `json:"noneLabel,omitempty"` }
APITopologyOptionGroup describes a group of APITopologyOptions
type Adder ¶
Adder is something that can accept reports. It's a convenient interface for parts of the app, and several experimental components. It takes the following arguments: - context.Context: the request context - report.Report: the deserialised report - []byte: the serialised report (as gzip'd msgpack)
type Collector ¶
A Collector is a Reporter and an Adder
func NewCollector ¶
NewCollector returns a collector ready for use.
func NewFileCollector ¶
NewFileCollector reads and parses the files at path (a file or directory) as reports. If there are multiple files, and they all have names representing "nanoseconds since epoch" timestamps, e.g. "1488557088545489008.msgpack.gz", then the collector will return merged reports resulting from replaying the file reports in a loop at a sequence and speed determined by the timestamps. Otherwise the collector always returns the merger of all reports.
type ControlRouter ¶
type ControlRouter interface { Handle(ctx context.Context, probeID string, req xfer.Request) (xfer.Response, error) Register(ctx context.Context, probeID string, handler xfer.ControlHandlerFunc) (int64, error) Deregister(ctx context.Context, probeID string, id int64) error }
ControlRouter is a thing that can route control requests and responses between the UI and a probe.
func NewLocalControlRouter ¶
func NewLocalControlRouter() ControlRouter
NewLocalControlRouter creates a new ControlRouter that does everything locally, in memory.
type CtxHandlerFunc ¶
CtxHandlerFunc is a http.HandlerFunc, with added contexts
type DockerClient ¶
type DockerClient interface {
ListContainers(fsouza.ListContainersOptions) ([]fsouza.APIContainers, error)
}
DockerClient is the little bit of the docker client we need.
type Interface ¶
Interface is because net.Interface isn't mockable.
func Interfaces ¶
Interfaces returns the list of Interfaces on the machine.
type InterfaceFunc ¶
InterfaceFunc is the type of Interfaces()
type Merger ¶
Merger is the type for a thing that can merge reports.
func NewFastMerger ¶
func NewFastMerger() Merger
NewFastMerger makes a Merger which merges together reports, mutating the one we are building up
type PipeRouter ¶
type PipeRouter interface { Exists(context.Context, string) (bool, error) Get(context.Context, string, End) (xfer.Pipe, io.ReadWriter, error) Release(context.Context, string, End) error Delete(context.Context, string) error Stop() }
PipeRouter stores pipes and allows you to connect to either end of them.
func NewLocalPipeRouter ¶
func NewLocalPipeRouter() PipeRouter
NewLocalPipeRouter returns a new local (in-memory) pipe router.
type Registry ¶
Registry is a threadsafe store of the available topologies
func (*Registry) Add ¶
func (r *Registry) Add(ts ...APITopologyDesc)
Add inserts a topologyDesc to the Registry's items map
func (*Registry) AddContainerFilters ¶
func (r *Registry) AddContainerFilters(newFilters ...APITopologyOption)
AddContainerFilters adds container filters to this Registry
type Reporter ¶
type Reporter interface { Report(context.Context, time.Time) (report.Report, error) HasReports(context.Context, time.Time) (bool, error) HasHistoricReports() bool WaitOn(context.Context, chan struct{}) UnWait(context.Context, chan struct{}) }
Reporter is something that can produce reports on demand. It's a convenient interface for parts of the app, and several experimental components.
type StaticCollector ¶
StaticCollector always returns the given report.
func (StaticCollector) Add ¶
Add adds a report to the collector's internal state. It implements Adder.
func (StaticCollector) HasHistoricReports ¶
func (c StaticCollector) HasHistoricReports() bool
HasHistoricReports indicates whether the collector contains reports older than now-app.window.
func (StaticCollector) HasReports ¶
HasReports indicates whether the collector contains reports between timestamp-app.window and timestamp.
func (StaticCollector) Report ¶
Report returns a merged report over all added reports. It implements Reporter.
func (StaticCollector) UnWait ¶
func (c StaticCollector) UnWait(context.Context, chan struct{})
UnWait lets other components stop waiting on a new report being received. It implements Reporter.
func (StaticCollector) WaitOn ¶
func (c StaticCollector) WaitOn(context.Context, chan struct{})
WaitOn lets other components wait on a new report being received. It implements Reporter.
type WebReporter ¶
WebReporter is a reporter that creates reports whose data is eventually displayed on websites. It carries fields that will be forwarded to the detailed.RenderContext