notifiarr

package
v0.2.7 Latest Latest
Warning

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

Go to latest
Published: Jan 22, 2022 License: MIT Imports: 36 Imported by: 0

Documentation

Overview

Package notifiarr provides a standard interface for sending data to notifiarr.com. Several methods are exported to make POSTing data to notifarr easier. This package also handles the incoming Plex webhook as well as the "crontab" timers for plex sessions, snapshots, dashboard state, custom format sync for Radarr and release profile sync for Sonarr. This package's cofiguration is provided by the configfile package.

Index

Constants

View Source
const (
	ModeDev  = "development"
	ModeProd = "production"
)
View Source
const (
	// DefaultRetries is the number of times to attempt a request to notifiarr.com.
	// 4 means 5 total tries: 1 try + 4 retries.
	DefaultRetries = 4
	// RetryDelay is how long to Sleep between retries.
	RetryDelay = 222 * time.Millisecond
)

Variables

View Source
var (
	ErrNon200          = fmt.Errorf("return code was not 200")
	ErrInvalidResponse = fmt.Errorf("invalid response")
	ErrInvalidApp      = fmt.Errorf("invalid application provided")
)

Errors returned by this library.

View Source
var ErrNoChannel = fmt.Errorf("no channel to send session request")
View Source
var (
	ErrNoDBInBackup = fmt.Errorf("no database file found in backup")
)

Errors returned by this package.

Functions

This section is empty.

Types

type BackupInfo added in v0.2.5

type BackupInfo struct {
	App    starr.App `json:"app"`
	Int    int       `json:"instance"`
	Name   string    `json:"name"`
	File   string    `json:"file,omitempty"`
	Ver    string    `json:"version,omitempty"`
	Integ  string    `json:"integrity,omitempty"`
	Quick  string    `json:"quick,omitempty"`
	Rows   int       `json:"rows,omitempty"`
	Size   int64     `json:"bytes,omitempty"`
	Tables int64     `json:"tables,omitempty"`
	Date   time.Time `json:"date,omitempty"`
}

BackupInfo contains a pile of information about a Starr database (backup). This is the data sent to notifiarr.com.

type BackupPayload added in v0.2.5

type BackupPayload struct {
	App   starr.App           `json:"app"`
	Int   int                 `json:"instance"`
	Name  string              `json:"name"`
	Files []*starr.BackupFile `json:"backups"`
}

BackupPayload is the data we send to notifiarr.

type ClientInfo added in v0.1.6

type ClientInfo struct {
	User struct {
		WelcomeMSG string `json:"welcome"`
		Subscriber bool   `json:"subscriber"`
		Patron     bool   `json:"patron"`
	} `json:"user"`
	Actions struct {
		Poll      bool             `json:"poll"`
		Plex      *plex.Server     `json:"plex"`      // optional
		Apps      appConfigs       `json:"apps"`      // unused yet!
		Dashboard dashConfig       `json:"dashboard"` // now in use.
		Sync      syncConfig       `json:"sync"`      // in use (cfsync)
		Gaps      gapsConfig       `json:"gaps"`      // radarr collection gaps
		Custom    []*timerConfig   `json:"custom"`    // custom GET timers
		Snapshot  *snapshot.Config `json:"snapshot"`  // optional
	} `json:"actions"`
}

ClientInfo is the client's startup data received from the website.

func (*ClientInfo) IsPatron added in v0.1.13

func (c *ClientInfo) IsPatron() bool

IsPatron returns true if the client is a patron. False otherwise.

func (*ClientInfo) IsSub added in v0.1.13

func (c *ClientInfo) IsSub() bool

IsSub returns true if the client is a subscriber. False otherwise.

func (*ClientInfo) String added in v0.1.6

func (c *ClientInfo) String() string

String returns the message text for a client info response.

type Config

type Config struct {
	Apps     *apps.Apps       // has API key
	Plex     *plex.Server     // plex sessions
	Snap     *snapshot.Config // system snapshot data
	Services *ServiceConfig
	Retries  int
	BaseURL  string
	Timeout  cnfg.Duration
	Trigger  Triggers
	MaxBody  int
	Sighup   chan os.Signal

	*logs.Logger // log file writer
	// contains filtered or unexported fields
}

Config is the input data needed to send payloads to notifiarr.

func (*Config) GetClientInfo added in v0.1.6

func (c *Config) GetClientInfo(event EventType) (*ClientInfo, error)

GetClientInfo returns an error if the API key is wrong. Returns client info otherwise.

func (*Config) GetData added in v0.1.16

func (c *Config) GetData(url string) (*Response, error)

func (*Config) GetHostInfoUID added in v0.2.0

func (c *Config) GetHostInfoUID() (*host.InfoStat, error)

GetHostInfoUID attempts to make a unique machine identifier...

func (*Config) GetSessions added in v0.1.16

func (c *Config) GetSessions(wait bool) (*plex.Sessions, error)

GetSessions returns the plex sessions. This uses a channel so concurrent requests are avoided. Passing wait=true makes sure the results are current. Waits up to 10 seconds before requesting. Passing wait=false will allow for sessions up to 10 seconds old. This may return faster.

func (*Config) HostInfoNoError added in v0.2.0

func (c *Config) HostInfoNoError() *host.InfoStat

HostInfoNoError will return nil if there is an error, otherwise a copy of the host info.

func (*Config) Info added in v0.1.14

func (c *Config) Info() map[string]interface{}

Info is used for JSON input for our outgoing client info.

func (*Config) PlexHandler added in v0.1.15

func (c *Config) PlexHandler(w http.ResponseWriter, r *http.Request)

PlexHandler handles an incoming webhook from Plex.

func (*Config) SendData

func (c *Config) SendData(uri string, payload interface{}, log bool) (*Response, error)

SendData sends raw data to a notifiarr URL as JSON.

func (*Config) Setup added in v0.2.0

func (c *Config) Setup(mode string) string

Start (and log) snapshot and plex cron jobs if they're configured.

func (*Config) Start

func (c *Config) Start()

Start runs the timers.

func (*Config) Stop

func (c *Config) Stop(event EventType)

Stop all internal cron timers and Triggers.

type EventType added in v0.2.0

type EventType string

EventType identifies the type of event that sent a paylaod to notifiarr.

const (
	EventCron    EventType = "cron"
	EventUser    EventType = "user"
	EventAPI     EventType = "api"
	EventHook    EventType = "webhook"
	EventStart   EventType = "start"
	EventMovie   EventType = "movie"
	EventEpisode EventType = "episode"
	EventPoll    EventType = "poll"
	EventReload  EventType = "reload"
)

These are all our known event types.

type IntList added in v0.2.7

type IntList []int

IntList has a method to abstract lookups.

func (IntList) Has added in v0.2.7

func (l IntList) Has(instance int) bool

Has returns true if the list has an instance ID.

type ItemList added in v0.1.9

type ItemList map[int]ListItem

func (ItemList) Empty added in v0.1.9

func (i ItemList) Empty() bool

func (ItemList) Len added in v0.1.9

func (i ItemList) Len() (count int)

type ListItem added in v0.2.0

type ListItem struct {
	Elapsed time.Duration `json:"elapsed"`
	Name    string        `json:"name"`
	Queue   []interface{} `json:"queue"`
}

type Payload

type Payload struct {
	Plex *plex.Sessions       `json:"plex,omitempty"`
	Snap *snapshot.Snapshot   `json:"snapshot,omitempty"`
	Load *plexIncomingWebhook `json:"payload,omitempty"`
}

Payload is the outbound payload structure that is sent to Notifiarr for Plex and system snapshot data.

type QueuePayload added in v0.1.9

type QueuePayload struct {
	Lidarr  ItemList `json:"lidarr,omitempty"`
	Radarr  ItemList `json:"radarr,omitempty"`
	Readarr ItemList `json:"readarr,omitempty"`
	Sonarr  ItemList `json:"sonarr,omitempty"`
}

type RadarrTrashPayload added in v0.2.7

type RadarrTrashPayload struct {
	Instance        int                      `json:"instance"`
	Name            string                   `json:"name"`
	CustomFormats   []*radarr.CustomFormat   `json:"customFormats,omitempty"`
	QualityProfiles []*radarr.QualityProfile `json:"qualityProfiles,omitempty"`
	Error           string                   `json:"error"`
	// Purposely not exported so as to not use it externally.
	NewMaps *cfMapIDpayload `json:"newMaps,omitempty"`
}

RadarrTrashPayload is the payload sent and received to/from notifarr.com when updating custom formats for Radarr. This is used in other places, like the trash API handler in the 'client' module.

type Response added in v0.2.0

type Response struct {
	Result  string `json:"result"`
	Details struct {
		Response json.RawMessage `json:"response"` // can be anything. type it out later.
		Started  time.Time       `json:"started"`
		Finished time.Time       `json:"finished"`
		Elapsed  cnfg.Duration   `json:"elapsed"`
	} `json:"details"`
}

Response is what notifiarr replies to our requests with.

try this
{
    "response": "success",
    "message": {
        "response": {
            "instance": 1,
            "debug": null
        },
        "started": "23:57:03",
        "finished": "23:57:03",
        "elapsed": "0s"
    }
}
{
    "response": "success",
    "message": {
        "response": "Service status cron processed.",
        "started": "00:04:15",
        "finished": "00:04:15",
        "elapsed": "0s"
    }
}
{
    "response": "success",
    "message": {
        "response": "Channel stats cron processed.",
        "started": "00:04:31",
        "finished": "00:04:36",
        "elapsed": "5s"
    }
}
{
    "response": "success",
    "message": {
        "response": "Dashboard payload processed.",
        "started": "00:02:04",
        "finished": "00:02:11",
        "elapsed": "7s"
    }
}

nitsua: all responses should be that way.. but response might not always be an object.

func (*Response) String added in v0.2.5

func (r *Response) String() string

String turns the response into a log entry.

type Route added in v0.2.0

type Route string

Route is used to give us methods on our route paths.

const (
	BaseURL    = "https://notifiarr.com"
	DevBaseURL = "https://dev.notifiarr.com"

	ClientRoute Route = userRoute2 + "/client"
	CFSyncRoute Route = userRoute1 + "/trash"
	GapsRoute   Route = userRoute1 + "/gaps"

	DashRoute    Route = notifiRoute + "/dashboard"
	StuckRoute   Route = notifiRoute + "/stuck"
	PlexRoute    Route = notifiRoute + "/plex"
	SnapRoute    Route = notifiRoute + "/snapshot"
	SvcRoute     Route = notifiRoute + "/services"
	CorruptRoute Route = notifiRoute + "/corruption"
	BackupRoute  Route = notifiRoute + "/backup"
)

Notifiarr URLs. Data sent to these URLs:

api/v1/notification/plex?event=...

api (was plexcron)
user (was plexcron)
cron (was plexcron)
webhook (was plexhook)
movie
episode

api/v1/notification/services?event=...

api
user
cron
start (only fires on startup)

api/v1/notification/snapshot?event=...

api
user
cron

api/v1/notification/dashboard?event=... (requires interval from website/client endpoint)

api
user
cron

api/v1/notification/stuck?event=...

api
user
cron

api/v1/user/gaps?app=radarr&event=...

api
user
cron

api/v2/user/client?event=start

see description https://github.com/Notifiarr/notifiarr/pull/115

api/v1/user/trash?app=...

radarr
sonarr

func (Route) Path added in v0.2.0

func (r Route) Path(event EventType, params ...string) string

Path adds parameters to a route path and turns it into a string.

type ServiceCheck added in v0.2.0

type ServiceCheck struct {
	Name     string        `json:"name"`
	Type     string        `json:"type"`
	Expect   string        `json:"expect"`
	Timeout  cnfg.Duration `json:"timeout"`
	Interval cnfg.Duration `json:"interval"`
}

ServiceCheck comes from the services package. It's only used for display on the website.

type ServiceConfig added in v0.2.0

type ServiceConfig struct {
	Interval cnfg.Duration   `json:"interval"`
	Parallel uint            `json:"parallel"`
	Disabled bool            `json:"disabled"`
	Checks   []*ServiceCheck `json:"checks"`
}

ServiceConfig comes from the services package. It's only used for display on the website.

type SonarrTrashPayload added in v0.2.7

type SonarrTrashPayload struct {
	Instance        int                      `json:"instance"`
	Name            string                   `json:"name"`
	ReleaseProfiles []*sonarr.ReleaseProfile `json:"releaseProfiles,omitempty"`
	QualityProfiles []*sonarr.QualityProfile `json:"qualityProfiles,omitempty"`
	Error           string                   `json:"error"`
	// Purposely not exported so as to not use it externally.
	NewMaps *cfMapIDpayload `json:"newMaps,omitempty"`
}

SonarrTrashPayload is the payload sent and received to/from notifarr.com when updating custom formats for Sonarr.

type Sortable added in v0.1.13

type Sortable struct {
	Name    string    `json:"name"`
	Sub     string    `json:"subName,omitempty"`
	Date    time.Time `json:"date"`
	Season  int64     `json:"season,omitempty"`
	Episode int64     `json:"episode,omitempty"`
	// contains filtered or unexported fields
}

Sortable holds data about any Starr item. Kind of a generic data store.

type SortableList added in v0.1.13

type SortableList []*Sortable

SortableList allows sorting a list.

func (*SortableList) Shrink added in v0.1.13

func (s *SortableList) Shrink(size int)

Shrink a sortable list.

type State added in v0.1.13

type State struct {
	// Shared
	Error    string        `json:"error"`
	Instance int           `json:"instance"`
	Missing  int64         `json:"missing,omitempty"`
	Size     int64         `json:"size"`
	Percent  float64       `json:"percent,omitempty"`
	Upcoming int64         `json:"upcoming,omitempty"`
	Next     SortableList  `json:"next,omitempty"`
	Latest   SortableList  `json:"latest,omitempty"`
	OnDisk   int64         `json:"onDisk,omitempty"`
	Elapsed  cnfg.Duration `json:"elapsed"` // How long it took.
	Name     string        `json:"name"`
	// Radarr
	Movies int64 `json:"movies,omitempty"`
	// Sonarr
	Shows    int64 `json:"shows,omitempty"`
	Episodes int64 `json:"episodes,omitempty"`
	// Readarr
	Authors  int   `json:"authors,omitempty"`
	Books    int64 `json:"books,omitempty"`
	Editions int   `json:"editions,omitempty"`
	// Lidarr
	Artists int   `json:"artists,omitempty"`
	Albums  int64 `json:"albums,omitempty"`
	Tracks  int64 `json:"tracks,omitempty"`
	// Downloader
	Downloads   int   `json:"downloads,omitempty"`
	Uploaded    int64 `json:"uploaded,omitempty"`
	Incomplete  int64 `json:"incomplete,omitempty"`
	Downloaded  int64 `json:"downloaded,omitempty"`
	Uploading   int64 `json:"uploading,omitempty"`
	Downloading int64 `json:"downloading,omitempty"`
	Seeding     int64 `json:"seeding,omitempty"`
	Paused      int64 `json:"paused,omitempty"`
	Errors      int64 `json:"errors,omitempty"`
	Month       int64 `json:"month,omitempty"`
	Week        int64 `json:"week,omitempty"`
}

State is partially filled out once for each app instance.

type States added in v0.1.13

type States struct {
	Lidarr  []*State `json:"lidarr"`
	Radarr  []*State `json:"radarr"`
	Readarr []*State `json:"readarr"`
	Sonarr  []*State `json:"sonarr"`
	Qbit    []*State `json:"qbit"`
	Deluge  []*State `json:"deluge"`
	SabNZB  []*State `json:"sabnzbd"`
}

States is our compiled states for the dashboard.

type Timer added in v0.1.15

type Timer struct {
	// contains filtered or unexported fields
}

Timer is used to set a cooldown time.

func (*Timer) Active added in v0.1.15

func (t *Timer) Active(d time.Duration) bool

Active returns true if a timer is active, otherwise it becomes active.

type TriggerName added in v0.2.5

type TriggerName string

TriggerName makes sure triggers have a known name.

const (
	TrigLidarrBackup   TriggerName = "Sending Lidarr Backup File List to Notifiarr."
	TrigProwlarrBackup TriggerName = "Sending Prowlarr Backup File List to Notifiarr."
	TrigRadarrBackup   TriggerName = "Sending Radarr Backup File List to Notifiarr."
	TrigReadarrBackup  TriggerName = "Sending Readarr Backup File List to Notifiarr."
	TrigSonarrBackup   TriggerName = "Sending Sonarr Backup File List to Notifiarr."
)

Used to find and identiy each trigger in the trigger list.

const (
	TrigLidarrCorrupt   TriggerName = "Checking Lidarr instances for database backup corruption."
	TrigProwlarrCorrupt TriggerName = "Checking Prowlarr instances for database backup corruption."
	TrigRadarrCorrupt   TriggerName = "Checking Radarr instances for database backup corruption."
	TrigReadarrCorrupt  TriggerName = "Checking Readarr instances for database backup corruption."
	TrigSonarrCorrupt   TriggerName = "Checking Sonarr instances for database backup corruption."
)

Trigger Types.

const (
	TrigSnapshot       TriggerName = "Gathering and sending System Snapshot."
	TrigDashboard      TriggerName = "Initiating State Collection for Dashboard."
	TrigCFSync         TriggerName = "Starting Custom Formats and Quality Profiles Sync for Radarr and Sonarr."
	TrigCollectionGaps TriggerName = "Sending Radarr Collection Gaps."
	TrigPlexSessions   TriggerName = "Gathering and sending Plex Sessions."
	TrigStuckItems     TriggerName = "Checking app queues and sending stuck items."
	TrigPollSite       TriggerName = "Polling Notifiarr for new settings."
	TrigStop           TriggerName = "Stop Channel is used for reloads and must not have a function."
)

Identified Action Triggers. Name and explanation.

type Triggers added in v0.1.15

type Triggers struct {
	List []*action // List of action triggers
	// contains filtered or unexported fields
}

Triggers allow trigger actions in the timer routine.

func (*Triggers) Backup added in v0.2.5

func (t *Triggers) Backup(event EventType, app starr.App) error

func (*Triggers) Corruption added in v0.2.5

func (t *Triggers) Corruption(event EventType, app starr.App) error

func (*Triggers) SendDashboardState added in v0.2.0

func (t *Triggers) SendDashboardState(event EventType)

SendDashboardState sends the current states for the dashboard.

func (*Triggers) SendGaps added in v0.1.16

func (t *Triggers) SendGaps(event EventType)

func (*Triggers) SendPlexSessions added in v0.1.15

func (t *Triggers) SendPlexSessions(event EventType)

SendPlexSessions sends plex sessions in a go routine through a channel.

func (*Triggers) SendSnapshot added in v0.1.15

func (t *Triggers) SendSnapshot(event EventType)

func (*Triggers) SendStuckQueueItems added in v0.2.0

func (t *Triggers) SendStuckQueueItems(event EventType)

func (*Triggers) SyncCF added in v0.1.15

func (t *Triggers) SyncCF(event EventType)

Jump to

Keyboard shortcuts

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