v2

package
v0.0.22 Latest Latest
Warning

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

Go to latest
Published: Nov 10, 2021 License: Apache-2.0 Imports: 14 Imported by: 1

Documentation

Index

Constants

View Source
const (
	TagRun  string = "run"
	TagScan string = "scan"
)
View Source
const (
	ErrApplicationInvalid  api.ErrorType = "application-invalid"
	ErrApplicationNotFound api.ErrorType = "application-not-found"
	ErrScenarioInvalid     api.ErrorType = "scenario-invalid"
	ErrScenarioNotFound    api.ErrorType = "scenario-not-found"
	ErrScanInvalid         api.ErrorType = "scan-invalid"
	ErrActivityInvalid     api.ErrorType = "activity-invalid"
	ErrActivityRateLimited api.ErrorType = "activity-rate-limited"
)

Variables

This section is empty.

Functions

This section is empty.

Types

type API

type API interface {
	// CheckEndpoint verifies we can talk to the backend.
	CheckEndpoint(ctx context.Context) (api.Metadata, error)

	// ListApplications gets a list of existing applications for an authorized request.
	ListApplications(ctx context.Context, q ApplicationListQuery) (ApplicationList, error)
	// ListApplicationsByPage returns single page of applications identified by the supplied URL.
	ListApplicationsByPage(ctx context.Context, u string) (ApplicationList, error)
	// CreateApplication creates a new application.
	CreateApplication(ctx context.Context, app Application) (api.Metadata, error)
	// GetApplication retrieves an application.
	GetApplication(ctx context.Context, u string) (Application, error)
	// GetApplicationByName retrieves an application.
	GetApplicationByName(ctx context.Context, n ApplicationName) (Application, error)
	// UpsertApplication updates or creates an application.
	UpsertApplication(ctx context.Context, u string, app Application) (api.Metadata, error)
	// UpsertApplicationByName updates or creates an application.
	UpsertApplicationByName(ctx context.Context, n ApplicationName, app Application) (api.Metadata, error)
	// DeleteApplication deletes an application.
	DeleteApplication(ctx context.Context, u string) error

	// ListScenarios lists configured scenarios for an application.
	ListScenarios(ctx context.Context, u string, q ScenarioListQuery) (ScenarioList, error)
	// CreateScenario creates a scenario.
	CreateScenario(ctx context.Context, u string, scn Scenario) (api.Metadata, error)
	// GetScenario retrieves a scenario.
	GetScenario(ctx context.Context, u string) (Scenario, error)
	// UpsertScenario updates or creates a scenario with the URL scenario name.
	UpsertScenario(ctx context.Context, u string, scn Scenario) (Scenario, error)
	// DeleteScenario deletes a scenario.
	DeleteScenario(ctx context.Context, u string) error
	// PatchScenario updates attributes on a scenario.
	PatchScenario(ctx context.Context, u string, scn Scenario) error

	// GetTemplate gets the application scenario template.
	GetTemplate(ctx context.Context, u string) (Template, error)
	// UpdateTemplate records or updates scenario template.
	UpdateTemplate(ctx context.Context, u string, s Template) error
	// PatchTemplate updates a partial scenario template.
	PatchTemplate(ctx context.Context, u string, s Template) error

	// ListActivity gets activity feed for an application.
	ListActivity(ctx context.Context, u string, q ActivityFeedQuery) (ActivityFeed, error)
	// CreateActivity creates application activity.
	CreateActivity(ctx context.Context, u string, a Activity) error
	// DeleteActivity resolves application activity.
	DeleteActivity(ctx context.Context, u string) error
	// PatchApplicationActivity updates application activity.
	PatchApplicationActivity(ctx context.Context, u string, a ActivityFailure) error

	// SubscribeActivity returns a subscriber for the activity feed.
	SubscribeActivity(ctx context.Context, q ActivityFeedQuery) (Subscriber, error)
}

func NewAPI

func NewAPI(c api.Client) API

type Activity

type Activity struct {
	api.Metadata `json:"-"`
	Run          *RunActivity  `json:"run,omitempty"`
	Scan         *ScanActivity `json:"scan,omitempty"`
}

type ActivityExtension

type ActivityExtension struct {
	ActivityFailure
}

type ActivityFailure

type ActivityFailure struct {
	FailureReason  string `json:"failure_reason,omitempty"`
	FailureMessage string `json:"failure_message,omitempty"`
}

type ActivityFeed

type ActivityFeed struct {
	HomePageURL string         `json:"home_page_url,omitempty"`
	FeedURL     string         `json:"feed_url,omitempty"`
	NextURL     string         `json:"next_url,omitempty"`
	Hubs        []ActivityHub  `json:"hubs,omitempty"`
	Items       []ActivityItem `json:"items"`
}

func (*ActivityFeed) SetBaseURL

func (af *ActivityFeed) SetBaseURL(u string)

SetBaseURL resolves the URLs on the activity feed against a supplied base. Typically, the URL used to fetch the feed, the feed's `feed_url` field, and the base URL should all match; however, it may be the case that the `feed_url` field is returned as a relative URL (the JSON Feed spec does not specify a behavior in this regard).

type ActivityFeedQuery

type ActivityFeedQuery struct {
	Query map[string][]string
}

func (*ActivityFeedQuery) SetType

func (q *ActivityFeedQuery) SetType(t ...string)

type ActivityHub

type ActivityHub struct {
	Type string `json:"type"`
	URL  string `json:"url"`
}

type ActivityItem

type ActivityItem struct {
	ID            string             `json:"id"`
	URL           string             `json:"url,omitempty"`
	ExternalURL   string             `json:"external_url,omitempty"`
	Title         string             `json:"title,omitempty"`
	DatePublished time.Time          `json:"date_published,omitempty"`
	DateModified  time.Time          `json:"date_modified,omitempty"`
	Tags          []string           `json:"tags,omitempty"`
	StormForge    *ActivityExtension `json:"_stormforge,omitempty"`
}

func (*ActivityItem) HasTag

func (ai *ActivityItem) HasTag(tag string) bool

type Application

type Application struct {
	api.Metadata `json:"-"`
	Name         ApplicationName `json:"name"`
	DisplayName  string          `json:"title,omitempty"`
	Resources    []interface{}   `json:"resources,omitempty"`
}

type ApplicationItem

type ApplicationItem struct {
	Application
	// The number of scenarios associated with this application.
	ScenarioCount int `json:"scenarioCount,omitempty"`
}

func (*ApplicationItem) UnmarshalJSON

func (ai *ApplicationItem) UnmarshalJSON(b []byte) error

type ApplicationList

type ApplicationList struct {
	// The application list metadata.
	api.Metadata `json:"-"`
	// The total number of items in the collection.
	TotalCount int `json:"totalCount,omitempty"`
	// The list of applications.
	Applications []ApplicationItem `json:"applications,omitempty"`
}

type ApplicationListQuery

type ApplicationListQuery struct{ api.IndexQuery }

type ApplicationName

type ApplicationName string

ApplicationName represents a name token used to identify an application.

func (ApplicationName) String

func (n ApplicationName) String() string

type Lister added in v0.0.21

type Lister struct {
	// API is the Application API used to fetch objects.
	API API
	// BatchSize overrides the default batch size for fetching lists.
	BatchSize int
}

Lister is a helper to individually visit all items in a list (even across page boundaries).

func (*Lister) ForEachApplication added in v0.0.21

func (l *Lister) ForEachApplication(ctx context.Context, q ApplicationListQuery, f func(*ApplicationItem) error) error

ForEachApplication iterates over all the applications matching the supplied query.

func (*Lister) ForEachScenario added in v0.0.21

func (l *Lister) ForEachScenario(ctx context.Context, app *Application, q ScenarioListQuery, f func(*ScenarioItem) error) (err error)

ForEachScenario iterates over all scenarios for an application matching the supplied query.

func (*Lister) GetApplicationByNameOrTitle added in v0.0.22

func (l *Lister) GetApplicationByNameOrTitle(ctx context.Context, name string) (*Application, error)

GetApplicationByNameOrTitle tries to get an application by name and falls back to a linear search over all the applications by title.

func (*Lister) GetScenarioByNameOrTitle added in v0.0.22

func (l *Lister) GetScenarioByNameOrTitle(ctx context.Context, app *Application, name string) (*Scenario, error)

GetScenarioByNameOrTitle tries to get a scenario by name and falls back to a linear search over all the scenarios by title.

type PollingSubscriber

type PollingSubscriber struct {
	// The API instance used to fetch the feed.
	API API
	// The URL to poll.
	FeedURL string
	// Time between polling requests. Defaults to 30 seconds.
	PollInterval time.Duration
	// Adjust the poll duration by a random amount. Defaults to 1.0, effectively
	// a random amount up to the full poll interval.
	JitterFactor float64
	// Flag indicating that failed activities should still be reported.
	ReportFailedActivities bool // TODO Should this be part of the ActivityFeedQuery?
	// contains filtered or unexported fields
}

PollingSubscriber is a primitive strategy that simply polls for changes.

func (*PollingSubscriber) PollTimer

func (s *PollingSubscriber) PollTimer() *time.Timer

PollTimer returns a new timer for the next polling operation.

func (*PollingSubscriber) Subscribe

func (s *PollingSubscriber) Subscribe(ctx context.Context, ch chan<- ActivityItem) error

Subscribe polls for activity, blocking until the supplied context is finished or a fatal error occurs talking to the activity endpoint.

type RunActivity

type RunActivity struct {
	Scenario string `json:"scenario"`
	ActivityFailure
}

type ScanActivity

type ScanActivity struct {
	Scenario string `json:"scenario"`
	ActivityFailure
}

type Scenario

type Scenario struct {
	api.Metadata  `json:"-"`
	Name          string        `json:"name"`
	DisplayName   string        `json:"title,omitempty"`
	Configuration []interface{} `json:"configuration,omitempty"`
	Objective     []interface{} `json:"objective,omitempty"`

	StormForgePerformance interface{} `json:"stormforgePerf,omitempty"`
	Locust                interface{} `json:"locust,omitempty"`
	Custom                interface{} `json:"custom,omitempty"`
}

type ScenarioItem

type ScenarioItem struct {
	Scenario
}

func (*ScenarioItem) UnmarshalJSON

func (l *ScenarioItem) UnmarshalJSON(b []byte) error

type ScenarioList

type ScenarioList struct {
	// The scenario list metadata.
	api.Metadata `json:"-"`
	// The total number of items in the collection.
	TotalCount int `json:"totalCount,omitempty"`
	// The list of scenarios.
	Scenarios []ScenarioItem `json:"scenarios,omitempty"`
}

type ScenarioListQuery

type ScenarioListQuery struct{ api.IndexQuery }

type Subscriber

type Subscriber interface {
	// Subscribe initiates a subscription that continues for the lifetime of the context.
	Subscribe(ctx context.Context, ch chan<- ActivityItem) error
}

Subscriber describes a strategy for subscribing to feed notifications.

type Template

type Template struct {
	// The list of parameters for this template.
	Parameters []TemplateParameter `json:"parameters,omitempty"`
	// The list of metrics for this template.
	Metrics []TemplateMetric `json:"metrics,omitempty"`
}

type TemplateMetric

type TemplateMetric struct {
	// The name of the metric.
	Name string `json:"name"`
	// The flag indicating this metric should be minimized.
	Minimize bool `json:"minimize,omitempty"`
	// The flag indicating this metric is optimized (nil defaults to true).
	Optimize *bool `json:"optimize,omitempty"`
	// The domain of the metric
	Bounds *TemplateMetricBounds `json:"bounds,omitempty"`
}

type TemplateMetricBounds

type TemplateMetricBounds struct {
	// The minimum value for a metric.
	Min float64 `json:"min,omitempty"`
	// The maximum value for a metric.
	Max float64 `json:"max,omitempty"`
}

type TemplateParameter

type TemplateParameter struct {
	// The name of the parameter.
	Name string `json:"name"`
	// The type of the parameter.
	Type string `json:"type"`
	// The optional baseline value of the parameter, either numeric or categorical.
	Baseline *api.NumberOrString `json:"baseline,omitempty"`
	// The domain of the parameter.
	Bounds *TemplateParameterBounds `json:"bounds,omitempty"`
	// The list of allowed categorical values for the parameter.
	Values []string `json:"values,omitempty"`
}

type TemplateParameterBounds

type TemplateParameterBounds struct {
	// The minimum value for a numeric parameter.
	Min json.Number `json:"min,omitempty"`
	// The maximum value for a numeric parameter.
	Max json.Number `json:"max,omitempty"`
}

Jump to

Keyboard shortcuts

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