this post was submitted on 22 Sep 2024
706 points (98.4% liked)

Technology

59438 readers
3439 users here now

This is a most excellent place for technology news and articles.


Our Rules


  1. Follow the lemmy.world rules.
  2. Only tech related content.
  3. Be excellent to each another!
  4. Mod approved content bots can post up to 10 articles per day.
  5. Threads asking for personal tech support may be deleted.
  6. Politics threads may be removed.
  7. No memes allowed as posts, OK to post as comments.
  8. Only approved bots from the list below, to ask if your bot can be added please contact us.
  9. Check for duplicates before posting, duplicates may be removed

Approved Bots


founded 1 year ago
MODERATORS
 

cross-posted from: https://discuss.tchncs.de/post/22423685

EDIT: For those who are too lazy to click the link, this is what it says

Hello,

Sad news for everyone. YouTube/Google has patched the latest workaround that we had in order to restore the video playback functionality.

Right now we have no other solutions/fixes. You may be able to get Invidious working on residential IP addresses (like at home) but on datacenter IP addresses Invidious won't work anymore.

If you are interested to install Invidious at home, we remind you that we have a guide for that here: https://docs.invidious.io/installation/..

This is not the death of this project. We will still try to find new solutions, but this might take time, months probably.

I have updated the public instance list in order to reflect on the working public instances: https://instances.invidious.io. Please don't abuse them since the number is really low.

Feel free to discuss this politely on Matrix or IRC.

you are viewing a single comment's thread
view the rest of the comments
[–] flop_leash_973@lemmy.world 83 points 1 month ago* (last edited 1 month ago) (4 children)

YouTube will not change until people stop using it. And people do not want to put up with the inconvenience of not having a YouTube type service again for the amount of time it would take for YouTube to change or a viable competitor to take their place, it really is that simple.

Are YouTube and Google terrible? For sure, but it only got this way because the only backstop to holding them accountable, the consumer, has proven that they will choose putting up with shitty products and services in the name of convenience 9 times out of 10.

Same reasons that ad tiers are gaining a foothold in streaming services like Netflix. The consumer has shown they are fine with it.

[–] Petter1@lemm.ee 20 points 1 month ago (2 children)

Time to pirate YT content and upload to usenet to be automatically downloaded using sonarr

[–] Gutless2615@ttrpg.network 8 points 1 month ago (3 children)

Yes but literally throwing together a script to download the days subscription videos to a jellyfin media drive would be stupidly simple.

[–] Petter1@lemm.ee 5 points 1 month ago

Sure, but not as convenient 🤷🏻

[–] speeding_slug@feddit.nl 4 points 1 month ago* (last edited 1 month ago) (1 children)

It already exists, even as a Docker. Not as simple as an *arr style interface, but it works great one you set it up.

ytdl-sub

[–] Gutless2615@ttrpg.network 2 points 1 month ago

Well you know what they say “Great minds think quicker than mine and probably have already had that thought.”

[–] irreticent@lemmy.world 3 points 1 month ago (1 children)

"Stupidly simple" might be overselling it when it comes to the masses adopting it. Not everyone is adept at "throwing together a script."

That being said, I'm all for helping the masses adapt.

[–] Gutless2615@ttrpg.network 4 points 1 month ago (1 children)

“Give me a Python script using yt-dlp that I can run on a cronjob that will download the videos from any of my subscribed channels since the last time the script was run”

You can use the following Python script to download videos from your subscribed channels since the last run. This script uses yt-dlp and stores the last download timestamp to track new videos.

First, ensure you have yt-dlp installed:

pip install yt-dlp

Then, create a script called download_videos.py:

import os
import json
import subprocess
from datetime import datetime

# Configuration
last_run_file = 'last_run.json'
download_directory = 'downloads'

# Ensure the download directory exists
os.makedirs(download_directory, exist_ok=True)

# Load the last run time
if os.path.exists(last_run_file):
    with open(last_run_file, 'r') as f:
        last_run = json.load(f)['last_run']
else:
    last_run = datetime.now().isoformat()

# Update the last run time to now
current_run = datetime.now().isoformat()

# Command to get videos from subscribed channels since the last run
command = [
    'yt-dlp',
    '--download-archive', 'archive.txt',
    '--output', f'{download_directory}/%(title)s.%(ext)s',
    '--date-after', last_run,
    '--no-post-overwrites',
    '--merge-output-format', 'mp4',
    'https://www.youtube.com/channel/CHANNEL_ID',  # Replace with your channel URL
]

# Run the command
subprocess.run(command)

# Save the current run time
with open(last_run_file, 'w') as f:
    json.dump({'last_run': current_run}, f)

print("Download complete. Next run will check for videos since:", current_run)

Setting Up the Cron Job

  1. Make the script executable:

    chmod +x download_videos.py
    
  2. Open your crontab:

    crontab -e
    
  3. Add a line to run the script at your desired interval (e.g., daily at 2 AM):

    0 2 * * * /path/to/python /path/to/download_videos.py
    

Notes

  • Replace CHANNEL_ID in the script with your actual channel IDs or use a playlist URL if preferred.
  • The archive.txt file keeps track of already downloaded videos to avoid duplicates.
  • Adjust the paths to Python and your script as needed.
[–] webghost0101@sopuli.xyz 2 points 1 month ago* (last edited 1 month ago) (1 children)

Another example, which i can personally verify has been working fine for months. It works a bit different to the above, it downloads the latests 2* vids that are not already downloaded and runs once every hour with cron. I also attempted to filter out live vids and shorts.

Channels i am "subscribed" too are stored in a single text file, it also uses the avc1 codec because i found p9 and p10 had issues with the jellyfin client on my tv.

looks like this, i added categories but i don't actually use them in the script besides putting them in a variable, lol. Vid-limit is how many of the latests vids it should look at to download. The original reason i implemented that is so i could selectively download a bulk of latests vids if i wanted to.

Cat=Science
Name=Vertitasium
VidLimit=2
URL=https://www.youtube.com/channel/UCHnyfMqiRRG1u-2MsSQLbXA

Cat=Minecraft
Name=EthosLab
VidLimit=2
URL=https://www.youtube.com/channel/UCFKDEp9si4RmHFWJW1vYsMA
#!/bin/bash


# Define the directory to store channel lists and scripts
script_dir="/.../YTDL"

# Define the base directory to store downloaded videos
base_download_dir="/.../youtubevids"

# Change to the script directory
cd "$script_dir"

# Parse the Channels.txt file and process each channel
awk -F'=' '
  /^Cat/ {Cat=$2}
  /^Name/ {Name=$2}
  /^VidLimit/ {VidLimit=$2}
  /^URL/ {URL=$2; print Cat, Name, VidLimit, URL}
' "$script_dir/Channels.txt" | while read -r Cat Name VidLimit URL; do
    # Define the download directory for this channel
    download_dir="$base_download_dir"
    
    # Define the download archive file for this channel
    archive_file="$script_dir/DLarchive$Name.txt"
    
    # Create the download directory if it does not exist
    mkdir -p "$download_dir"
    
    # If VidLimit is "ALL", set playlist_end option to empty, otherwise set it to --playlist-end <VidLimit>
    playlist_end_option=""
    if [[ $VidLimit != "ALL" ]]; then
        playlist_end_option="--playlist-end $VidLimit"
    fi
yt-dlp \
        --download-archive "$archive_file" \
        $playlist_end_option \
        --write-description \
        --write-thumbnail \
        --convert-thumbnails jpg \
        --add-metadata \
        --embed-thumbnail \
        --match-filter "!is_live & !was_live & original_url!*=/shorts/" \
        --merge-output-format mp4 \
        --format "bestvideo[vcodec^=avc1]+bestaudio[ext=m4a]/best[ext=mp4]/best" \
        --output "$download_dir/${Name} - %(title)s.%(ext)s" \
        "$URL"
        
done
[–] Gutless2615@ttrpg.network 1 points 1 month ago (1 children)

Yeah this is more elegant and closer to what I’d actually want to implement. I was more just showing what could be done in literally thirty seconds on the can with ChatGPT.

[–] webghost0101@sopuli.xyz 1 points 1 month ago

I knew i recognized that output.

Mine is actually also made with the help of Chatgpt but manually refined and tested.

[–] PM_Your_Nudes_Please@lemmy.world 7 points 1 month ago (1 children)

Honestly, it would probably be easier to just build a *arr program specifically for downloading YouTube videos directly. Tie it into the rest of the *arr suite, with naming conventions for Plex/Jellyfin.

[–] Petter1@lemm.ee 1 points 1 month ago

I would install that, but I fear scraping youtube will be a arms race, soon, similar to other streaming services

[–] UniversalMonk@lemmy.world 17 points 1 month ago (3 children)

Same reasons that ad tiers are gaining a foothold in streaming services like Netflix. The consumer has shown they are fine with it.

Yep, I remember when Netlfix first put it out there that they would start with the ads, and everyone on reddit was like, "Canceling my Netflix right now!!"

Netflix is doing just fine without the 5 redditors who actually did cancel it. lmao

[–] A_Random_Idiot@lemmy.world 19 points 1 month ago (3 children)

the problem is so many people are willing to say they'll take a stand.

but when the time comes, the mindnumbingly overwhelming majority suck it up, because they must have their precious shiny and can not suffer even the mildest of inconvenience.

Its my biggest gripe in gaming, but its a enormous gripe just in general, with everything. because it doesnt matter if you are talking about appliances, creative software, video games, streaming services, stores, etc.

[–] D_Air1@lemmy.ml 2 points 1 month ago (1 children)

To summarize what I was telling another person. The number of people who care are far outnumbered by the number of people who don't. It doesn't matter if you or I or all 10,000 (just a random number for the sake of argument) of the people subscribed to a sub like this were to cancel when r/justworks or r/normie (made up subreddits for the sake of argument) has 100,000,000 who don't give a damn about computers, privacy, or anything else beyond the service working or not.

[–] setsneedtofeed@lemmy.world 3 points 1 month ago (1 children)

I agree. Tech communities have a habit of drastically over estimating how much everyone else cares about the details of tech.

Even something as simple as PC gaming scares off a lot of people because of the perception that you need to be some kind of tech wizard in order to cobble everything together to make a game run. Actual cobbling together of software to pirate (no matter how simple it seems to people in the know) is just a bunch of technobabble.

[–] D_Air1@lemmy.ml 1 points 1 month ago (1 children)

I have people whom I still need to explain copy and paste to on a regular basis. Trust me, I understand.

[–] dan@upvote.au 1 points 1 month ago* (last edited 1 month ago)

I'm a millennial and sometimes I feel like we're the only generation that learnt how to use computers properly. Boomers / Gen X often aren't great with computers, and neither are Gen Z / Alpha since they use phones and tablets far more. There's outliers of course.

[–] Petter1@lemm.ee 1 points 1 month ago

🏴‍☠️ 🏴‍☠️🏴‍☠️

[–] KillingTimeItself@lemmy.dbzer0.com 1 points 1 month ago (1 children)

this is the primary reason i advocate for more piracy, and even legal protections for piracy, in some capacity.

It's one of the few spaces i consider to be a "truly free market" when it comes to economics.

[–] A_Random_Idiot@lemmy.world 1 points 1 month ago* (last edited 1 month ago) (1 children)

I'm more and more inclined towards the idea of piracy myself as time goes on and media continues to shave itself down into more and more ridiculous, unrelated shards, that you have to subscribe to just to be able to SEE if they have what you want.

I don't actively do it actively since I dont really know where to begin, and things I have found have been to sketch for me, or requiring memberships or even payments to join.

[–] KillingTimeItself@lemmy.dbzer0.com 1 points 1 month ago (1 children)

if you're looking for the babies first torrenting introduction, dbzer0 has a pretty comprehensive guide on it.

Might be worth looking into i2p as well, if you don't want to spend any money on it at least. Usenets and closed trackers are a weird one, usually based on memberships, but with good quality control of members and content so.

there's also the *arr stack but im sure there's a write of that one up on github or something.

[–] A_Random_Idiot@lemmy.world 1 points 1 month ago (1 children)

I poked around dbzer0 and found a few streaming sites, Nothing which carried anything i was particularly interested in.

Navigating this stuff without my ISP getting pissy is another hurdle, too.

It was much easier 20+ years ago when you just searched KaZaA or Limewire, or back when piratebay was the site (and before it got drowned in virus traps)

https://lemmy.dbzer0.com/c/piracy

check out the megathread for generic info and recommendations.

https://lemmy.dbzer0.com/post/30062 specific thread for i2p, there's plenty more information out there, you can also ask me about a few things as well.

the TL;DR for doing it without ur isp bonking u is to use a VPN, or a seedbox, which are options. Though you'll ideally want to use anonymous payment services like monero instead of something else, if you really want to be secure.

from what i understand, private trackers are generally fine and secure, aside from the fact that ur isp might not like the traffic, but that's a fault of the ISP, not the law. torrenting is perfectly legal. Though using a VPN is probably still recommended anyway.

navigating malicious software is kind of hit or miss now, but it's more likely you'll find them on bigger reaching platforms, and in actual software, rather than like, mp3s or movies. That's just basic opsec though. (again private trackers are beneficial for this reason, they have better QA and vetting)

[–] D_Air1@lemmy.ml 4 points 1 month ago (3 children)

I know you weren't using the number 5 as a hard example, but a thing that people still don't seem to realize is that the people in threads like this are the people that actually care. Even if the few thousand redditors who subscribe to a subreddit where they discussed that topic were to all (and I mean 100% of them) cancel there subscriptions. That is still only a drop in the bucket for Netflix. Losing a few thousand subscribers is still nothing if they made more money with the addition of ads.

[–] glitchdx@lemmy.world 5 points 1 month ago

these are also the people who would pay more for quality service if it was available.

[–] setsneedtofeed@lemmy.world 5 points 1 month ago (1 children)

It is interesting to me that the chorus always talking about "switching" to piracy after every incident is also intimately familiar with piracy already. Almost as if it's just people who already pirate talking to each other about how hard they are going to pirate. Meanwhile general audiences don't care.

Almost as if it’s just people who already pirate talking to each other about how hard they are going to pirate. Meanwhile general audiences don’t care.

this isn't quite true, we have seen an uptick in piracy over the last few years from the streaming service hyper diversion thats been happening for some time now.

It's probably not a lot of people, but it is still happening.

[–] dan@upvote.au 2 points 1 month ago* (last edited 1 month ago)

Losing a few thousand subscribers is still nothing if they made more money with the addition of ads.

It's the same with increasing the price of a service. Usually, the extra revenue from the price increase is far greater than the revenue loss from people that unsubscribe. If a business has a choice between a large number of customers with a small amount of profit per customer, and a small number of customers with a larger amount of profit per customer, they'll always pick the latter. Fewer customers reduces other costs, for example less support load, less bandwidth usage, etc.

[–] pooperNickel@lemm.ee 2 points 1 month ago

"Socialist Chaos Trow" lol

[–] ironsoap@lemmy.one 11 points 1 month ago (1 children)

While I agree, I have a hard time seeing how people will stop using it until the field changes. Maybe in 10 years it will the the MySpace of the sitcom era, but right now it's still growing. That growth is giving it carte blanche to manipulate the users as it sees fit. Regulation might impact it, but it's still a bit of a Goliath.

  • Compared to 2023, YouTube’s user base has grown by 20 million this year, representing a 0.74% increase. From Global media insights

Also the active user base is 2.7 billion people in 2024 from the same source above.

The alternatives are out there, but just not in the same league.

[–] AbsoluteChicagoDog@lemm.ee 4 points 1 month ago

I see we're pretending the government doesn't have regulatory power today