Skip to main content

CLI to download videos from https://xvideos.com

Project description

xvideos-dl

Build status Python Version Dependencies Status

Code style: black Security: bandit Pre-commit Semantic Versions License

CLI to download videos from https://xvideos.com

Features

  • Download a single video (requires the URL of the video playback page)
  • Download all videos in the favorites (requires the URL of the favorite page)
  • Download all videos uploaded by the user (requires the URL of the user's homepage)
  • Download all videos published by the channel (requires the URL of the channel homepage)
  • Segmented high-speed download, breakpoint download, progress and status display

Usage

⚠️Requires:

  • Python: >= 3.6.1
  • Cookie: When you run it for the first time, you will be prompted to enter the cookie, log in https://xvideos.com with your account, copy and paste a long string of cookies, then enjoy it.

Cookie is stored in ~/.xvideos/cookie (or C:\Users<USER>\cookie).

  • Install xvideos-dl
pip install -U xvideos-dl
  • Get CLI help
xvideos-dl --help
  • Download single / favorites / uploaded / published videos in one command:
xvideos-dl https://www.xvideos.com/video37177493/asian_webcam_2_camsex4u.life https://www.xvideos.com/favorite/71879935/_ https://www.xvideos.com/profiles/mypornstation https://www.xvideos.com/channels/av69tv  

Release History

1.2.0

  • Support Python 3.6.1+

1.1.2

Bugfix:

  • Fixed a bug that would not retry when the network connection failed.

1.1.1

New Feature:

  • Add parameters to control the start and end of the video in the download list.

Others:

  • When running the same command repeatedly, quickly skip the downloaded video.
  • Catch exceptions: 404 not found, forbidden downloading...

1.1.0

New Features:

  • Download all videos uploaded by users.
  • Download all videos posted by the channel.
  • Download single, playlist, user uploaded and channel posted videos in one command.
  • Optimize download status display.

1.0.1

New Features:

  • Download videos from favorites.
  • Show download speed.

1.0.0

Initial release on PyPY.


For Contributors

Initial

  1. Fork and clone this repo:
git clone https://github.com/lonsty/xvideos-dl
  1. If you don't have Poetry installed run:
make download-poetry
  1. Initialize poetry and install pre-commit hooks:
make install

Makefile usage

Makefile contains many functions for fast assembling and convenient work.

1. Download Poetry

make download-poetry

2. Install all dependencies and pre-commit hooks

make install

If you do not want to install pre-commit hooks, run the command with the NO_PRE_COMMIT flag:

make install NO_PRE_COMMIT=1

3. Check the security of your code

make check-safety

This command launches a Poetry and Pip integrity check as well as identifies security issues with Safety and Bandit. By default, the build will not crash if any of the items fail. But you can set STRICT=1 for the entire build, or you can configure strictness for each item separately.

make check-safety STRICT=1

or only for safety:

make check-safety SAFETY_STRICT=1

multiple

make check-safety PIP_STRICT=1 SAFETY_STRICT=1

List of flags for check-safety (can be set to 1 or 0): STRICT, POETRY_STRICT, PIP_STRICT, SAFETY_STRICT, BANDIT_STRICT.

4. Check the codestyle

The command is similar to check-safety but to check the code style, obviously. It uses Black, Darglint, Isort, and Mypy inside.

make check-style

It may also contain the STRICT flag.

make check-style STRICT=1

List of flags for check-style (can be set to 1 or 0): STRICT, BLACK_STRICT, DARGLINT_STRICT, ISORT_STRICT, MYPY_STRICT.

5. Run all the codestyle formaters

Codestyle uses pre-commit hooks, so ensure you've run make install before.

make codestyle

6. Run tests

make test

7. Run all the linters

make lint

the same as:

make test && make check-safety && make check-style

List of flags for lint (can be set to 1 or 0): STRICT, POETRY_STRICT, PIP_STRICT, SAFETY_STRICT, BANDIT_STRICT, BLACK_STRICT, DARGLINT_STRICT, ISORT_STRICT, MYPY_STRICT.

8. Build docker

make docker

which is equivalent to:

make docker VERSION=latest

More information here.

9. Cleanup docker

make clean_docker

or to remove all build

make clean

More information here.

📈 Releases

You can see the list of available releases on the GitHub Releases page.

We follow Semantic Versions specification.

We use Release Drafter. As pull requests are merged, a draft release is kept up-to-date listing the changes, ready to publish when you’re ready. With the categories option, you can categorize pull requests in release notes using labels.

For Pull Request this labels are configured, by default:

Label Title in Releases
enhancement, feature 🚀 Features
bug, refactoring, bugfix, fix 🔧 Fixes & Refactoring
build, ci, testing 📦 Build System & CI/CD
breaking 💥 Breaking Changes
documentation 📝 Documentation
dependencies ⬆️ Dependencies updates

You can update it in release-drafter.yml.

GitHub creates the bug, enhancement, and documentation labels for you. Dependabot creates the dependencies label. Create the remaining labels on the Issues tab of your GitHub repository, when you need them.

🛡 License

License

This project is licensed under the terms of the MIT license. See LICENSE for more details.

📃 Citation

@misc{xvideos-dl,
  author = {xvideos-dl},
  title = {CLI to download videos from https://xvideos.com},
  year = {2021},
  publisher = {GitHub},
  journal = {GitHub repository},
  howpublished = {\url{https://github.com/lonsty/xvideos-dl}}
}

Credits

This project was generated with python-package-template.

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

xvideos-dl-1.2.0.tar.gz (13.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

xvideos_dl-1.2.0-py3-none-any.whl (10.8 kB view details)

Uploaded Python 3

File details

Details for the file xvideos-dl-1.2.0.tar.gz.

File metadata

  • Download URL: xvideos-dl-1.2.0.tar.gz
  • Upload date:
  • Size: 13.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.5 CPython/3.6.12 Linux/4.19.128-microsoft-standard

File hashes

Hashes for xvideos-dl-1.2.0.tar.gz
Algorithm Hash digest
SHA256 57862943e0b8a475eb57d658578ac38716a7b9e286812ae8a3ef6aaa1648558e
MD5 92613222314622ef6c150be10c1b20af
BLAKE2b-256 5d18eacc333a01d0af4251c5f167e6797090c31532fd8541e85187af1aeb9340

See more details on using hashes here.

File details

Details for the file xvideos_dl-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: xvideos_dl-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 10.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.5 CPython/3.6.12 Linux/4.19.128-microsoft-standard

File hashes

Hashes for xvideos_dl-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d8937b5839b6d8c2449f26af5b41f40ef5eb43d79446b927c1d00a6cce5728f9
MD5 d960ce2113e15902b996b9ff5d872cd7
BLAKE2b-256 10da35378e4061f996df265d319b41b4189af1f40090665a18d5b55bb1b0ff2c

See more details on using hashes here.

Supported by

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