Skip to main content

A library to create video services

Project description



:vhs: VideoService

The library you needed to create your own Video Service

VideoService is a python library focused on the BackEnd for Video Services, such as YouTube (Note that this library is not used in YouTube, it is just an example).
VideoService uses a JSON DataBase to manage all the Videos on the server and its not dependant on external libraries to work (except for OpenCV and Lingua), all functionalities depend on bare Python libraries.

:bookmark_tabs: Table of Content


:blue_heart: Main Features

  • Managing Video Files
  • Managing Data Bases
  • Search Engine
    • Title Search
    • MultiFilter search
      • Length
      • Tags
      • Order
    • "Reputation system"

:arrow_down: Install package

Make sure you running on Python 3.12 (No support for other versions now)

PIP

  • If you want user intended version, run:pip install VideoService

  • If you want tester intended version, run: pip install VideoService[dev]

Cloning repository

  1. Clone this repository or download it
  2. Put the VideoService folder on your project folder
  3. You're good to go

:memo: Working On

Currently working on the version compatibility of the library (I will test down to 3.8)
Started debugging and doing the Example files for giving further documentation and explanation on how to use the library

I will add support for PlayLists/Series, on the next version of the library, but first we need the first deploy.
A Languages API will also be released to make it easier to have language support, instead of having the dictionaries in your own server

:clipboard: Documentation

Here is an extensive documentation of how VideoService library works and how to use it.

:bookmark_tabs: INDEX

VideoService

VIDEO SERVICE
-------------
The library you didn't know you needed 🗿

----

This library gives you all you need to create a video service, Video management,
DataBase management, and an integrated Search Engine.
VideoService : class
--------------------
Main class of Video Service library (and the only class you'll need 😉)
This class will manage all the backend of the service, and you will just
need to call it's methods when required by the server.

Parameters
----------
    DATABASE : str
    Path to the DataBase JSON file

    MINIATURES : str
    Path to the Miniatures folder

    VIDEOS : str
    Path to the Videos folder

    UPLOADS : str
    Path to the Uploads folder

    LANGUAGES : str
    Path to the languages DataBase folder

Raise
-----
    ValueError 
    If variable was not the expected type

    DataBaseNotFound
    If DataBase JSON was not found

    FolderNotFound
    If folder was not found
-----

Upload : method
---------------
Method used to upload files to the DataBase

Parameters
----------
    TITLE : str
    Title provided for the video

    VIDEO_FILENAME : str
    File name of the video

    MINIATURE_FILENAME : str, optional
    File name of the miniature for the video , by default None

    DESCRIPTION : str, optional
    Description for the video, by default None

    TAGS : list[str], optional
    Tags for the video, by default None

Raise
-----
    ValueError
    If variable was not the expected type

    FolderNotFound
    If folder was not found
-----

Save Videos : method
--------------------
Save_videos transforms the `videos` list to a dictionary to then save it
to the DataBase JSON file.
Automatically performed by the server when a new Video is uploaded.
--------------------

Delete Video : method
---------------------
Method used to delete videos from the DataBase


Parameters
----------
    VIDEO_ID : int, optional
    Index that leads to the video on the `videos` list, by default None

    VIDEO_FILENAME : str, optional
    Filename of the video, by default None

**Requires only one of both parameter**

Raise
-----
    ValueError
    If variable was not the expected type
    If no arguments are provided
-----

Query : method
--------------
Method used to perform a query

Parameters
----------
    query : str
    Contains the searched value

    order_settings : list[str | bool]
    Contains what to order with and direction

    filter_settings : dict[str, dict[str, List[str | int] | bool]]
    Contains what to filter with

    tags : list[str], optional
    Tags assigned when upload, by default None

Returns
-------
    Search : Search
    Contains all info about the query

Raise
-----
    ValueError
    WrongOrderStructure
    WrongFilterStructure
    WrongTagsStructure
    If variable was not the expected type
-----

Update likes : method
----------------------------
update_likes updates the like cound of a video from the `videos` list<br>
given specific parameters.

Parameters
----------
    number : int
    Number to add to the like count, can be positive or negative.

    VIDEO_ID : int, optional
    Index that leads to the video on the `videos` list, by default None

    VIDEO_FILENAME : str, optional
    Filename of the video, by default None

    **Requires only one of both Video related parameters**

Raise
-----
    ValueError
    If variable was not the expected type
    If no video related arguments are provided

uploads_manager

Uploads Manager
---------------
This file contains the class UploadManager, in which we can find all methods
related with file uploads to the server.
UploadManager : class
---------------------
The class Upload Manager is in charge of managing the uploads
that are done to the server.

This class creates an object containing the paths to the Uploads,
Miniatures and Videos folder and is used to move files between
folders and indexing uploaded files into the DataBase JSON.

Parameters
----------
    UPLOADS : str
    Path to the Uploads folder

    MINIATURES : str
    Path to the Miniatures folder

    VIDEOS : str
    Path to the Videos folder
----------

Upload : method
---------------
Method used to upload files to the DataBase

Parameters
----------
    videos : Videos
    Information about the Videos DataBase

    TITLE : str
    Title provided for the video

    VIDEO_FILENAME : str
    File name of the video

    MINIATURE_FILENAME : str, optional
    File name of the miniature for the video , by default None

    DESCRIPTION : str, optional
    Description for the video, by default None

    TAGS : list[str], optional
    Tags for the video, by default None

Returns
-------
    videos : Videos
    Contains all info about the DataBase

videos

Videos
------
This file contains the class Video and Videos, which are in charge of managing
the Videos DataBase.
  • Class Video

Video : class
-------------
The Video object contains all data assigned to a video on the
DataBase given when uploaded to the server.

Parameters
----------
    TITLE : str
    Title assigned to the video on upload

    VIDEO_FILENAME : str
    Name of the file of the video

    VIDEO_FILETYPE : str
    File extension of the video

    MINIATURE_FILENAME : str
    Name of the file of the miniature

    MINIATURE_FILETYPE : str
    File extension of the miniature

    UPLOAD_DATE : str
    Date when the video was uploaded

    LENGTH : int
    Duration of the video in seconds

    DESCRIPTION : str, optional
    Description provided on upload, by default None

    TAGS : list[str], optional
    Tags provided on upload, by default None

    LIKES : int, optional
    Use if Like system is used, by default None
----------

Video : property
----------------
Video object to dict

This property takes all values assigned to the object and<br>
transforms them into a dict

Returns
-------
    video_json : dict
    Contains all info about the Video object
  • Class Videos

Videos : class
--------------
The Videos object contains all the videos contained in the DataBase 
by using Video objects.

Parameters
----------
    DATABASE : str
    Path to the DataBase JSON file

    MINIATURES : str
    Path to the Miniatures folder

    VIDEOS : str
    Path to the Videos folder
----------

Load Videos : method
---------------------
Method used to load videos from the DataBase

Load_videos access the DataBase JSON file and loads all the data in
it to Video objects and dumps them into a list.

Returns
-------
    videos : list[Video]
    Contains all info about the DataBase
-------

Save Videos : method
--------------------
Method used to save videos to the DataBase

Save_videos transforms the videos list to a dictionary to then save
it to the DataBase JSON file.

Returns
-------
    videos : list[Video]
    Contains all info about the DataBase
-------

Add Videos : method
-------------------
Method used to add videos to the DataBase

Add_video creates a new Video object and appends it to the videos
list. It then uses save_video function to save the new video added
to the DataBase.

Parameters
----------
    TITLE : str
    Title assigned to the video on upload

    VIDEO_FILENAME : str
    Name of the file of the video

    VIDEO_FILETYPE : str
    File extension of the video

    MINIATURE_FILENAME : str
    Name of the file of the miniature

    MINIATURE_FILETYPE : str
    File extension of the miniature

    UPLOAD_DATE : str
    Date when the video was uploaded

    LENGTH : int
    Duration of the video in seconds

    DESCRIPTION : str, optional
    Description provided on upload, by default None

    TAGS : list[str], optional
    Tags provided on upload, by default None

    LIKES : int, optional
    Use if Like system is used, by default None
----------

Delete Video : method
---------------------
Method used to delete videos from the DataBase

Delete_video deletes a video from the videos list given specific parameters.

Parameters
----------
    VIDEO_ID : int, optional
    Index that leads to the video on the videos list, by default None

    VIDEO_FILENAME : str, optional
    Filename of the video, by default None

-> Requires only one of both parameter

Raise
-----
    IndexError
    If VIDEO_ID is not in range of amount of videos

    Exception (on self.__get_by_name)
    If VIDEO_FILENAME is not in database
-----

Like count : method
-------------------
Like_count updates the like cound of a video from the `videos` list<br>
given specific parameters.

Parameters
----------
    number : int
    Number to add to the like count, can be positive or negative.

    VIDEO_ID : int, optional
    Index that leads to the video on the `videos` list, by default None

    VIDEO_FILENAME : str, optional
    Filename of the video, by default None

    **Requires only one of both Video related parameters**

Raise
-----
    IndexError
    If VIDEO_ID is not in range of amount of videos

    Exception (on self.__get_by_name)
    If VIDEO_FILENAME is not in database
-----

SearchEngine

SEARCH ENGINE
-------------
Use the custom search engine designed by Dtar380 for the VideoService library
Multilingual search engine based on percentage of coincidence of a query, with
the ability to filter and order results as user desires. Giving the ability to
the user to change query parameters as fast as possible thanks to the Search
class objects implementation.

search_engine.py

search_engine.py
----------------
Containing all functions of the search engine, this is where your search takes
place.
  • Class QueryWords

QueryWords : class
------------------
The QueryWords class contains the weights for each type of word.
A QueryWords object contains the words of the query divided in
each category as well as the max weight it can have.

Parameters
----------
    query : str
    Contains the searched value

    language_dict : dict
    Contains a dictionary of the language of the query
----------
  • Functions

Search : method
---------------
Function used to perform a search

Parameters
----------
    videos : list[Video]
    Contains all info about the DataBase

    query : str
    Contains the searched value

    languages_path : str
    Path to the languages DataBase

Returns
-------
    videos : list[Video]
    Contains all info about the DataBase
-------

Order : method
--------------
Function used to order the videos

Parameters
----------
    videos : list[Video]
    Contains all info about the DataBase

    order_settings : list[str | bool]
    Contains what to order with and direction

    title : str, optional
    Query, by default None

    tags : list[str], optional
    Tags assigned when upload, by default None

Returns
-------
    videos : list[Video]
    Contains all info about the DataBase
-------

Filter : method
---------------
Function used to filter the videos

Parameters
----------
    videos : list[Video]
    Contains all info about the DataBase

    filter_settings : dict[str, dict[str, List[str | int] | bool]]
    Contains what to filter with

Returns
-------
    videos : list[Video]
    Contains all info about the DataBase
-------

Class Search

Search : class
--------------
A Search object is created when ever a search is performed 
by a user, and it contains all info about the query.

Parameters
----------
    query : str
    Contains the searched value

    videos : list[Video]
    Contains all info about the DataBase

    languages_path : str
    Path to the languages DataBase

    order_settings : list[str | bool]
    Contains what to order with and direction
    Default, by Title coincidence descendant

    filter_settings : dict[str, dict[str, List[str | int] | bool]]
    Contains what to filter with
    Default, deactivated every filter

    tags : list[str], optional
    Tags assigned when upload, by default None
----------

Query Server : method
---------------------
Use when want to perform a query to the server.
Sets the class variable `result` to the result of
the query.
----------

Tags Change : method
--------------------
Use when user changed the tags of the query.
Automatically changes the result of the query.

Parameters
----------
    tags : list[str]
    Tags searched for the video

Raise
-----
    WrongTagsStructure
    If variable was not the expected type
-----

Order Settings Change : method
------------------------------
Use when user changed order settings. Automatically
changes the result of the query.

Parameters
----------
    order_settings : list[str | bool]
    List containing the parameter to use and way to order
    If Second Value True descendant order if False ascendant

Raise
-----
    WrongOrderStructure
    If variable was not the expected type
-----

Filter Settings Change : method
-------------------------------
Use when user changed filter settings. Automatically 
changes the result of the query.

Parameters
----------
    filter_settings : dict[str, dict[str, List[str | int] | bool]]
    Dict containing the parameters to use

Raise
-----
    WrongFilterStructure
    If variable was not the expected type
-----

Query Settings

order_setting structure:
[
    str,
    True | False
]

order types:
"_order_by_title_coincidence"
"_order_by_date"
"_order_by_length"
"_order_by_tags_coincidence"
"_order_by_popularity"

-------------------------
filter_setting structure:
{
"_filter_by_date": {
    "filter": List[str],
    "active": True | False
    },
"_filter_by_length": {
    "filter": List[int],
    "active": True | False
    },
"_filter_by_tags": {
    "filter": List[str],
    "active": True | False
    }
}

:open_file_folder: Known Issues

As there hasn't been a deploy yet, Im not trying to find bugs, Im just coding and testing

:scroll: License

VideoService is distributed under the license MIT.
See the LICENSE file for more information.

:money_with_wings: Sponsorship

You can support me and the project with a donation to my Ko-Fi

ko-fi

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

videoservice-0.1.1.tar.gz (6.8 kB view details)

Uploaded Source

Built Distribution

VideoService-0.1.1-py3-none-any.whl (6.1 kB view details)

Uploaded Python 3

File details

Details for the file videoservice-0.1.1.tar.gz.

File metadata

  • Download URL: videoservice-0.1.1.tar.gz
  • Upload date:
  • Size: 6.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.19

File hashes

Hashes for videoservice-0.1.1.tar.gz
Algorithm Hash digest
SHA256 ad00d1aa2c10e3fe8b5da5011b65bb641489e6b23d55b357d70335e4ece94936
MD5 69111a143e6d844eba35bd3b3feca0fc
BLAKE2b-256 e1823472e9c28c35ec4277c2f0dea8f6558f5b9d85173a4db2d137f24a1d921c

See more details on using hashes here.

File details

Details for the file VideoService-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for VideoService-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1b423f5bb5938f577d4bd6989179a85972b97132011cca2cd87d68b0dbd835ed
MD5 8220415c1edbe63d7136c6b6410da311
BLAKE2b-256 d8eaf3cf21ea39a666055d463c19bd9e028a6370b52e42632b94e59af9a3dc47

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page