Sleazy Fork is available in English.

dp-vids.com helper

A script that lets you download videos with the click of a button and hide private videos.

// ==UserScript==
// @name        dp-vids.com helper
// @namespace   Violentmonkey Scripts
// @match       https://dp-vids.com/*
// @match       https://pnt-vids.com/*
// @grant       none
// @version     1.5
// @author      Penomancer
// @description A script that lets you download videos with the click of a button and hide private videos.
// @license MIT
// ==/UserScript==

(function waitForPageContext(callback, interval = 100) {
    const checkPageContext = setInterval(() => {
        if (typeof window.pageContext !== 'undefined') {
            clearInterval(checkPageContext);
            callback(); // Call the callback function when pageContext is defined
        }
    }, interval);



})(function() {
    'use strict';
    console.log("Starting Script")

    const originalFetch = window.fetch;
    let downloadLink = '';
    let downloadLinkToUse = '';
    let videoSrc = '';
    let newTabLink = '';
    const downloadLinkStarter = 'https://dp-vids.com/contents/videos/';
    const downloadLinkStarterPnt = 'https://pnt-vids.com/contents/videos/';
    const videoTitle = document.title;
    const targetClass = 'line-private';
    const regex = /\/(\d+\/\d+\/\d+\.mp4\/)$/;


    function addDownloadButton(downloadLink) {
        console.log("Download link for button:", downloadLink)
        const tabsMenu = document.querySelector('.tabs-menu');
        if (tabsMenu) {
            const tabsMenuList = tabsMenu.querySelector('ul');
            const newTab = document.createElement('li');
            tabsMenuList.prepend(newTab);

            const linkElement = document.createElement('a');
            linkElement.textContent = 'Download';
            linkElement.href = downloadLink;
            linkElement.target = '_blank';
            linkElement.className = "toggle-button"
            linkElement.download = videoTitle
            newTab.appendChild(linkElement);
        } else {
            console.error("Parent element not found.");
        }
    }

    function removeTargetDivs() {
        const divs = document.querySelectorAll(`.${targetClass}`);
        divs.forEach(div => div.remove());
    }



    if (window.location.href.includes("/videos") || window.location.href.includes("/video") ) {
    console.log("Videos Found")
const jsonLdScript = document.querySelector('script[type="application/ld+json"]');

if (jsonLdScript) {
    try {
        const jsonData = JSON.parse(jsonLdScript.textContent);

        const videoName = jsonData.name;
        const videoDescription = jsonData.description;
        const thumbnailUrl = jsonData.thumbnailUrl;
        const uploadDate = jsonData.uploadDate;
        const duration = jsonData.duration;
        const contentUrl = jsonData.contentUrl;

        console.log("Video Name:", videoName);
        console.log("Description:", videoDescription);
        console.log("Thumbnail URL:", thumbnailUrl);
        console.log("Upload Date:", uploadDate);
        console.log("Duration:", duration);
        console.log("Content URL:", contentUrl);

        downloadLink = contentUrl
    } catch (error) {
        console.error("Error parsing JSON-LD data:", error);
    }
} else {
    console.error("JSON-LD script tag not found.");
}
    const noPlayerElements = document.querySelectorAll('.no-player');
    if (noPlayerElements.length > 0) {
      console.log("Found 'no-player' elements on the page.");
      noPlayerElements.forEach(element => {
      element.innerHTML = `<video width="100%" height="auto"  controls name="media"><source src="${downloadLink}" type="video/mp4"></video>`;
  });
    } else {
      console.log("Didn't find no-player elements on the page.")
    }
const match = downloadLink.match(regex);
    let extractedPart = match[1]; // This will give you the '8000/8024/8024.mp4/'
    extractedPart = extractedPart.slice(0, -1);
    if (window.location.href.includes("dp")){
    downloadLink = downloadLinkStarter + extractedPart
        } else {
      downloadLink = downloadLinkStarterPnt + extractedPart
    }
    console.log("Extracted part:", extractedPart);


    console.log("Download Link:", downloadLink)

    addDownloadButton(downloadLink);
                }

        removeTargetDivs();
        const observer = new MutationObserver(removeTargetDivs);
        observer.observe(document.body, { childList: true, subtree: true, attributes: true });

})();