Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9ffbc49ad3 | ||
|
|
644dc8e3af | ||
|
|
47bc4e94dc | ||
|
|
f17d39fe17 | ||
|
|
966dcacf8d |
@@ -24,7 +24,8 @@ PLEX_TOKEN = "SuperSecretToken"
|
|||||||
#PLEX_USERNAME = ""
|
#PLEX_USERNAME = ""
|
||||||
#PLEX_PASSWORD = ""
|
#PLEX_PASSWORD = ""
|
||||||
#PLEX_SERVERNAME = "Plex Server"
|
#PLEX_SERVERNAME = "Plex Server"
|
||||||
|
## Skip hostname validation for ssl certificates.
|
||||||
|
SSL_BYPASS = "False"
|
||||||
|
|
||||||
## Jellyfin server URL, use hostname or IP address if the hostname is not resolving correctly
|
## Jellyfin server URL, use hostname or IP address if the hostname is not resolving correctly
|
||||||
## Comma seperated list for multiple servers
|
## Comma seperated list for multiple servers
|
||||||
|
|||||||
41
.github/workflows/codeql.yml
vendored
Normal file
41
.github/workflows/codeql.yml
vendored
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
name: "CodeQL"
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [ "main" ]
|
||||||
|
pull_request:
|
||||||
|
branches: [ "main" ]
|
||||||
|
schedule:
|
||||||
|
- cron: "23 20 * * 6"
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
analyze:
|
||||||
|
name: Analyze
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
permissions:
|
||||||
|
actions: read
|
||||||
|
contents: read
|
||||||
|
security-events: write
|
||||||
|
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
language: [ python ]
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Initialize CodeQL
|
||||||
|
uses: github/codeql-action/init@v2
|
||||||
|
with:
|
||||||
|
languages: ${{ matrix.language }}
|
||||||
|
queries: +security-and-quality
|
||||||
|
|
||||||
|
- name: Autobuild
|
||||||
|
uses: github/codeql-action/autobuild@v2
|
||||||
|
|
||||||
|
- name: Perform CodeQL Analysis
|
||||||
|
uses: github/codeql-action/analyze@v2
|
||||||
|
with:
|
||||||
|
category: "/language:${{ matrix.language }}"
|
||||||
@@ -27,6 +27,12 @@ ENV WHITELIST_USERS ''
|
|||||||
|
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
|
RUN apt-get update && \
|
||||||
|
apt-get install -y --no-install-recommends \
|
||||||
|
build-essential && \
|
||||||
|
apt-get clean && \
|
||||||
|
rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
COPY ./requirements.txt ./
|
COPY ./requirements.txt ./
|
||||||
RUN pip install --no-cache-dir -r requirements.txt
|
RUN pip install --no-cache-dir -r requirements.txt
|
||||||
|
|
||||||
|
|||||||
27
src/plex.py
27
src/plex.py
@@ -1,4 +1,5 @@
|
|||||||
import re, requests
|
import re, requests
|
||||||
|
from urllib3.poolmanager import PoolManager
|
||||||
|
|
||||||
from plexapi.server import PlexServer
|
from plexapi.server import PlexServer
|
||||||
from plexapi.myplex import MyPlexAccount
|
from plexapi.myplex import MyPlexAccount
|
||||||
@@ -11,6 +12,14 @@ from src.functions import (
|
|||||||
future_thread_executor,
|
future_thread_executor,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Bypass hostname validation for ssl. Taken from https://github.com/pkkid/python-plexapi/issues/143#issuecomment-775485186
|
||||||
|
class HostNameIgnoringAdapter(requests.adapters.HTTPAdapter):
|
||||||
|
def init_poolmanager(self, connections, maxsize, block=..., **pool_kwargs):
|
||||||
|
self.poolmanager = PoolManager(num_pools=connections,
|
||||||
|
maxsize=maxsize,
|
||||||
|
block=block,
|
||||||
|
assert_hostname=False,
|
||||||
|
**pool_kwargs)
|
||||||
|
|
||||||
def get_user_watched(user, user_plex, library):
|
def get_user_watched(user, user_plex, library):
|
||||||
try:
|
try:
|
||||||
@@ -252,20 +261,22 @@ class Plex:
|
|||||||
self.username = username
|
self.username = username
|
||||||
self.password = password
|
self.password = password
|
||||||
self.servername = servername
|
self.servername = servername
|
||||||
self.plex = self.login(ssl_bypass)
|
self.ssl_bypass = ssl_bypass
|
||||||
|
self.plex = self.login(self.baseurl, self.token, ssl_bypass)
|
||||||
self.admin_user = self.plex.myPlexAccount()
|
self.admin_user = self.plex.myPlexAccount()
|
||||||
self.users = self.get_users()
|
self.users = self.get_users()
|
||||||
|
|
||||||
def login(self, ssl_bypass=False):
|
def login(self, baseurl, token, ssl_bypass=False):
|
||||||
try:
|
try:
|
||||||
if self.baseurl and self.token:
|
if baseurl and token:
|
||||||
# Login via token
|
# Login via token
|
||||||
if ssl_bypass:
|
if ssl_bypass:
|
||||||
session = requests.Session()
|
session = requests.Session()
|
||||||
session.verify = False
|
# By pass ssl hostname check https://github.com/pkkid/python-plexapi/issues/143#issuecomment-775485186
|
||||||
plex = PlexServer(self.baseurl, self.token, session=session)
|
session.mount("https://", HostNameIgnoringAdapter())
|
||||||
|
plex = PlexServer(baseurl, token, session=session)
|
||||||
else:
|
else:
|
||||||
plex = PlexServer(self.baseurl, self.token)
|
plex = PlexServer(baseurl, token)
|
||||||
elif self.username and self.password and self.servername:
|
elif self.username and self.password and self.servername:
|
||||||
# Login via plex account
|
# Login via plex account
|
||||||
account = MyPlexAccount(self.username, self.password)
|
account = MyPlexAccount(self.username, self.password)
|
||||||
@@ -312,8 +323,8 @@ class Plex:
|
|||||||
if self.admin_user == user:
|
if self.admin_user == user:
|
||||||
user_plex = self.plex
|
user_plex = self.plex
|
||||||
else:
|
else:
|
||||||
user_plex = PlexServer(
|
user_plex = self.login(
|
||||||
self.plex._baseurl, user.get_token(self.plex.machineIdentifier)
|
self.plex._baseurl, user.get_token(self.plex.machineIdentifier), self.ssl_bypass
|
||||||
)
|
)
|
||||||
|
|
||||||
libraries = user_plex.library.sections()
|
libraries = user_plex.library.sections()
|
||||||
|
|||||||
Reference in New Issue
Block a user