Skip to content
This repository has been archived by the owner on Oct 13, 2024. It is now read-only.

Commit

Permalink
feat(yt-dl): automatically gather youtube cookies
Browse files Browse the repository at this point in the history
  • Loading branch information
ReenigneArcher committed Nov 29, 2023
1 parent 673fe04 commit dd0822b
Show file tree
Hide file tree
Showing 13 changed files with 590 additions and 16 deletions.
112 changes: 101 additions & 11 deletions Contents/Code/general_helper.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,10 @@
from plexhints.log_kit import Log # log kit
from plexhints.prefs_kit import Prefs # prefs kit

# imports from Libraries\Shared
from plexapi.base import PlexPartialObject
import requests
from typing import Optional

# local imports
from constants import metadata_base_directory, metadata_type_map, themerr_data_directory
Expand All @@ -27,15 +31,15 @@


def get_media_upload_path(item, media_type):
# type: (any, str) -> str
# type: (PlexPartialObject, str) -> str
"""
Get the path to the theme upload directory.
Get the hashed path of the theme upload directory for the item specified by the ``item``.
Parameters
----------
item : any
item : PlexPartialObject
The item to get the theme upload path for.
media_type : str
The media type to get the theme upload path for. Must be one of 'art', 'posters', or 'themes'.
Expand Down Expand Up @@ -75,15 +79,15 @@ def get_media_upload_path(item, media_type):


def get_themerr_json_path(item):
# type: (any) -> str
# type: (PlexPartialObject) -> str
"""
Get the path to the Themerr data file.
Get the path to the Themerr data file for the item specified by the ``item``.
Parameters
----------
item : any
item : PlexPartialObject
The item to get the Themerr data file path for.
Returns
Expand All @@ -102,7 +106,7 @@ def get_themerr_json_path(item):


def get_themerr_json_data(item):
# type: (any) -> dict
# type: (PlexPartialObject) -> dict
"""
Get the Themerr data for the specified item.
Expand All @@ -111,7 +115,7 @@ def get_themerr_json_data(item):
Parameters
----------
item : any
item : PlexPartialObject
The item to get the Themerr data for.
Returns
Expand Down Expand Up @@ -153,16 +157,102 @@ def get_themerr_settings_hash():
return settings_hash


def get_user_country_code(ip_address=None):
# type: (Optional[str]) -> str
"""
Get the country code for the user with the given IP address.
Parameters
----------
ip_address : Optional[str]
The IP address of the user.
Returns
-------
str
The `ALPHA-2 <https://www.iban.com/country-codes>`__ country code for the user with the given IP address.
Examples
--------
>>> get_user_country_code()
'US'
"""
api_url = 'https://ipinfo.io/json'
if ip_address:
api_url = 'https://ipinfo.io/{}/json'.format(ip_address)

try:
response = requests.get(api_url)
data = response.json()
return data.get('country').encode('utf-8')
except requests.RequestException as e:
Log.Error("Could not determine user country: {}".format(e))

Check warning on line 189 in Contents/Code/general_helper.py

View check run for this annotation

Codecov / codecov/patch

Contents/Code/general_helper.py#L189

Added line #L189 was not covered by tests


def is_user_in_eu(ip_address=None):
# type: (Optional[str]) -> bool
"""
Check if the user with the given IP address is in the European Union.
Parameters
----------
ip_address : Optional[str]
The IP address of the user.
Returns
-------
bool
True if the user with the given IP address is in the European Union, False otherwise.
Examples
--------
>>> is_user_in_eu()
False
"""
eu_countries = [

Check warning on line 212 in Contents/Code/general_helper.py

View check run for this annotation

Codecov / codecov/patch

Contents/Code/general_helper.py#L212

Added line #L212 was not covered by tests
'AT', # Austria
'BE', # Belgium
'BG', # Bulgaria
'CY', # Cyprus
'CZ', # Czech Republic
'DE', # Germany
'DK', # Denmark
'EE', # Estonia
'ES', # Spain
'FI', # Finland
'FR', # France
'GR', # Greece
'HR', # Croatia
'HU', # Hungary
'IE', # Ireland
'IT', # Italy
'LT', # Lithuania
'LU', # Luxembourg
'LV', # Latvia
'MT', # Malta
'NL', # Netherlands
'PL', # Poland
'PT', # Portugal
'RO', # Romania
'SE', # Sweden
'SI', # Slovenia
'SK', # Slovakia
]

country_code = get_user_country_code(ip_address=ip_address)
return country_code in eu_countries

Check warning on line 243 in Contents/Code/general_helper.py

View check run for this annotation

Codecov / codecov/patch

Contents/Code/general_helper.py#L242-L243

Added lines #L242 - L243 were not covered by tests


def remove_uploaded_media(item, media_type):
# type: (any, str) -> None
# type: (PlexPartialObject, str) -> None
"""
Remove themes for the specified item.
Deletes the themes upload directory for the item specified by the ``item``.
Parameters
----------
item : any
item : PlexPartialObject
The item to remove the themes from.
media_type : str
The media type to remove the themes from. Must be one of 'art', 'posters', or 'themes'.
Expand Down Expand Up @@ -193,7 +283,7 @@ def remove_uploaded_media_error_handler(func, path, exc_info):
----------
func : any
The function that caused the error.
path : str
path : any
The path that caused the error.
exc_info : any
The exception information.
Expand All @@ -202,15 +292,15 @@ def remove_uploaded_media_error_handler(func, path, exc_info):


def update_themerr_data_file(item, new_themerr_data):
# type: (any, dict) -> None
# type: (PlexPartialObject, dict) -> None
"""
Update the Themerr data file for the specified item.
This updates the themerr data file after uploading media to the Plex server.
Parameters
----------
item : any
item : PlexPartialObject
The item to update the Themerr data file for.
new_themerr_data : dict
The Themerr data to update the Themerr data file with.
Expand Down
60 changes: 60 additions & 0 deletions Contents/Code/platform_helper.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
# -*- coding: utf-8 -*-

# standard imports
import os
import platform

# plex debugging
try:
import plexhints # noqa: F401
except ImportError:
pass

Check warning on line 11 in Contents/Code/platform_helper.py

View check run for this annotation

Codecov / codecov/patch

Contents/Code/platform_helper.py#L10-L11

Added lines #L10 - L11 were not covered by tests
else: # the code is running outside of Plex
from plexhints.log_kit import Log # log kit


def get_os_architecture():
# type: () -> str
"""
Get the OS architecture.
Returns
-------
str
The OS architecture. One of ``x86_64``, ``x86``, ``aarch64`` or ``Unknown architecture``.
Examples
--------
>>> get_os_architecture()
"x86_64"
"""
# Getting architecture using platform module
machine = platform.machine()

# For more detailed check, especially for Windows OS
if os.name == 'nt':
# Possible values: '32bit', '64bit'
# This will tell us if the OS is 64-bit or 32-bit
architecture = platform.architecture()

if architecture[0] == '64bit':
return 'x86_64'
elif architecture[0] == '32bit':
return 'x86'

Check warning on line 43 in Contents/Code/platform_helper.py

View check run for this annotation

Codecov / codecov/patch

Contents/Code/platform_helper.py#L42-L43

Added lines #L42 - L43 were not covered by tests
else:
return 'Unknown architecture'

Check warning on line 45 in Contents/Code/platform_helper.py

View check run for this annotation

Codecov / codecov/patch

Contents/Code/platform_helper.py#L45

Added line #L45 was not covered by tests
else:
# For Unix/Linux systems, we can rely more on platform.machine()
if machine in ['x86_64', 'AMD64']:
return 'x86_64'
elif machine in ['i386', 'i686', 'x86']:
return 'x86'
elif machine in ['aarch64', 'arm64']:
return 'aarch64'

Check warning on line 53 in Contents/Code/platform_helper.py

View check run for this annotation

Codecov / codecov/patch

Contents/Code/platform_helper.py#L50-L53

Added lines #L50 - L53 were not covered by tests
else:
return 'Unknown architecture'

Check warning on line 55 in Contents/Code/platform_helper.py

View check run for this annotation

Codecov / codecov/patch

Contents/Code/platform_helper.py#L55

Added line #L55 was not covered by tests


# constants
architecture = get_os_architecture()
os_system = platform.system().lower()
7 changes: 7 additions & 0 deletions Contents/Code/scheduled_tasks.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
# local imports
from constants import plugin_identifier
from plex_api_helper import scheduled_update
from selenium_helper import install_driver
from webapp import cache_data

# setup logging for schedule
Expand Down Expand Up @@ -107,8 +108,14 @@ def setup_scheduling():
See Also
--------
plex_api_helper.scheduled_update : Scheduled function to update the themes.
selenium_helper.install_driver : Scheduled function to install the browser driver, if required.
webapp.cache_data : Scheduled function to cache data for web dashboard.
"""
if Prefs['bool_auto_update_items']:
schedule.every(max(1, int(Prefs['int_update_browser_driver_interval']))).hours.do(

Check warning on line 115 in Contents/Code/scheduled_tasks.py

View check run for this annotation

Codecov / codecov/patch

Contents/Code/scheduled_tasks.py#L115

Added line #L115 was not covered by tests
job_func=run_threaded,
target=install_driver
)
schedule.every(max(15, int(Prefs['int_update_themes_interval']))).minutes.do(
job_func=run_threaded,
target=scheduled_update
Expand Down
Loading

0 comments on commit dd0822b

Please sign in to comment.