2019-04-15 20:42:02 -04:00
|
|
|
package linodego
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
"time"
|
2020-06-12 05:36:54 -04:00
|
|
|
|
|
|
|
"github.com/linode/linodego/internal/duration"
|
|
|
|
"github.com/linode/linodego/internal/parseabletime"
|
2019-04-15 20:42:02 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
// Event represents an action taken on the Account.
|
|
|
|
type Event struct {
|
|
|
|
// The unique ID of this Event.
|
|
|
|
ID int `json:"id"`
|
|
|
|
|
|
|
|
// Current status of the Event, Enum: "failed" "finished" "notification" "scheduled" "started"
|
|
|
|
Status EventStatus `json:"status"`
|
|
|
|
|
|
|
|
// The action that caused this Event. New actions may be added in the future.
|
|
|
|
Action EventAction `json:"action"`
|
|
|
|
|
|
|
|
// A percentage estimating the amount of time remaining for an Event. Returns null for notification events.
|
|
|
|
PercentComplete int `json:"percent_complete"`
|
|
|
|
|
|
|
|
// The rate of completion of the Event. Only some Events will return rate; for example, migration and resize Events.
|
|
|
|
Rate *string `json:"rate"`
|
|
|
|
|
|
|
|
// If this Event has been read.
|
|
|
|
Read bool `json:"read"`
|
|
|
|
|
|
|
|
// If this Event has been seen.
|
|
|
|
Seen bool `json:"seen"`
|
|
|
|
|
|
|
|
// The estimated time remaining until the completion of this Event. This value is only returned for in-progress events.
|
2020-06-12 05:36:54 -04:00
|
|
|
TimeRemaining *int `json:"-"`
|
2019-04-15 20:42:02 -04:00
|
|
|
|
|
|
|
// The username of the User who caused the Event.
|
|
|
|
Username string `json:"username"`
|
|
|
|
|
|
|
|
// Detailed information about the Event's entity, including ID, type, label, and URL used to access it.
|
|
|
|
Entity *EventEntity `json:"entity"`
|
|
|
|
|
2020-06-12 05:36:54 -04:00
|
|
|
// Detailed information about the Event's secondary or related entity, including ID, type, label, and URL used to access it.
|
|
|
|
SecondaryEntity *EventEntity `json:"secondary_entity"`
|
|
|
|
|
2019-04-15 20:42:02 -04:00
|
|
|
// When this Event was created.
|
|
|
|
Created *time.Time `json:"-"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// EventAction constants start with Action and include all known Linode API Event Actions.
|
|
|
|
type EventAction string
|
|
|
|
|
|
|
|
// EventAction constants represent the actions that cause an Event. New actions may be added in the future.
|
|
|
|
const (
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionAccountUpdate EventAction = "account_update"
|
|
|
|
ActionAccountSettingsUpdate EventAction = "account_settings_update"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionBackupsEnable EventAction = "backups_enable"
|
|
|
|
ActionBackupsCancel EventAction = "backups_cancel"
|
|
|
|
ActionBackupsRestore EventAction = "backups_restore"
|
|
|
|
ActionCommunityQuestionReply EventAction = "community_question_reply"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionCommunityLike EventAction = "community_like"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionCreateCardUpdated EventAction = "credit_card_updated"
|
|
|
|
ActionDiskCreate EventAction = "disk_create"
|
|
|
|
ActionDiskDelete EventAction = "disk_delete"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionDiskUpdate EventAction = "disk_update"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionDiskDuplicate EventAction = "disk_duplicate"
|
|
|
|
ActionDiskImagize EventAction = "disk_imagize"
|
|
|
|
ActionDiskResize EventAction = "disk_resize"
|
|
|
|
ActionDNSRecordCreate EventAction = "dns_record_create"
|
|
|
|
ActionDNSRecordDelete EventAction = "dns_record_delete"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionDNSRecordUpdate EventAction = "dns_record_update"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionDNSZoneCreate EventAction = "dns_zone_create"
|
|
|
|
ActionDNSZoneDelete EventAction = "dns_zone_delete"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionDNSZoneUpdate EventAction = "dns_zone_update"
|
|
|
|
ActionHostReboot EventAction = "host_reboot"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionImageDelete EventAction = "image_delete"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionImageUpdate EventAction = "image_update"
|
|
|
|
ActionLassieReboot EventAction = "lassie_reboot"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionLinodeAddIP EventAction = "linode_addip"
|
|
|
|
ActionLinodeBoot EventAction = "linode_boot"
|
|
|
|
ActionLinodeClone EventAction = "linode_clone"
|
|
|
|
ActionLinodeCreate EventAction = "linode_create"
|
|
|
|
ActionLinodeDelete EventAction = "linode_delete"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionLinodeUpdate EventAction = "linode_update"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionLinodeDeleteIP EventAction = "linode_deleteip"
|
|
|
|
ActionLinodeMigrate EventAction = "linode_migrate"
|
|
|
|
ActionLinodeMutate EventAction = "linode_mutate"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionLinodeMutateCreate EventAction = "linode_mutate_create"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionLinodeReboot EventAction = "linode_reboot"
|
|
|
|
ActionLinodeRebuild EventAction = "linode_rebuild"
|
|
|
|
ActionLinodeResize EventAction = "linode_resize"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionLinodeResizeCreate EventAction = "linode_resize_create"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionLinodeShutdown EventAction = "linode_shutdown"
|
|
|
|
ActionLinodeSnapshot EventAction = "linode_snapshot"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionLinodeConfigCreate EventAction = "linode_config_create"
|
|
|
|
ActionLinodeConfigDelete EventAction = "linode_config_delete"
|
|
|
|
ActionLinodeConfigUpdate EventAction = "linode_config_update"
|
|
|
|
ActionLishBoot EventAction = "lish_boot"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionLongviewClientCreate EventAction = "longviewclient_create"
|
|
|
|
ActionLongviewClientDelete EventAction = "longviewclient_delete"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionLongviewClientUpdate EventAction = "longviewclient_update"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionManagedDisabled EventAction = "managed_disabled"
|
|
|
|
ActionManagedEnabled EventAction = "managed_enabled"
|
|
|
|
ActionManagedServiceCreate EventAction = "managed_service_create"
|
|
|
|
ActionManagedServiceDelete EventAction = "managed_service_delete"
|
|
|
|
ActionNodebalancerCreate EventAction = "nodebalancer_create"
|
|
|
|
ActionNodebalancerDelete EventAction = "nodebalancer_delete"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionNodebalancerUpdate EventAction = "nodebalancer_update"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionNodebalancerConfigCreate EventAction = "nodebalancer_config_create"
|
|
|
|
ActionNodebalancerConfigDelete EventAction = "nodebalancer_config_delete"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionNodebalancerConfigUpdate EventAction = "nodebalancer_config_update"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionPasswordReset EventAction = "password_reset"
|
|
|
|
ActionPaymentSubmitted EventAction = "payment_submitted"
|
|
|
|
ActionStackScriptCreate EventAction = "stackscript_create"
|
|
|
|
ActionStackScriptDelete EventAction = "stackscript_delete"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionStackScriptUpdate EventAction = "stackscript_update"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionStackScriptPublicize EventAction = "stackscript_publicize"
|
|
|
|
ActionStackScriptRevise EventAction = "stackscript_revise"
|
|
|
|
ActionTFADisabled EventAction = "tfa_disabled"
|
|
|
|
ActionTFAEnabled EventAction = "tfa_enabled"
|
|
|
|
ActionTicketAttachmentUpload EventAction = "ticket_attachment_upload"
|
|
|
|
ActionTicketCreate EventAction = "ticket_create"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionTicketUpdate EventAction = "ticket_update"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionVolumeAttach EventAction = "volume_attach"
|
|
|
|
ActionVolumeClone EventAction = "volume_clone"
|
|
|
|
ActionVolumeCreate EventAction = "volume_create"
|
|
|
|
ActionVolumeDelte EventAction = "volume_delete"
|
2020-06-12 05:36:54 -04:00
|
|
|
ActionVolumeUpdate EventAction = "volume_update"
|
2019-04-15 20:42:02 -04:00
|
|
|
ActionVolumeDetach EventAction = "volume_detach"
|
|
|
|
ActionVolumeResize EventAction = "volume_resize"
|
|
|
|
)
|
|
|
|
|
|
|
|
// EntityType constants start with Entity and include Linode API Event Entity Types
|
|
|
|
type EntityType string
|
|
|
|
|
2020-06-12 05:36:54 -04:00
|
|
|
// EntityType contants are the entities an Event can be related to.
|
2019-04-15 20:42:02 -04:00
|
|
|
const (
|
2020-06-12 05:36:54 -04:00
|
|
|
EntityLinode EntityType = "linode"
|
|
|
|
EntityDisk EntityType = "disk"
|
|
|
|
EntityDomain EntityType = "domain"
|
|
|
|
EntityNodebalancer EntityType = "nodebalancer"
|
2019-04-15 20:42:02 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
// EventStatus constants start with Event and include Linode API Event Status values
|
|
|
|
type EventStatus string
|
|
|
|
|
|
|
|
// EventStatus constants reflect the current status of an Event
|
|
|
|
const (
|
|
|
|
EventFailed EventStatus = "failed"
|
|
|
|
EventFinished EventStatus = "finished"
|
|
|
|
EventNotification EventStatus = "notification"
|
|
|
|
EventScheduled EventStatus = "scheduled"
|
|
|
|
EventStarted EventStatus = "started"
|
|
|
|
)
|
|
|
|
|
|
|
|
// EventEntity provides detailed information about the Event's
|
|
|
|
// associated entity, including ID, Type, Label, and a URL that
|
|
|
|
// can be used to access it.
|
|
|
|
type EventEntity struct {
|
|
|
|
// ID may be a string or int, it depends on the EntityType
|
|
|
|
ID interface{} `json:"id"`
|
|
|
|
Label string `json:"label"`
|
|
|
|
Type EntityType `json:"type"`
|
|
|
|
URL string `json:"url"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// EventsPagedResponse represents a paginated Events API response
|
|
|
|
type EventsPagedResponse struct {
|
|
|
|
*PageOptions
|
|
|
|
Data []Event `json:"data"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// endpoint gets the endpoint URL for Event
|
|
|
|
func (EventsPagedResponse) endpoint(c *Client) string {
|
|
|
|
endpoint, err := c.Events.Endpoint()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2020-06-12 05:36:54 -04:00
|
|
|
|
2019-04-15 20:42:02 -04:00
|
|
|
return endpoint
|
|
|
|
}
|
|
|
|
|
2020-06-12 05:36:54 -04:00
|
|
|
// UnmarshalJSON implements the json.Unmarshaler interface
|
|
|
|
func (i *Event) UnmarshalJSON(b []byte) error {
|
|
|
|
type Mask Event
|
|
|
|
|
|
|
|
p := struct {
|
|
|
|
*Mask
|
|
|
|
Created *parseabletime.ParseableTime `json:"created"`
|
|
|
|
TimeRemaining json.RawMessage `json:"time_remaining"`
|
|
|
|
}{
|
|
|
|
Mask: (*Mask)(i),
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := json.Unmarshal(b, &p); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
i.Created = (*time.Time)(p.Created)
|
|
|
|
i.TimeRemaining = duration.UnmarshalTimeRemaining(p.TimeRemaining)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2019-04-15 20:42:02 -04:00
|
|
|
// endpointWithID gets the endpoint URL for a specific Event
|
2020-06-12 05:36:54 -04:00
|
|
|
func (i Event) endpointWithID(c *Client) string {
|
2019-04-15 20:42:02 -04:00
|
|
|
endpoint, err := c.Events.Endpoint()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2020-06-12 05:36:54 -04:00
|
|
|
|
|
|
|
endpoint = fmt.Sprintf("%s/%d", endpoint, i.ID)
|
|
|
|
|
2019-04-15 20:42:02 -04:00
|
|
|
return endpoint
|
|
|
|
}
|
|
|
|
|
|
|
|
// appendData appends Events when processing paginated Event responses
|
|
|
|
func (resp *EventsPagedResponse) appendData(r *EventsPagedResponse) {
|
|
|
|
resp.Data = append(resp.Data, r.Data...)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ListEvents gets a collection of Event objects representing actions taken
|
|
|
|
// on the Account. The Events returned depend on the token grants and the grants
|
|
|
|
// of the associated user.
|
|
|
|
func (c *Client) ListEvents(ctx context.Context, opts *ListOptions) ([]Event, error) {
|
|
|
|
response := EventsPagedResponse{}
|
|
|
|
err := c.listHelper(ctx, &response, opts)
|
2020-06-12 05:36:54 -04:00
|
|
|
|
2019-04-15 20:42:02 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2020-06-12 05:36:54 -04:00
|
|
|
|
2019-04-15 20:42:02 -04:00
|
|
|
return response.Data, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetEvent gets the Event with the Event ID
|
|
|
|
func (c *Client) GetEvent(ctx context.Context, id int) (*Event, error) {
|
|
|
|
e, err := c.Events.Endpoint()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2020-06-12 05:36:54 -04:00
|
|
|
|
2019-04-15 20:42:02 -04:00
|
|
|
e = fmt.Sprintf("%s/%d", e, id)
|
|
|
|
r, err := c.R(ctx).SetResult(&Event{}).Get(e)
|
2020-06-12 05:36:54 -04:00
|
|
|
|
2019-04-15 20:42:02 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2020-06-12 05:36:54 -04:00
|
|
|
return r.Result().(*Event), nil
|
2019-04-15 20:42:02 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// MarkEventRead marks a single Event as read.
|
|
|
|
func (c *Client) MarkEventRead(ctx context.Context, event *Event) error {
|
|
|
|
e := event.endpointWithID(c)
|
|
|
|
e = fmt.Sprintf("%s/read", e)
|
|
|
|
|
|
|
|
_, err := coupleAPIErrors(c.R(ctx).Post(e))
|
|
|
|
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// MarkEventsSeen marks all Events up to and including this Event by ID as seen.
|
|
|
|
func (c *Client) MarkEventsSeen(ctx context.Context, event *Event) error {
|
|
|
|
e := event.endpointWithID(c)
|
|
|
|
e = fmt.Sprintf("%s/seen", e)
|
|
|
|
|
|
|
|
_, err := coupleAPIErrors(c.R(ctx).Post(e))
|
|
|
|
|
|
|
|
return err
|
|
|
|
}
|