Stealing Storage from Telegram
ฝัง
- เผยแพร่เมื่อ 12 พ.ค. 2024
- By popular demand.
Discord: / discord
Github for code: github.com/devdetour/Telegram...
Ko-Fi: ko-fi.com/devdetour
Chapters:
00:00 Last Time
00:40 Shameless plug
0:42 Why I Didn't Do That
1:58 What/Why Telegram
2:32 Not Banned Yet
2:43 Teldrive
3:20 FUSE programs
4:36 Implementing It
6:18 Fixing It
6:34 Writing is Hard
9:48 Reading is Also Hard
10:52 Performance
11:29 TY, CYA - วิทยาศาสตร์และเทคโนโลยี
2 years ago I wanted build the exact same fuse mount thingy with telegram, but gave up since it was very very very much ambitious for my knowledge in systems file i/o operations. Really informative content, Keep em coming. Enjoyed every bit! ❤
This guy is the reason free services eventually start to cost money.
Yea specially if its out in the public then alot of people will do the same, just because something is free doesnt mean it has no expenses behind it
I was kinda surprise when I found your channel. You’re underrated for the type of content you’re making
ty you reminded me to subscribe to this amazing creator
I JUST saw your part 1 video of stealing storage from discord and your part 2 is up by the time I finished the video(uploaded an hour ago)!
1 correction, when I mention at 10:37 that Telegram is doing some encryption stuff and maybe that's why it's slow, this is incorrect. Though Telegram DOES support encryption, this was not an encrypted chat, so that wouldn't make things slow.
Another clarification, I knew what RAR was before my last video, just not that it could break files into chunks and password protect them. I guess I phrased this badly :)
The thing you mentioned is actually about end-to-end encryption (E2EE). Every chat is encrypted by default. The difference is whenever this encryption is E2E (telegram secret chats) or client-server (default).
And to add, the data is not only encrypted to the server, it’s is obfuscated by breaking it into pieces and storing it on multiple servers so if only one server is access the data is junk.
One thing I noticed in your design layout was the decision to encrypt each segment of the total file separately. While this does not affect functionality, it can impact the information security of the uploaded data.
By encrypting each chunk separately, with what I assume is the same symmetric key, you run the risk of crypto-analysis on the file chunks revealing data on the key and or plaintext. The reason for this is due to the fact, because of the segmented nature of the encryption, you are effectively re-using the same key for multiple encryptions.
While this is not a huge deal practically, it is still a possible attack vector. A simple solution would be to simply encrypt the entire file once, and then split the encrypted data afterwards.
Other than that (unrealistic, you used CBC mode by the looks of it, so IV helps a lot) security vulnerability in a scheme that was made for fun, amazing video! I must say, I love over-the-top systems that solve problems in a way-more-than-necessary manner simply because it can 😂
The algorithm has brought me back. Thank you.
Anyday Google Drive, Dropbox, or other cloud storage can change their policy or go down. That is why it is always a good idea to have multiple backup plans.
i use telegram as a backup mainly for the photos from my phone but also other important files. the main drawback is that the download and upload speeds can be quite slow sometimes.
You're amazing. I had always given up on my dream of becoming a programmer, but you sparked it once more.
NIce, just installed teldrive, just make sure to use your own api id and hash
that's amazing lmao
to be honest, this approach is much easier than the previous one. it took me around 8 seconds to think of a way to create this, but the only difference is that i would have to use something like a /sync to send the new pictures/videos
Can you open source this? Would like to contribute. Or you have already and I haven't reached that point in the video
Yeah! GitHub repo link is in the description. Contributions very much welcome!
@@devdetourand the discord fs?
Me not knowing how Github works (Im not a programmer)
@@-john-9438then why comment
this project may help me archiving my interpolated video project when I don't have any available HDD storage. thanks
I would've written each chunk as their own file and have a metadata file (FAT) for each message id part to the file. if you overwrite, you replace the initial X block files and delete the rest if they are smaller, or create new block files if they are bigger.
Same here. First I watched your video related to Discord unlimited storage and then realised why didn't i used telegram and then i upgraded my code for telegram.
Telegram is slow for non premium especially in the evening (in Europe), sometimes downloading a simple 20MB video takes forever.
Honestly just for the unlimited file size, it's worth paying the premium just for the speed, specially if you compress everything in 2gb chunks for backup
7z supports encrypting, splitting, and compressing files into chunks and has better compression ratios than rar.
I would also use the brotli fork, as it has an even better compression algorithm.
Yay, got into the video! Great video dude!
awsome i always wanted to do omething like that ! uploading photos to some place and showing them dynamically from my deployed web app
this is amazing
Very interesting video again!
btw the teldrive owner got his own rclone fork that supports teldrive. I was using rclone mount and it was working perfectly fine :)
On discord, why dont use another channel to save the name and the file ids? Or at least make a backup of the id list every once in a while on Google Drive, Dropbox, (Telegram, Discord,) etc.
This is so good!
I would love to see a fuse system that cache usb-drive metadata only. Meaning I dont have to connect the usb-drive to my computer to check what files I had on it last time it was connected.
I think Windows has that and calls it hierarchical storage management
Everything from voidtools can do that too
Hey man! Could you mentioned in the description that people also can TELEGRAM-UPLOAD from Pypi?
Another great video!
A lot of specialized file download software can download a file using multiple connections simultaneously, maybe you can use that to improve speeds more?
People who experiment with these free storage tactics are a large part of the reason why tech companies have started putting up paywalls for their services. Server space doesn’t grow on trees.
This is why we can't have good things. Telegram will likely impose a restrictions after this.
@@Kipruto254 didn't this guy mention something like this existing already?
@@Kipruto254 Telegram just deletes old files when they start running out of space. Your uploaded files aren't guaranteed to live there forever. The faster people use it up like this, the faster they delete. So it's really no sweat off their back. Other than increased bandwidth usage, but we saw Telegram's mitigation for that, they throttle it, hoping you'll upgrade to premium.
exactly dude, free storage doesnt mean it auto generates itself with no costs infinitely
@@R_Samnan It's a loss leader. And it's not like it's guaranteed storage. If they need more space, they just delete your old files. The storage may not auto generate, but it does regenerate.
I’m from the future, you’ll have at least 500k subs by the end of this year man
FUSE sounds like it might be relevant to a problem I've had on my to do list to solve. Is this the same term used by the Windows ecosystem for the concept?
yes. i found this method about 2,5 years ago but i never automated it, i couldnt do it. i was waiting for someone to do this application. thanks
This is actually good if you dont want certain files on four system. This way you can just drop them on a "cloud" that has no connection to you
TIP: Try to send all the zipped files togheter and to download all of them togheter and then allow the user to modify, etc., so the flow should look like "read:download all (storing in temp)->check if they are all (by seeing witch are the missing ones checking their names from the DB file)->once they're all merge the file->show the file", " write: if the new file was used less then x time ago (ex. 2 hours ago), wait; else, move the file to temp->split in chunks->check and write to db->upload->check with db". Like 3 months ago, I tried to do the same thing by hand, separating the files with Winrar and uploading them slowly, and it worked, but if I have to upload a lot of things, it could get messy. PS: We also have to think about resuming upload after power-up and checking partially uploaded files during shoutdown, but it can be resolved by leaving the files in temp until they're fully uploaded with the checks mentioned before and other checks when booting and shutting down the PC (we write the queue of files to upload and download somewhere in the database to know what we were doing before the shoutdown). Nice video, keep on going man, I love these kind of things. Sorry for my bad english btw.
The caching scheme you implemented does not let you read files if they don't fit in RAM. Fuse manages data in chunks to allow working on files larger than free memory.
There are no good fuse tutorials in yt search, you should add fuselib or something to the tags or title of the video.
I intend to use this for a personal server of mine if i can figure out how to get it working on my linux machine.
Theres already some fusefs stuff going on under the hood so it can't be too bad... right?
Edit: i downloaded the example script amd your telegram fusefs script as examples so hopefully I can make sense of it with those.
Sure, these are “bad” download and upload speeds if compared to transferring files to a local drive, but what about enabling it to sync just like Nextcloud or OneDrive does? Wouldn't it be awesome to use this in order to have locally stored files backed up to the cloud. I could assume the Nextcloud client would be a huge help to implement something like this here!
What do you think?
Store files on TH-cam with digital data modes like OFDM-3500.
On a TDLib level for telegram you can request parts of the file instead of the whole file from the storage
Great video!
can you reduce the background music volume next time?
Thanks for the feedback, I'll keep this in mind. Still trying to figure out the right audio levels :)
@@devdetour please dont go way lower. often videos have comedically quiet background music. Guess its a matter of preference
sounds great for a backup system that has no guarantee the data will remain there 😅
Those file upload speeds don't seem right though... Would adding more upload/download workers improve the performance? The data may need to be split into chunks for each worker, but it may be faster overall?
I'm pretty sure it is rate limited per account or even per IP
i never thought of telegram for storage
i LOVE fuse stuff, i've tried to do a similar thing in windows with terabox because the client sucks, but it didn't work out
I see we have advanced pretty far from the time I used a free ad-supported web hoster with filesize limits and a PHP script to concatenate split files.
I have noticed, that the download speed is kinda slow even when you download files normaly. So I think it actually has to do something with their servers
No need for Samba on your Linux host, if you want to run it on windows there is WinFsp, which is basically FUSE for Windows.
Why not use read write streams for uploading and downloading. And then in the pipeline add a counter for the amount of chunks that got written or read.
you can store your data on TH-cam by uploading videos and use them as filesystem
Maybe it is better if you just sync the file in the background, possible make small chunks to have multiple upload run simultaneously?
Now with 2 different providers(telegram + discord) you can actually have raid 1?
It'd be fun to have a whole OS stored in telegram, and have your bootloader fetch if form there every time you boot up the PC.
Dude making a suggestion of how a data center can boot x3
Telegram download is slower than upload on purpose to decrease people misusing the service as much. But it's still really useful in a pinch.
I have an idea can you create an GUI for telegram only for uploading the files like if the members is free the file limit will be 2GB I'd the premium users is 4GB limit so if this idea create an GUI project is bit more powerful to use ??❤
Cool keep up 🆙 👍 😅
Till Telegram bans your account for whatever TOS violation, you may appeal but your files are gone
Other issue is capped download speed
I didn't have enough storage space so I used TH-cam to store all my videos, including my own film which took months of tedious work to make. Then TH-cam deleted my channel, destroying everything. Don't trust online storage!
Imagine you could sync with this like with Nextcloud ^ ^
What about pings? You can give them data and they'll send it back. Just do that a lot of times a second sending data to different IPs and you're storing data.. over internet wires!
I swear I saw a video like that already.
@@Spiderfffun Please link it if you can find it! Would be interesting.
@@juuujuuu1564 th-cam.com/video/JcJSW7Rprio/w-d-xo.html
@@juuujuuu1564 th-cam.com/video/JcJSW7Rprio/w-d-xo.html
Yes, someone has done this! th-cam.com/video/JcJSW7Rprio/w-d-xo.html. It's really really interesting!
I have a question??
Does the files last as long as the telegram exists?
Actually, HTTP supports something called download range, which only downloads the requested range from a file.
thank you
fsync/fflush: exists
devdetour: reinvented cache goes brrrrr
I did actually look at pyfuse3's fsync(), but I don't think it behaves like a cache. As far as I can tell from the pyfuse3 docs (www.rath.org/pyfuse3-docs/operations.html#pyfuse3.Operations.fsync), it just passes the fh, not actually the data, so a separate cache is still needed - and I couldn't actually get pyfuse3 to call into fsync() in testing, so I kept it in release(). Maybe not optimal, but it works!
Wonder if Guilded would be faster then discord as it offers 500mb file upload limit
tbh when you live in a country where an SSD costs an entire months paycheck, a free but shitty cloud service doesn't seem that bad.
I love it when you do this lol
i loved the Rick and Morty reference
yeah, tried it some time ago, teledrive has very bad speed in general, got myself a 4tb drive instead
How is this not a negative for telegram?
I love telegram as a service, I don't think I'm a fan of potentially them bearing more load then they need to when the provide such an amazing service so cleanly.
Is it reasonable to ask to rethink this? Maybe do it to someone like Apple?
The reason why Telegram download is so slow is that Telegram limits regular users' download speed cuz they want to make use buy their premium subscription. That was intentional.
did you also purchase premium? it's cheap iirc and it says speed does increase for premium users.
The download speed in telegram is limited just so that you don't use it as a file storage
wasn't there Unlim Cloud app which used telegram for storgae. Or did it stopped working?
Very nice
You used FUSE and still - no random reads/writes, missed a huge opportunity to allow streaming media with low latency, torrent seeding and many other things.
figo, iscritta
I completely forgot rar files were a thing. Don't really run into them outside of torrenting games.
What about creating a bunch of google/microsoft account and store files in there?
bro, the worst day was when I lost my group with my files and there was no backup, (I was banned from my group somehow) so I don't trust Telegram much for backups
Yeah, Telegram doesn't guarantee they'll keep your messages. That's how they can offer storage for "unlimited" files. If they start running out of space, they start deleting old files.
I do the same thing for years with files, links, music etc
What about steam could you store files on steam using there cloud save feature
I think the download speed on telegram can be improved by buying telegram premium..
Telegram is pretty aggressive when it comes to bandwidth or API usage.
Bandwidth, sure. But API usage? I don't think they're any worse than most other platforms out there.
genius
DAMNN
2:50 Literally me with all of my projects 😭
start teaching coding ngl your really fun to watch❤❤
I'm surprised you didn't write any streaming logic. I suppose a 2GB max memory cache isn't the worst, but it could also perform way better
Yep, telegram supports that too and it works really well
Oh man do we need a windows version of this
Stealing Storage from TH-cam next? Is there any stego in this video?
download speed is capped if iur account not premium
crazy
How about make telegram and discord on a raid like thing?
it good for another backup
I use firebase to store the
Files id name number of chunks date cunks message id
Its great but want to make it possible to stream large video files in real time
Telegram really slow sometimes in uploading/downloading
that's crazy
how to make a video player that is hosted online but it uses telegram data
Didn't know about winRAR and telegram 💀💀💀💀
Does this provide any form of redundancy? Cause why would you otherwise even bother the slightest... There are zip programs out there making raid like redundancy possible for zip files. Multipar for example.
what if you emulate how ssd works