$ pip install devine
Note
If pip gives you a warning about a path not being in your PATH environment variable then promptly add that path then
close all open command prompt/terminal windows, or devine
won't work as it will not be found.
Voilà ? — You now have the devine
package installed!
A command-line interface is now available, try devine --help
.
The following is a list of programs that need to be installed by you manually.
.mkv
file.Tip
You should install these from a Package Repository if you can; including winget/chocolatey on Windows. They will
automatically add the binary's path to your PATH
environment variable and will be easier to update in the future.
Important
Most of these dependencies are portable utilities and therefore do not use installers. If you do not install them
from a package repository like winget/choco/pacman then make sure you put them in your current working directory, in
Devine's installation directory, or the binary's path into your PATH
environment variable. If you do not do this
then Devine will not be able to find the binaries.
First, take a look at devine --help
for a full help document, listing all commands available and giving you more
information on what can be done with Devine.
Here's a checklist on what I recommend getting started with, in no particular order,
devine dl
.devine cfg tag NOGRP
for ...-NOGRP
.And here's some more advanced things you could take a look at,
Documentation on the config is available in the CONFIG.md file, it has a lot of handy settings.
If you start to get sick of putting something in your CLI call, then I recommend taking a look at it!
Unlike similar project's such as youtube-dl, Devine does not currently come with any Services. You must develop your own Services and only use Devine with Services you have the legal right to do so.
Note
If you made a Service for Devine that does not use Widevine or any other DRM systems, feel free to make a Pull Request and make your service available to others. Any Service on youtube-dl (or yt-dlp) would be able to be added to the Devine repository as they both use the Unlicense license therefore direct reading and porting of their code would be legal.
Warning
Only create or use Service Code with Services you have full legal right to do so.
A Service consists of a folder with an __init__.py
file. The file must contain a class of the same name as the folder.
The class must inherit the Service class and implement all the abstracted methods. It must finally implement a new
method named cli
where you define CLI arguments.
/devine/services
. The folder name you choose will be what's known as the Service Tag.
This "tag" is used in the final output filename of downloaded files, for various code-checks, lookup keys in
key-vault databases, and more.__init__.py
file and write a class inheriting the Service class. It must be named
the exact same as the folder. It is case-sensitive.cli
method. This method must be static (i.e. @staticmethod
). For example
to implement the bare minimum to receive a Title ID of sorts:
@staticmethod
@click.command(name="YT", short_help="https://youtube.com", help=__doc__)
@click.argument("title", type=str)
@click.pass_context
def cli(ctx, **kwargs):
return YT(ctx, **kwargs)
cli
method, even if you do not want or need any CLI arguments. It is required for the core
CLI functionality to be able to find and call the class.__init__()
method):
def __init__(self, ctx, title):
self.title = title
super().__init__(ctx) # important
# ... the title is now available across all methods by calling self.title
Note
Service
marked as abstract (@abstractmethod
) MUST be implemented by
your class.__init__()
method) you MUST super call it, e.g., super().__init__()
at the
top of the override. This does not apply to any abstract methods, as they are unimplemented.get_session
method,
then modify self.session
. Do not manually make self.session
from scratch.Tip
self.session
class instance variable, e.g. self.session.get(url)
.config.yaml
file next to your __init__.py
, you can access it with self.config
.Service tags generally follow these rules:
[A-Z0-9i]{2,4}
.
i
is only used for select services. Specifically BBC iPlayer and iTunes.+
or Plus
, the last character should be a P
.
E.g., ATVP
for Apple TV+
, DSCP
for Discovery+
, DSNP
for Disney+
, and PMTP
for Paramount+
.These rules are not exhaustive and should only be used as a guide. You don't strictly have to follow these rules, but I recommend doing so for consistency.
Sending and receiving zipped Service folders is quite cumbersome. Let's explore alternative routes to collaborating on Service Code.
Warning
Please be careful with who you trust and what you run. The users you collaborate with on Service code could update it with malicious code that you would run via devine on the next call.
If you are collaborating with a team on multiple services then forking the project is the best way to go.
git clone <your repo url here>
and then cd
into it.git remote add upstream https://github.com/devine-dl/devine
git remote set-url --push upstream DISABLE
git fetch upstream
git pull upstream master
git reset --hard v1.0.0
.Now commit your Services or other changes to your forked repository.
Once committed all your other team members can easily pull changes as well as push new changes.
When a new update comes out you can easily rebase your fork to that commit to update.
git fetch upstream
git rebase upstream/master
However, please make sure you look at changes between each version before rebasing and resolve any breaking changes and deprecations when rebasing to a new version.
If you are new to git
then take a look at GitHub Desktop.
Tip
A huge benefit with this method is that you can also sync dependencies by your own Services as well!
Just use poetry
to add or modify dependencies appropriately and commit the changed poetry.lock
.
However, if the core project also has dependency changes your poetry.lock
changes will conflict and you
will need to learn how to do conflict resolution/rebasing. It is worth it though!
This is a great option for those who wish to do something like the forking method, but may not care what changes happened or when and just want changes synced across a team.
This also opens up the ways you can host or collaborate on Service code. As long as you can receive a directory that updates with just the services within it, then you're good to go. Options could include an FTP server, Shared Google Drive, a non-fork repository with just services, and more.
services
directory somewhere in it and have all your services within it.services
directory to the /devine
folder. You should
end up with /devine/services
folder containing services, not /devine/services/services
.You have to make sure the original folder keeps receiving and downloading/streaming those changes. You must also make sure that the version of devine you have locally is supported by the Service code.
Note
If you're using a cloud source that downloads the file once it gets opened, you don't have to worry as those will automatically download. Python importing the files triggers the download to begin. However, it may cause a delay on startup.
Devine can authenticate with Services using Cookies and/or Credentials. Credentials are stored in the config, and
Cookies are stored in the data directory which can be found by running devine env info
.
To add a Credential to a Service, take a look at the Credentials Config
for information on setting up one or more credentials per-service. You can add one or more Credential per-service and
use -p/--profile
to choose which Credential to use.
To add a Cookie to a Service, use a Cookie file extension to make a cookies.txt
file and move it into the Cookies
directory. You must rename the cookies.txt
file to that of the Service tag (case-sensitive), e.g., NF.txt
. You can
also place it in a Service Cookie folder, e.g., /Cookies/NF/default.txt
or /Cookies/NF/.txt
.
You can add multiple Cookies to the /Cookies/NF/
folder with their own unique name and then use -p/--profile
to
choose which one to use. E.g., /Cookies/NF/sam.txt
and then use it with --profile sam
. If you make a Service Cookie
folder without a .txt
or default.txt
, but with another file, then no Cookies will be loaded unless you use
-p/--profile
like shown. This allows you to opt in to authentication at whim.
Tip
-p/--profile
.Warning
Profile names are case-sensitive and unique per-service. They have no arbitrary character or length limit, but for convenience sake I don't recommend using any special characters as your terminal may get confused.
Cookies must be in the standard Netscape cookies file format.
Recommended Cookie exporter extensions:
Rotem Dan
Ninh Pham
, Rahul Shaw
Any other extension that exports to the standard Netscape format should theoretically work.
Warning The Get cookies.txt extension by Rahul Shaw is essentially spyware. Do not use it. There are some safe versions floating around (usually just older versions of the extension), but since there are safe alternatives I'd just avoid it altogether. Source: https://reddit.com/r/youtubedl/comments/10ar7o7
A Widevine Provision is needed for acquiring licenses containing decryption keys for DRM-protected content. They are not needed if you will be using devine on DRM-free services. Please do not ask for any Widevine Device Files, Keys, or Provisions as they cannot be provided.
Devine only supports .WVD
files (Widevine Device Files). However, if you have the Provision RSA Private Key and
Device Client Identification Blob as blob files (e.g., device_private_key
and device_client_id_blob
), then you can
convert them to a .WVD
file by running pywidevine create-device --help
.
Once you have .WVD
files, place them in the WVDs directory which can be found by calling devine env info
.
You can then set in your config which WVD (by filename only) to use by default with devine cfg cdm.default wvd_name
.
From here you can then set which WVD to use for each specific service. It's best to use the lowest security-level
provision where possible.
An alternative would be using a pywidevine Serve-compliant CDM API. Of course, you would need to know someone who is serving one, and they would need to give you access. Take a look at the remote_cdm config option for setup information. For further information on it see the pywidevine repository.
Devine and it's community pages should be treated with the same kindness as other projects. Please refrain from spam or asking for questions that infringe upon a Service's End User License Agreement.
This software is licensed under the terms of GNU General Public License, Version 3.0.
You can find a copy of the license in the LICENSE file in the root folder.
© rlaphoenix 2019-2024