an unofficial REST API for Reddit that mimics the official Reddit API by scraping data from Reddit. This project aims to provide an alternative way to access Reddit data without incurring high API ...
I am making a Unofficial Reddit API, which mimics the official one.
Its early days, but I would like to have a discussion here about it since my post was blocked on reddit(of course).
Let me know what you think of the project, if you have any input, let me know.
API access was only half the problem. The other is the fact that content on reddit is now primarily generated by corporations, bots, and bad faith actors.
Going there for specific threads (e.g. help posts in programming subs) seems okay-ish, but scrolling the front page is a doomed endeavor at this point... not much different from Facebook or Instagram.
Out of curiosity, I flipped through a few days back, and it's exactly that. Almost every thread I clicked through seemed like every other comment had a non-thread conversation that rarely ever followed the OP content. So it's just a bunch of AI chatbots talking to each other about nothing. That didn't take long.
"Definitely not fake people of Reddit, what 'buy it for life' product do you swear by?"
Top answer:
"Le greetings, fellow Redditors! (The narwhal bacons, amirite???) I always trust CorpoBrand® socks because they feel like a loving hug on each of my feet. Once you try one on, you'll never want to wear any other socks. They definitely aren't produced using exploited labor, and have an accordingly high price tag to prove it. You'll want to buy 20, but they're so durable, you can take them to the grave! (Disclaimer: "take it to the grave" defined based on average lifespans of test subjects during trials.)
Bro, just stop. You'll get C&Ded. Stop thinking about reddit. Cut it out of your life. You don't need it anymore. Nobody does. We will find another way without it.
Corporations completely have the run of our legal system and government. Boeing can murder whistleblowers and get away with it for fuck sake. Op is using fucking github for this. Even common sense opsec practices wouldn't be enough. Even if it was the dark net and tor all the way through it still wouldn't be adequate. They even posted about it on reddit. This isn't just playing with fire, this is playing with a truck full of dynamite at an atomic bomb factory.
Pretty sure that on average, I write more lines of Python per day than are in this repo at the moment, and I'm not constantly under threat of a cease and decist from arriving at my doorstep.
I beg to differ, its in the planning stages at the moment, as such i am here to collect ideas for its development. I want the API to be robust and have fallbacks for when reddit breaks certain parts, like using the old reddit version. This is a big task, and it needs to be planned right.
Please don't take personal offense, but you have merely a project scaffold with an unrealistic goal that will be blocked and C&D'd into the ground, without any other projects created.
It doesn't matter how hard you're working on your anonymity, this project will be ripped apart by a horde of lawyers in seconds. You're not only doing something questionable or against ToS, you're directly attacking and sabotaging their monetization. This will not be taken lightly by the legal team of reddit.
You want to provide a better, cooler, more robust and other random buzzwords API than the own of reddit. So, you alone, want to provide a better API than the whole team of reddit does for their absolute core product, all by scraping. This is simply not realistic.
While we're at the topic of monetization, scraping, ETL into your own model and providing the API - for the amount of content that reddit has (quantity, not quality) this will be a highly resource intensive task. How do you plan to fund that, since your API will be better than the official one, I can expect at least the same performance as well, right?
And also, most importantly, even if you magically achieve working around all that and get that working - why? Who is your expected user group?
Pretty much every software using reddit moved away from reddit or simply has died.
AI gen content is rampant, and most discussions seem like bots talking to bots.
There is literally nothing to gain from an API to reddit - so why would anyone bother using it?
It's a good initiative, but is it really worth at this time?
I am not entirely sure to be honest. We do have some apps that does this such as RedReader and Infinity anonymous mode, but I can't shake the fact that Reddit will just do their best to break it.
Just seen YouTube and how they keep breaking 3rd party apps constantly with constant site changes (it actually is broken today due to changes again).
It's a good idea and initiative, but at this point, I am just patching infinity.
Redreader uses the official API, they have an exception from paying (for now) because they have accessibility features that most apps including the official one lack.
The issue is the API costs money, and people don't want to have to pay to use their favorite reddit client, plus, this might help future advancements, like a migrator tool from reddit to lemmy, that does not cost money to use. that could help lemmy adoption.
Just to add my thoughts, it was not closing free API that made me stop using Reddit. It was their management response / actions / not providing a viable API thus killing 3rd party apps. If management would have changed I would probably go back.
If I could access Reddit ad free via my own 3rd party app with no restrictions based on some monthly or yearly fee, I probably would pay that.
Reddit has issues which the fediverse solves. The fediverse has issues that Reddit solves.
Now that I am here tho, I wouldn't go back
Yup, I had been looking for alternatives for years, but none seemed "ready." When the API change was announced, my definition of "ready" suddenly changed and I came to Lemmy. It's good enough, but I'll bail as soon as something better comes along.
Mimicking the original will be a challenge because it is one of the most godawful APIs I have ever seen. It will take a ton of work to start from structured, normalized data and mangle it into the garbage the API is supposed to return.
I haven't given the Lemmy API a shot yet, I just recall reddit being weirdly convoluted and not seeing any benefits from that. The documentation was not kept well either.
Decentralization is, by definition, censorship-resistant, just hop to another instance.
There is censorship, but i think it's on par with reddit. Were i to post some of the stuff i post here on lemmy on mastodon instead i'd have my account banned. Speaking from experience.
Is there a reason you're scraping data rather than attaching a network sniffer/reverse engineering the official apps and documenting the results? Or map the RSS feed to an API? The main thrust behind my comment is that I think scraping is pretty fragile, so I'm interested as to why other options are infeasible.
This is likely to be C&D'd as well if it ever reaches the point where it does anything useful (remember, reddit doesn't need grounds that would hold up in court to send a C&D).
I suspect that any of the methods proposed here would be prone to a C&D, but IMO the safest legally would probably be the RSS method (not a lawyer though). Reddit's RSS feeds are public, documented, and available without the need for private APIs, authentication, or an API key, so I don't see how they could claim that a wrapper is unauthorised/illegal. Documenting their private API however seems like a gray area. Google LLC v. Oracle America, Inc. found that APIs are copyrightable, but this use may constitute fair use.
Because we need to retain the breadth of functionality the API has, if you want to just scrape posts, APIs for that already exist, but i am aiming for something more.
About reverse engineering, they can change that part at any time too, and may be even more fragile as they can change that without breaking the UX, if they change the front page CSS selectors or layout for example, it will effect the UX more as it changes the expected output, not the middle end that is just raw data.
Thats my reasoning, I appreciate the input though (:
Making a breaking change to the mobile API also breaks old outdated installations of the app. Websites and their APIs are usually synced, apps not so.
If they were really motivated to stop your method, they could just obfuscate the frontend with webpack and break your scraper every time they make an update.
Basically you want to write scraping solution specially for Reddit, it would be great if you started with scraping Frameworks like python scrapy framework
Pretty cool of you to do this! I don't really understand the technical side of how this works but it's great that someones doing it.
Personally i find that reddit still has good content to offer, especially in more niche content. Sure anything on r/all is 90% bots but other stuff isn't.
Now, if only to get their auto bots to stopping banning accounts for little to no reasons. If you disagree with the wrong mod or they don't like what to you say, they ban you.
My 12yr old account got banned. I'm not worried about the link karma and comment karma.