notifiarr

package
v0.2.4 Latest Latest
Warning

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

Go to latest
Published: Dec 23, 2021 License: MIT Imports: 29 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")
)

Errors returned by this library.

View Source
var ErrNoChannel = fmt.Errorf("no channel to send session request")

Functions

This section is empty.

Types

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"`
}

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  time.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.

func (*Config) VersionHandler added in v0.1.15

func (c *Config) VersionHandler(r *http.Request) (int, interface{})

VersionHandler returns application run and build time data and application statuses: /api/version.

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 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 RadarrCustomFormatPayload added in v0.1.6

type RadarrCustomFormatPayload struct {
	Instance        int                      `json:"instance"`
	Name            string                   `json:"name"`
	CustomFormats   []*radarr.CustomFormat   `json:"customFormats,omitempty"`
	QualityProfiles []*radarr.QualityProfile `json:"qualityProfiles,omitempty"`
	NewMaps         *cfMapIDpayload          `json:"newMaps,omitempty"`
}

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

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.

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"
)

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 parameter 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 SonarrCustomFormatPayload added in v0.1.6

type SonarrCustomFormatPayload struct {
	Instance        int                      `json:"instance"`
	Name            string                   `json:"name"`
	ReleaseProfiles []*sonarr.ReleaseProfile `json:"releaseProfiles,omitempty"`
	QualityProfiles []*sonarr.QualityProfile `json:"qualityProfiles,omitempty"`
	NewMaps         *cfMapIDpayload          `json:"newMaps,omitempty"`
}

SonarrCustomFormatPayload 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 Triggers added in v0.1.15

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

Triggers allow trigger actions in the timer routine.

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