Skip to content

Latest commit

 

History

History
241 lines (145 loc) · 5.71 KB

README.md

File metadata and controls

241 lines (145 loc) · 5.71 KB

pavie

Node.js restful API for Plex Media Server.

Tested on Plex Media Server v1.16.3.

License: MIT npm version Install size

Summary

Libraries

Directories

Synchronize

Playlists

History

Metadata

Images

Install

$ npm install pavie

Usage

const Pavie = require("pavie")

const pavie = new Pavie({ username: "USERNAME", password: "PASSWORD" })

pavie
  .signin()
  .then(user => {
    console.log(user)
  })
  .catch(err => {
    console.error(err)
  })

Documentation

Instance methods

signin()

Authenticate user to Plex server. This is the first method to call, this instantiate your server and your token for the others methods !

Return user <object> if authentification is successfull.

getResources()

Get the list of resources with connection settings. Conection : [name, protocol, address, port, uri, local, relay, IPv6].

getUser()

Get user info. Return: [id, uuid, username, title, email, thumb, authToken, certificateVersion, rememberExpiresAt].

getIdentity()

Get basic info about the Plex server. Return: [machineIdentifier, version]

getActions()

Get the list actions availables. ie : platform, platformVersion, updatedAt, version, machineIdentifier, myPlexUsername. Return : [activities, butler, channels, clients, devices, diagnostics, hubs, library, livetv, media, player, playlists, resources, search, server, ...].

getMedatadata([id])

Get metdata of a media.

getServers()

Get a list of servers. Return: [name, host, address, port, machineIdentifier, version].

Libraries

getLibraries()

Get a list of libraries. Return: [section, recentlyAdded, onDeck].

getLibrary([library = 'sections'])

Get a list of sections in the library. Return: [Movies, Music, TV Shows].

refresh([library = 'sections'], [sectionId = 2])

Refresh a section.

Directories

getDirectoriesFromSection([library = 'sections'], [sectionId = 2])

Get list of directory in a specified section. Default : TV Shows section. Return : [all, unwatched, newest, recentlyAdded, recenntlyViewed, recentlyViewedShows, onDeck, folder, ...]

getDirectory([library = 'sections'], [sectionId = 2], [directory = 'all'])

Get a list of TV Shows by directory. Default : TV Shows and all. Return : [studio, type, title, contentRating, summary, index, rating, year, thumb, art, duration, originallyAvailableAt, ...].

search([library = 'sections'], [sectionId = 2], [filters = { type: 2}])

Search Tv Shows, episodes, movies or musics. Default : [sectionId : Tv Shows, type: Tv Shows] For Tv Shows, type: [2: Tv Shows, 3: Seasonn, 4 : Episode]

Synchronize

getSynchronize()

Get synchronize info.

synchronize([accounntId])

Synchronize Plex and Trakt.tv.

Playlists

getPlaylists()

Get all playlists.

getPlaylist([ratingKey])

Get playlist basic info.

  • ratingKey <string> | <number> Identifiant

getPlaylistFiles([ratingKey])

Get playlist video files.

  • ratingKey <string> | <number> Identifiant

addPlaylist([data])

Add new playlist.

  • data <object>
    • uri <string> Path to a list of video files, ie : server://2c59cf8256eccd8629081638e98e27bf8349c3e7/com.plexapp.plugins.library/library/metadata/26082
    • title <string> Title of the playlist
    • smart <number> Default: 0
    • type <string> Default: video

updatePlaylist([ratingKey], [data])

Update existing playlist.

  • ratingKey <string> | <number> Identifiant
  • data <object>
    • title <string> Title
    • summary <string> Description

updatePlaylistFiles([ratingKey], [uri])

Add files to an existing playlist.

  • ratingKey <string> | <number> Identifiant
  • uri <string> Path to a list of video files, ie: server://2c59cf8256eccd8629081638e98e27bf8349c3e7/com.plexapp.plugins.library/library/metadata/26082

removePlaylist([ratingKey])

Remove existing playlist.

  • ratingKey <string> | <number> Identifiant

History

getHistory(options)

Get the history of a TV Shows.

  • options <object>

    • metadataItemID <number> Identifiant
    • sort <string> Order by, default : viewed:desc

    Metadata

    getMetadata([id])

    Return all info about a media.

    • id <number> Identifiant

    getMetadataChildren([id], [options])

    Return all children metadata for a specified media. ie: Returnn seasons metadata for a specified Tv Show.

    • id <number> Identifiant
    • options <object>
      • excludeAllLeaves <number>, default: 1

    getRelated([id], [options])

    Return a list of related media.

    • id <number> Identifiant
    • options <object>
      • excludeFields <string>, default: summary
      • includeExternalMetadata <number>, default: 1
      • asyncAugmentMetadata <number>, default: 1

    getSimilar([id])

    Return a list of similar media.

    • id <number> Identifiant

Images

getImage([url], [options])

Return an image.

  • url <string> Path to the image
  • options <object>
    • width <number>, default: 170
    • height <number>, default: 96
    • minSize <number>, default: 1
    • upscale <number>, default: 1