Join devRant
Do all the things like
				++ or -- rants, post your own rants, comment on others' rants and build your customized dev avatar
				Sign Up
			Pipeless API
 
				From the creators of devRant, Pipeless lets you power real-time personalized recommendations and activity feeds using a simple API
				Learn More
			Search - "reverse engineering"
		- 
				    					
					
					Definitely my security teacher. He actually expected us to actively learn the stuff and put effort into our education. He guided us through malware analysis and reverse engineering, simplifying it without insulting us.
 
 We had students who thought they knew everything and he corrected them. We had arrogant students he put in place.
 
 He treated us like adults and expected us to act like adults.
 
 That's the only class I enjoyed studying for, because he would tell us exactly what wasn't on the exams (it was an intro course, didn't need to know the math). There were no trick questions.
 
 I told him about the shitty teacher and he helped me through that confidence block. He helped me realize I *can* make it through the workforce as a female in security because I will work my ass off to be the best I can be. He reminded me why I love computers and why I want to go into forensics.
 
 He's been a great mentor and role model and hiring him is one of the few things my department did right.7
- 
				    					
					
					Client: I want you to reverse engineer this piece of software!!
 *posts some link to an exe on altervista along with some unrelated crap*
 Oh and "I PAY"! (Because you can't even take that for granted anymore these days.)
 
 Me: Alright, I'll look into it but I'm not a reverse engineering expert so don't expect too much.
 *Closes Facebook*
 
 Client, day after: Hey have you looked into it already? Have you finished it already?! HEY, RESPOND ALREADY!!!
 
 Me (thinking): YEAH AFTER 1 DAY AND NO PAYMENT DETAILS WHATSOEVER, I INSTANTLY DROPPED EVERYTHING JUST TO PLEASE YOU, FILTHY RAT SACK!! You fucking wish, motherfucker. Down to lowest priority you go! And if I don't feel like doing it, how about I just drop your request and tell you to suck my fleshy snek, HOW ABOUT THAT HUH? Fucking piece of shit 😤12
- 
				    					
					
					Best experience: reverse engineering a CMS site to build a mobile app for it
 
 Worst experience: reverse engineering a CMS site to build a mobile app for it
- 
				    					
					
					Back when I was in school (about 15 years old) and I played games, I had a particularly favourite game that I would play. It was a lesser known strategy game made by a single hobbyist Dev.
 
 I was already known in the community for making some mods for the game and chatbots.
 
 What most people didn't know was that I had made a map hack and various other cheats that made it significantly easier to win by reverse engineering the game and modifying the x86 assembly in ollydbg.
 One thing in particular I had been working on at the time was a game replay editor. I had reverse engineered the saved game (replay) format and was able to replay them, edit them and generate them.
 
 During one particular match, a person in the community particularly annoyed me and I edited the saved game to change what his moves were and the words he spoke. It made him look a bit like an idiot but IMHO was only a slight exaggeration of the truth.
 I posted the game replay on the forums and everyone was in hysterics about the crazy things he did and said in the replay.
 As no one knew I had this capability they all believed the replay and even the guy in the replay couldn't believe it himself and didn't understand what happened. He just kept telling everyone it didn't happen and the 'truth is in the pudding'.
 
 Although I originally intended to tell everyone what I did, I never did and whenever the guy entered in to a game everyone would laugh about it and say 'the truth was in the pudding'.
 
 He was no longer annoying me and it sort of made me feel like a god at the time.
 So that's my wk65.2
- 
				    					
					
					Impostor vs Kenner syndrome
 
 We got a new kid which does his internship from school. We talked and he asked me what stuff I had done with 14 - 16. I remembered with 14 I was really into reverse engineering, assembler and c/c++ but never managed to actually build something.
 
 So he started to say stuff like he could replace me in an instant and he should get paid for this internship at least as much as I did, because he made some websites and games already.
 
 I really was down. Kids today get a lot of shit done and I was a disappointing lazy little shit just playing games and try to reverse engineer stuff and learn assembler and c++.
 
 It's been month and shit hit me when I've seen his stuff was copy pasted from a tutorial/ YouTube video.
 
 Today's ressources, languages, frameworks make it really easy to build something but I still got respect for everyone every age who is interested and get into programming and stuff.
 
 But I hope you'll read this you little shit and realise that you can use a simple physics engine by copy and pasting code. So don't talk disrespectful to people in general especially when they can create a whole game and physics engine.14
- 
				    					
					
					Finally got myself a Lytro Illum!
 I,v been wanting to buy one since it came out but the company who made it closed down in 2015..
 Thoose fuckers just thrown everything in the trash and set it on fire, software, firmware, mobile app etc.. no open source, no archives, your expensive camera is now a paper weight! You’r welcome!
 So i got myself a new hobby, started reverse-engineering the fuck out of it, luckily it’s based on android (api17), i have adb and it’s running a hidden DHCP server too so it’s coming along nicely :D
 I’m planning to make a camera control mobile app for it and maybe some faster image processing, wifi sharing etc..
 I love beeing in home office :D 19 19
- 
				    					
					
					So, a rather unfortunate bug on the Minecraft website.
 
 Minecraft allows you to change your name every 30 days. I was reverse engineering their API so I could use it personally.
 
 On the username change form there are two fields: your desired username, and your password.
 
 To protect myself from actually changing my name, I purposefully put in password123 so that it would fail. Then, I clicked "Change name" to monitor the network traffic.
 
 Well that's when two unfortunate things combined.
 
 #1: I used my last name to test. It's a unique word that is relatively short and very easy for me to type out of habit.
 
 #2: That password field doesn't actually get validated.
 
 So imagine my shock when I clicked "change username" and it WORKED.
 
 And now my username is doxxing me for at least 30 days + the permanent name history
 
 FUCK me5
- 
				    					
					
					I miss the days I actually enjoyed playing games.
 
 6 years of programming later...
 
 I'm always wondering how did they make the game? Once I find out how, I lose interest in the game.
 
 I spend more time reverse engineering/exploiting/modifying the Client of games than actually playing them, more out of curiosity than causing harm.
 
 Am I evil? 😫5
- 
				    					
					
					I often times write code and think to myself "I don't have to comment this, it's obvious what is going on", only to find myself back at the same code, figuring out wtf it does...1
- 
				    					
					
					I learnt programming by making cheats for games and reverse engineering them. It was a fun experience as it wasn't always easy to start with C++ and assembly but it was definitely worth it. Though when you come from a low level language such as C++, looking at highly abstract languages such as Javascript makes everything feel wrong in Javascript, especially when it comes to types and how you can just switch types in the middle of the code :D. But it also gives you an understanding of how Javascript could be implemented, what the engine is doing in the background when you create an object etc..
- 
				    					
					
					Just thought I'd share my current project: Taking an old ISA sound card I got off eBay and wiring it up to an Arduino to control its OPL3 synth from a MIDI keyboard. I have it mostly working now.
 
 No intention to play audio samples, so I've not bothered with any of the DMA stuff - just MIDI (MPU-401 UART) and OPL3.
 
 It has involved learning the pinout of the ISA bus connectors, figuring out which ones are actually used for this card, ignoring the standards a little (hello, amplifier chip that is wired up to the +12V line but which still happily works at +5V...)
 
 Most of the wires going to it are for each bit of the 16-bit address and 8-bit data. Using a couple of shift registers for the address, and a universal shift register for the data. Wrote some fairly primitive ISA bus read/write code, but it was really slow. Eventually found out about SPI and re-wrote the code to use that and it became very fast. Had trouble with some timings, fixed those.
 
 The card is an ISA Plug and Play card, meaning before I could use it I had to tell it what resources to use. Linux driver code and some reverse-engineering of the official Windows/DOS drivers got me past this stage.
 
 Wired up IRQ 5 to an Arduino interrupt to deal with incoming MIDI data, with a routine that buffers it. Ran into trouble with the interrupt happening during I/O and needing to do some I/O inside the handler and had to set a flag to decide whether to disable/re-enable interrupts during I/O.
 
 It looks like total chaos, but the various wires going across the breadboard are mainly to make it easier to deal with the 16-bit address and 8-bit data lines. The LEDs were initially used to check what addresses/data were being sent, but now only one of them is connected and indicates when the interrupt handler is executing.
 
 There's still a lot to do after that though - MIDI and OPL3 are two completely different things so I had to write some code to manage the different "channels" of the OPL3 chip. I have it playing multiple notes at the same time but need to make it able to control the various settings over MIDI. Eventually I might add some physical controls to it and get a PCB made.
 
 The fun part is, I only vaguely know what I'm doing with the electronics side of this. I didn't know what a "shift register" was before this project, nor anything about the workings of the ISA bus. I knew a bit about MIDI (both the protocol and generally how the MPU-401 UART works) along with the operation of a sound card from a driver/software perspective, but everything else is pretty new to me.
 
 As a useful little extra, I made some "fake" components that I can build the software against on a PC, to run some tests before uploading it to the Arduino (mostly just prints out the addresses it is going to try and write to). 46 46
- 
				    					
					
					Saw some cheapie little radio in the dollar store, bought 2 of them for reverse engineering. Powered it from my lab bench power supply as usual, and tested whether it actually works before doing anything else.. then I noticed that the tunes were actually quite catchy, so I just ended up listening.
 
 Then I started to notice that the audio wire I was using (the one I've spent a couple of days building earlier) had intermittent audio issues where the right driver would drop out when the wire was held in certain positions. Oscilloscope probing showed that there was some sort of disconnect, with only the 50Hz noise from the power lines showing up. Opened up the connector and noticed that the ground wire had detached. An 28AWG electrical wire that was inside a jack that was meant for stress relief! Yet the copper strands must've detached one by one regardless. What do I need then, huh?! 18AWG which wouldn't even fit on the connector, only to see the strands in that eventually detach as well?! You know what, let's go fancy.. 1AWG which is meant for extremely high current applications!!
 
 At that point I was literally shouting "FUCK!!! Why does this shit always happen to me?!! ONE FUCKING PROJECT THAT FINISHED SUCCESSFULLY, YET STILL BROKE?!!!! WHY!!!!!!"
 
 Clearly I need some fresh air to cool down. On my way to the fast food restaurant to get some Bicky burgers. More shit, humans. One stupid driver who slowed down on me, which of all things I hate the most. GO FASTER ALREADY YOU SLOWFUCK, AND GET THE FUCK OUT OF MY SIGHT!!! Next a pedestrian with a dog.. I swear motherfucker, if that dog comes anywhere near me I'll personally turn it into fucking fricassee.
 
 Ah and then comes the killer.. in this stupid fucking summer, all that's needed to fix any issue is a fucking stupid DESPACITO, right?! More like DeSPASTICo!! FUCK!!!!
 
 .. Back home, rather tired. So essentially a wire that was specifically built to have high endurance broke on me. Back to Bluetooth I guess.rant fuck the planet fuck humanity fuck everything fuck despacito fuck despastico fuck life fuck me fuck humans fuck the world fuck this shit fuck society2
- 
				    					
					
					Okay guys, this is it!
 
 Today was my final day at my current employer. I am on vacation next week, and will return to my previous employer on January the 2nd.
 
 So I am going back to full time C/C++ coding on Linux. My machines will, once again, all have Gentoo Linux on them, while the servers run Debian. (Or Devuan if I can help it.)
 
 ----------------------------------------------------------------
 
 So what have I learned in my 15 months stint as a C++ Qt5 developer on Windows 10 using Visual Studio 2017?
 
 1. VS2017 is the best ever.
 Although I am a Linux guy, I have owned all Visual C++/Studio versions since Visual C++ 6 (1999) - if only to use for cross-platform projects in a Windows VM.
 
 2. I love Qt5, even on Windows!
 And QtDesigner is a far better tool than I thought. On Linux I rarely had to design GUIs, so I was happily surprised.
 
 3. GUI apps are always inferior to CLI.
 Whenever a collegue of mine and me had worked on the same parts in the same libraries, and hit the inevitable merge conflict resolving session, we played a game: Who would push first? Him, with TortoiseGit and BeyondCompare? Or me, with MinTTY and kdiff3?
 Surprise! I always won! 😁
 
 4. Only shortly into Application Development for Windows with Visual Studio, I started to miss the fun it is to code on Linux for Linux.
 No matter how much I like VS2017, I really miss Code::Blocks!
 
 5. Big software suites (2,792 files) are interesting, but I prefer libraries and frameworks to work on.
 
 ----------------------------------------------------------------
 
 For future reference, I'll answer a possible question I may have in the future about Windows 10: What did I use to mod/pimp it?
 
 1. 7+ Taskbar Tweaker
 https://rammichael.com/7-taskbar-tw...
 
 2. AeroGlass
 http://www.glass8.eu/
 
 3. Classic Start (Now: Open-Shell-Menu)
 https://github.com/Open-Shell/...
 
 4. f.lux
 https://justgetflux.com/
 
 5. ImDisk
 https://sourceforge.net/projects/...
 
 6. Kate
 Enhanced text editor I like a lot more than notepad++. Aaaand it has a "vim-mode". 👍
 https://kate-editor.org/
 
 7. kdiff3
 Three way diff viewer, that can resolve most merge conflicts on its own. Its keyboard shortcuts (ctrl-1|2|3 ; ctrl-PgDn) let you fly through your files.
 http://kdiff3.sourceforge.net/
 
 8. Link Shell Extensions
 Support hard links, symbolic links, junctions and much more right from the explorer via right-click-menu.
 http://schinagl.priv.at/nt/...
 
 9. Rainmeter
 Neither as beautiful as Conky, nor as easy to configure or flexible. But it does its job.
 https://www.rainmeter.net/
 
 10 WinAeroTweaker
 https://winaero.com/comment.php/...
 
 Of course this wasn't everything. I also pimped Visual Studio quite heavily. Sam question from my future self: What did I do?
 
 1 AStyle Extension
 https://marketplace.visualstudio.com/...
 
 2 Better Comments
 Simple patche to make different comment styles look different. Like obsolete ones being showed striked through, or important ones in bold red and such stuff.
 https://marketplace.visualstudio.com/...
 
 3 CodeMaid
 Open Source AddOn to clean up source code. Supports C#, C++, F#, VB, PHP, PowerShell, R, JSON, XAML, XML, ASP, HTML, CSS, LESS, SCSS, JavaScript and TypeScript.
 http://www.codemaid.net/
 
 4 Atomineer Pro Documentation
 Alright, it is commercial. But there is not another tool that can keep doxygen style comments updated. Without this, you have to do it by hand.
 https://www.atomineerutils.com/
 
 5 Highlight all occurrences of selected word++
 Select a word, and all similar get highlighted. VS could do this on its own, but is restricted to keywords.
 https://marketplace.visualstudio.com/...
 
 6 Hot Commands for Visual Studio
 https://marketplace.visualstudio.com/...
 
 7 Viasfora
 This ingenious invention colorizes brackets (aka "Rainbow brackets") and makes their inner space visible on demand. Very useful if you have to deal with complex flows.
 https://viasfora.com/
 
 8 VSColorOutput
 Come on! 2018 and Visual Studio still outputs monochromatically?
 http://mike-ward.net/vscoloroutput/
 
 That's it, folks.
 
 ----------------------------------------------------------------
 
 No matter how much fun it will be to do full time Linux C/C++ coding, and reverse engineering of WORM file systems and proprietary containers and databases, the thing I am most looking forward to is quite mundane: I can do what the fuck I want!
 Being stuck in a project? No problem, any of my own projects is just a 'git clone' away. (Or fetch/pull more likely... 😜)
 Here I am leaving a place where gitlab.com, github.com and sourceforge.net are blocked.
 
 But I will also miss my collegues here. I know it.
 Well, part of the game I guess?7
- 
				    					
					
					Ok, I give up reverse engineering this. Full of netscape compatibility and iframes, and more shit.
 Typical korean websites. ^v^ rant debugging developer tools javascript performance website vivaldi reverse chromium netscape engineering1 rant debugging developer tools javascript performance website vivaldi reverse chromium netscape engineering1
- 
				    					
					
					!rant 📚 📑
 
 Cybersecurity books @Humble Bundle
 
 https://humblebundle.com/books/...
 
 There is a really great Humble Book Bundle at the moment, starting at 1$. The bundle contains several cyber security books ("Practical Reverse Engineering" and "Security Engineering" have a good reputation).8
- 
				    					
					
					This happened with one of our senior profs during the first year of my college. I wouldn't call him a dev if my life depended on calling him a dev but regardless, I narrate the story here.
 
 We were "taught" C++ by some really dumb professors during our first year of college and it was mandatory that everyone cleared the subject regardless of what field of engineering the students chose. Having already done 2 years of C++, it was quite a breeze for me. But during the final lab exam, one of my friends requested my help in solving the quite tough question (for those beginners). Thinking the exam and teaching was unfair, I stupidly wrote the answer on a piece of paper and passed it to him. One of our teachers, who had seen him ask me, was lying low waiting to catch me in the act and she swooped in and busted our asses kicking us out of the exam hall and sending us to the HoDs office like some prize from her war against academic corruption.
 In the end, I failed the exam for cheating and had to redo (not only the exam but the entire lab course).
 
 When I returned to college during the summer vacations to redo the course, I first met the antagonist of our story. Having a huge head that looked like a deformed watermelon and an ego the size of a building, he assaulted us first with a verbal diarrhoea of his achievements as a CS professor. I quickly realised that I was in a class of people who had failed to grasp how to make a program that printed "Hello World". To make things shorter, every question the prof gave us, I managed to solve in a mere matter of minutes, several better than his own solutions. Not having expected a student who knew his shit, he was determined to play me down. He hurled tougher question at me and I knocked them over his enormous head piercing his ego. He asked me such questions as how to reverse 1000 and get 0001 and wasn't satisfied with the several ways I gave because none of it were what he had in mind (which turned out to be storing them in a fucking array and printing them in reverse. That's printing not reversing you dung beetle). I kept my calm throughout but on the day of the final exam, he set quite a tough paper for a class of people who had already failed once. To his utter shock and dismay, I aced that too and I produced flawless code. This man who has an MTech from one of the most reputed colleges of my country then proceeded to tell me that he had to cut my marks because I had used more than one function when the question had asked for one function ( it never said only one). I lost my shit and pointed out that since I was the programmer, it was my wish how I coded. I also explained to him how repeating code is a bad practice and one should use functions to reduce redundancy and keep the code clean. Nevertheless, he lost his shit and he threatened me with consequences as apparently "I didn't know who I was messing with". I handed over the paper and stormed out of the class (though he called me back and tried to argue more with me. I apologized for losing my shit and left when he was done talking). I ended up getting a 'C'. Totally worth it.4
- 
				    					
					
					I'm currently one of two "pen testers" for the anticheat system of a game.
 
 It all started a few days ago when the developer handed me the obfuscated package and told me to go at it. No big deal, I've bypassed it before the obfuscation, so I just changed some imports and sent in the screenshot.
 
 Fast forward 100+ hours, it's turned into a cat-and-mouse game. He sends us (the testers) an update, we break it within hours. We show him what we exploited and he attempts to fix it. Rinse and repeat.
 
 Finally, today he patched the one hole that I've been using all this time: a field in a predictable location that contains the object used for networking. Did that stop me? No!
 
 After hours of searching, I found the field in an inner class of an inner class. Here we go again.3
- 
				    					
					
					1 - Writing a 20 lines Python module in 15 minutes approx.
 2 - Accidentally deleting this module.
 3 - Taking 1 hour finding a way to generating source code from the compiled PYC Python file.1
- 
				    					
					
					So... I've got a confession to make.
 I'm no longer a Dev. After the disaster that was my last commercial gig, I went and got a sec Ops role... And I love it. It's just technical problem solving and explaining all the way.
 Don't get me wrong, I still love to code. But that's exactly the thing. As a commercial developer employed by corporations, I spent close to 80 % of my time not coding, but in useless meetings, or trying to figure out just what my colleagues thought was "common sense", reverse engineering their work and documenting how to get it running, etc. Basically, fixing shit for braindead academics with next to no real world experience.
 Now, when I code, I get to do it on my own terms, with my own stack and as much comments and docs as I want to have. I own my time, and the only ones that are allowed to interrupt me is the local fire department.
 I can do what I'm fucking passionate about and leave the rest for the useless people.4
- 
				    					
					
					When you try to reverse engineer some $5 toy but the ICs Datasheet is only in chinese ;-(
 And Google translate for pdf sucks. 4 4
- 
				    					
					
					Taking a for-giggles training on reverse engineering... It's theory. Basic level theory. Posted 6 months ago.
 
 "someone might want to reverse engineer Microsoft Word in order to change its code so that it could be run on a Mac."
 
 Are we ignoring how old Word has had Mac support????
 
 Or "To prevent circumvention, some programs require as part of the terms of use that you do not attempt to reverse engineer their code." like this will stop someone who wants to circumvent having to pay from acting illegally, because we all totally read EULAs and T&Cs...
 
 Whyyyyyy4
- 
				    					
					
					This is Alvin, a small sub that is 60 years old, been to the Titanic wreckage many, many times. Still in active service.
 
 This is the difference between the real engineering and the kind of "engineering" done by so-called "disruptors" that say "move fast and break things".
 
 You're not an engineer — you're a douche that appropriates the engineering culture. You didn't make an "OS for productivity", you made a worse version of Lotus 1-2-3 from 1983. You didn't "reverse-engineer" anything — you copied and pasted funny letters and symbols put together by a language model that is as clueless as you are.
 
 Do not cite the deep magic to me, bitch. I was there when it was written. 11 11
- 
				    					
					
					When your colleague comments out some of your codes just to reverse engineer how it works. And checked it in!!! 1 1
- 
				    					
					
					The coolest thing I have worked on is a League of Legends sandbox. A reverse engineering of the official server, so we could do whatever we want.
- 
				    					
					
					So before the Age of JavaScript, when programming was trying to be an engineering discipline, I felt like we were getting close to figuring out what worked and what didn't. We had rules of thumb (more general than Patterns) and code smells.
 Then JavaScript came in and no one had time to think about "engineering" anymore. I'm fine with MVP and small iterations, but the disdain I see for making code clean and extendable and improvable is baffling (and annoying). First-time coders might never have had to fix someone else's code, but two weeks in a chair should have fixed that.
 It's not that understanding code is so hard (although it can be); understanding the _intent_ is hard. This MVP is great, but when no one had time to document what is actually supposed to happen, programmers have to reverse-engineer the *design*.4
- 
				    					
					
					I was having great progress in reverse-engineering the devRant Avatar system...
 
 And then I came to the shirt list.
 
 109 SHIRTS THAT HAD TO BE METICULOUSLY DOCUMENTED AND GIVEN AN INDIVIDUAL CODE
 
 AAAAAAAAAAAAAAAAAAAAAAAAAAAA9
- 
				    					
					
					Not a co-worker but a personal friend, I am still developing with the dude. He is absolutely AMAZING when it comes to reverse engineering he knows much more than me in this area of computer science. Actually one of my first friends who actually geeks out over this shit.10
- 
				    					
					
					Dev at the start of a project: My code will be effective, clean and well organised!
 Dev at the end of a project: console.log("Reverse engineering strictly prohibited.")
- 
				    					
					
					Reverse engineering an applications internal object model and creating an database model for it...
 
 The reason: Several versions of application exist, each deliver flat data by rest. The data is a complete potpourri of several different entities. *yaaaay*
 
 Eg. an example fictional call (real call and data would get me in trouble I think....)
 
 get_fiscal_report returning the fiscal data for _several_ companies, the companies _subsidiaries_ and the respective _segments_ for a _year_ with a key value enumeration.
 
 So it's an happy fuck up of N:N associative data that usually would be a hierarchical relationship...
 
 Year - Company
 Each Company has subsidiaries
 Each Company subsidiary has segments
 Each segment has a fixed enumeration of keys
 Each key has then the monetary value (e.g. 'operating_income' - 155_000 US-$)
 
 Example is made up, but my data contains exactly such a lovely nested hierarchical data flattened and misnamed to a point where it's close to garbage.
 
 Yaaaay.
 
 I had now 6 days of untucking this mess to a usable database representation...
 
 Sprinkling Unique Keys everywhere...
 
 Running persist script...
 
 Getting exceptions...
 
 Changing associations...
 
 Running persist script...
 
 Screaming.
 
 Changing associations...
 
 Violently cursing.
 
 Running persist script.
 
 Starting sacrificing interns...
 
 6 days.
 
 I need a new brain and a format of my soul.
 
 -.-
 
 Reverse engineering proprietary software is really an morbid adventure.1
- 
				    					
					
					I have found the best game for learning ever XD
 I have recently heared about io.netgarage.org and tried to solve several it's levels, and I find this game awsome
 It is the best to learn reverse engineering)) it is just like an Impossible quiz, where you have to smash the stack to get to the next level))
 I have wasted much time for that, but it is worth it))
 ((Not an advertisment))7
- 
				    					
					
					I'M A SENIOR DEVELOPER NOT A BUSINESS ANALYST...
 
 IF YOU GIVE ME SOME CRAPPY LEGACY CODE THAT SOMEONE RANDOMLY DECIDED TO USE, THE ONLY WAY I CAN UNDERSTAND IT IS BY RUNNING IT AND REVERSE ENGINEERING THE "BUSINESS LOGIC".
 
 ADD THAT WITH BAD INPUTS... THE ONLY THING YOUR DOING IS WASTING MY TIME..
 
 JUST BURN THE WHOLE THING AND GIVE ME THE REQUIREMENTS OF WHAT YOU ACTUALLY WANT....
 
 It feels like I've been fucking a pig all week...
 
 Oh and now my team agrees and will look to get the actual requirements from the business...
 
 This feels like a hallow victory.... As that was the first thing I told them to do....
- 
				    					
					
					Someone created a 0-followers private Twitter account and posted something to try out the new views count feature.
 It raked dozens of views in a couple hours.
 HOW?!?
 
 Source: https://twitter.com/briggityboppity...
 
 It looks like a funny data reverse-engineering exercise, so let's try and figure out what is going on.
 
 Hypothesis 1) it is the OP's own views.
 Reasonable, but unlikely if what OP says about not checking it for hours is true.
 
 H2) It's some background job in OP's device that is refreshing OP's own latest tweets, so even without human interaction technically H1 is true. It would be some really shoddy engineering to count eye-less page views, but that's also what managers would demand.
 
 H3) it's some internal Twitter automated function like back up, replication, indexing and word count.
 See H2, it would be even dumber to count that as page views.
 
 H4) it's some internal human reviewing for a keyword that could be associated with porn (in this case, "butts"). Really? dozens of humans to review a no-impact single post? They would have to employ hundreds of thousands of reviewers.
 
 H5) it's some page-loading shit, like thousands of similar tweets get stored in the same index hash page and end up counting as a view in all of them every time someone loads the index page. It would be like counting every hit in the namenode as a hit in every data asset in it's Hadoop partition, or every hit in a storage block as a hit in each of it's files.
 Duuuumb and kinda like H3.
 
 H6) page views are just a fraud to scam investors. Maybe it's a "most Blockchain transactions are fake" situation, maybe it's a "views get more engagement if you don't think a lot about it" situation, maybe it's a "we don't use the metric system to count page views" situation.
 All of them are very dumb.
 
 Other hypothesis or opinions?7
- 
				    					
					
					I am currently reverse-engineering the devRant Avatar APIs, I think I understand all of it now. I am curently making comprehensive documentation on it and I think I will release it (if the developers of devRant allow me to do so).
 
 I am reversing it as part of my project of making a devRant client built in SwiftUI, because I really want to make an avatar editor on there, it’s gonna be SICK!18
- 
				    					
					
					When I have to apply a strong coat of
 reverse engineering to understand an
 open source codebase, what's the
 point of being open.
 
 
 
 No but really, the
 
 WORKS ON MY BRAIN
 
 movement is quite strong ..6
- 
				    					
					
					I am a computer science student and have worked with Java and C++ until now. A week ago i started in a job i have gotten from my professor. I have to reverse engineer a big python project and figure out how some things work on the serverside. This is the first time i have to work with python.
 
 I get that you can write code fast with this dynamically typed language, but BOY. Is it just me or is this language fucking hard to reverse engineer? I mean what the fuck. There are some member variables in which can be anything. Like you suggest there is an object of this and that and then python comes in and is like: Good guess, but fuck you.4
- 
				    					
					
					A software had been developed over a decade ago. With critical design problems, it grew slower and buggier over time.
 As a simple change in any area could create new bugs in other parts, gradually the developers team decided not to change the software any more, instead for fixing bugs or adding features, every time a new software should be developed which monitors the main software, and tries to change its output from outside! For example, look into the outputs and inputs, and whenever there's this number in the output considering this sequence of inputs, change the output to this instead.
 As all the patchwork is done from outside, auxiliary software are very huge. They have to have parts to save and monitor inputs and outputs and algorithms to communicate with the main software and its clients.
 As this architecture becomes more and more complex, company negotiates with users to convince them to change their habits a bit. Like instead of receiving an email with latest notifications, download a csv every day from a url which gives them their notifications! Because it is then easier for developers to build.
 As the project grows, company hires more and more developers to work on this gigantic project. Suddenly, some day, there comes a young talented developer who realizes if the company develops the software from scratch, it could become 100 times smaller as there will be no patchwork, no monitoring of the outputs and inputs and no reverse engineering to figure out why the system behaves like this to change its behavior and finally, no arrangement with users to download weird csv files as there will be a fresh new code base using latest design patterns and a modern UI.
 Managers but, are unaware of technical jargon and have no time to listen to a curious kid! They look into the list of payrolls and say, replacing something we spent millions of man hours to build, is IMPOSSIBLE! Get back to your work or find another job!
 Most people decide to remain silence and therefore the madness continues with no resistance. That's why when you buy a ticket from a public transport system you see long delays and various unexpected behavior. That's why when you are waiting to receive an SMS from your bank you might end up requesting a letter by post instead!
 Yet there are some rebel developers who stand and fight! They finally get expelled from the famous powerful system down to the streets. They are free to open their startups and develop their dream system. They do. But government (as the only client most of the time), would look into the budget spending and says: How can we replace an annually billion dollar project without a toy built by a bunch of kids? And the madness continues.... Boeings crash, space programs stagnate and banks take forever to process risks and react. This is our world.3
- 
				    					
					
					Just succesfully converted my entire app from using web scraping data fetching to direct API by reverse-engineering their android app to get to their private API
 
 App is running much faster and more stable now, feels good3
- 
				    					
					
					//First rant
 
 So I've been working trying to get a file exporter for a binary file format mostly reverse engineered - 2001 Super Monkey Ball 2 (GameCube) if anyone's interested.
 
 Everything works fine, goals show up in the right places, wormholes work as intended, etc. That is everything, except every single level you create will be invisible, or crash (Depending on which version of Dolphin emu you use).
 
 This happens whenever trying to specify object names for 3D objects. I checked, all the many offsets seem correct, Object names are correct. Tried both null terminated strings and fixed 80 character strings - nothing.
 
 Some other guy also made an exporter that works, however the code is an absolute mess - basically unreadable. It also lacks some newer parts of the file spec, which is the main reason as to why I'm rewriting it.
 
 And as I'm working with an almost entirely unheard of file format, there are few people to go to for help. The 2 I know who are also familiar with the LZ file format have no idea either...
 
 Sigh.1
- 
				    					
					
					It was an internship. They wanted me to spoof the government's digital signature on some online tax-filing documents by reverse engineering the government's application, just because the whole process of recieving authentic signatures would have taken time, and they wanted it _now_2
- 
				    					
					
					Wasted a day as Shitlock Holmes with the build chain.
 
 It would not reproduce the firmware hexfile that had been checked in. Reverse engineering that along with the mapfile to find out the cause, it was a const string that was guarded by an ifdef from another file that was auto-generated as prebuild step via a script that fetched some version control info.
 
 Or, it would have been if the installation instructions had been correct and someone had described that no spaces in the absolute path name of the project are allowed. Otherwise, that shit just failed silently.
 
 I then had to reverse engineer the intended workflow from the commit history in the version control to figure out that the last dev obviously hadn't quite understood the project specific workflow and how the version control interacts with these build scripts.
 
 At least, I finally did get a matching hexfile.1
- 
				    					
					
					I am trying to reverse engineer a fingernail hardening device for rapid hardware prototyping (becoming some kind of hardware developer I guess)
 
 Since it is a fucking mess (all cables are black) they've chosen a weird construct to operate microcontroller on 240Vac (seems to be possible and made in very low energy consuming devices) i do not find any datasheet for one of the used products. It would help a lot but no. And messing around with high voltage is no fun.
 
 I'm unsure if this fits as a dev rant since most/all I've read so far are software-related. 9 9
- 
				    					
					
					I really hate PHP frameworks.
 
 I also often write my own frameworks but propriety. I have two decades experience doing without frameworks, writing frameworks and using frameworks.
 
 Virtually every PHP framework I've ever used has causes more headaches than if I had simply written the code.
 
 Let me give you an example. I want a tinyint in my database.
 
 > Unknown column type "tinyint" requested.
 
 Oh, doctrine doesn't support it and wont fix. Doctrine is a library that takes a perfectly good feature rich powerful enough database system and nerfs it to the capabilities of mysql 1.0.0 for portability and because the devs don't actually have the time to create a full ORM library. Sadly it's also the defacto for certain filthy disgusting frameworks whose name I shan't speak.
 
 So I add my own type class. Annoying but what can you do.
 
 I have to try to use it and to do so I have to register it in two places like this (pseudo)...
 
 Types::add(Tinyint::class);
 Doctrine::add(Tinyint::class);
 
 Seems simply enough so I run it and see...
 
 > Type tinyint already exists.
 
 So I assume it's doing some magic loading it based on the directory and commend out the Type::add line to see.
 
 > Type to be overwritten tinyint does not exist.
 
 Are you fucking kidding me?
 
 At this point I figure out it must be running twice. It's booting twice. Do I get a stack trace by default from a CLI command? Of course not because who would ever need that?
 
 I take a quick look at parent::boot(). HttpKernel is the standard for Cli Commands?
 
 I notice it has state, uses a protected booted property but I'm curious why it tries to boot so many times. I assume it's user error.
 
 After some fiddling around I get a stack trace but only one boot. How is it possible?
 
 It's not user error, the program flow of the framework is just sub par and it just calls boot all over the place.
 
 I use the state variable and I have to do it in a weird way...
 
 > $booted = $this->booted;parent::boot();if (!$booted) {doStuffOnceThatDependsOnParentBootage();}
 
 A bit awkward but not life and death. I could probably just return but believe or not the parent is doing some crap if already booted. A common ugly practice but one that works is to usually call doSomething and have something only work around the state.
 
 The thing is, doctrine does use TINYINT for bool and it gets all super confused now running commands like updates. It keeps trying to push changes when nothing changed. I'm building my own schema differential system for another project and it doesn't have these problems out of the box. It's not clever enough to handle ambiguous reverse mappings when single types are defined and it should be possible to match the right one or heck both are fine in this case. I'd expect ambiguity to be a problem with reverse engineer, not compare schema to an exact schema.
 
 This is numpty country. Changing TINYINT UNSIGNED to TINYINT UNSIGNED. IT can't even compare two before and after strings.
 
 There's a few other boots I could use but who cares. The internet seems to want to use that boot function. There's also init stages missing. Believe it or not there's a shutdown and reboot for the kernel. It might not be obvious but the Type::add line wants to go not in the boot method but in the top level scope along with the class definition. The top level scope is run only once.
 
 I think people using OOP frameworks forget that there's a scope outside of the object in PHP. It's not ideal but does the trick given the functionality is confined to static only. The register command appears to have it's own check and noop or simply overwrite if the command is issued twice making things more confusing as it was working with register type before to merely alias a type to an existing type so that it could detect it from SQL when reverse engineering.
 
 I start to wonder if I should just use columnDefinition.
 
 It's this. Constantly on a daily basis using these pretentious stuck up frameworks and libraries.
 
 It's not just the palava which in this case is relatively mild compared to some of the headaches that arise. It's that if you use a framework you expect basic things out of the box like oh I don't know support for the byte/char/tinyint/int8 type and a differential command that's able to compare two strings to see if they're different.
 
 Some people might say you're using it wrong. There is such a thing as a learning curve and this one goes down, learning all the things it can't do. It's cripplesauce.12
- 
				    					
					
					Seniority sucks sometimes.
 
 Today I took the time to figure out the API for a shipping website.
 
 I was super proud of this and figured that this could be useful for our application but the guy who has been there for 5+ years was like "no we have used an API for a previous client and caused the application to slow down by 1.2 seconds."
 
 Of course in my mind I'm like, "but what was the API that you used? When I use it, it's running and returning in milliseconds. Surely you're not doing it right."
 
 Of course because of his seniority I'm not going to say that.
 
 It just sucks a lot because I spent a lot of time reverse engineering the API. It would have been nice to have been noticed for that work.5
- 
				    					
					
					I did reverse engineering on window command prompt hahaha
 
 of course it was just for the commands:
 · set
 · cd
 · start
 which were the ones I needed because the admins in my school blocked cmd.4
- 
				    					
					
					That shitty moment when you are reverse engineering an app (LINE), but can't find any useful hints.
 Web analysis didn't help. Decompiling the windows executable also didn't help. Testing the app on different behaviour with python scripts didn't help. Analysing the android app on windows with the jadx decompiler and other decompiler didn't help that much.
 BUT today it worked. I did use a paid "Dex dump" android application. I found some methods that the app receives from the servers with a thrift protocol.
 Now I just need to find the right parameters to be finally able to make a bot. Hehehe.
 
 That was a hard way, but it paid out. I did learn so many things. It took me like a whole year. 5 5
- 
				    					
					
					What would be the best "hot"/upcoming languages for a final year college project?
 
 The project will focus on reverse engineering.
 
 Basic Example: Intercepting signals from products such as a toy helicopters/drones/etc, reverse engineer the signals and try gain control of the device from that.
 
 That's just a very basic function and there will be much more to it, but I'm struggling to decide on a language to pursue hand-in-hand with this project!
 
 I hear Rust, Go, Julia and co being tossed around a lot.
 
 Any suggestions would be helpful!
 
 Cheers7
- 
				    					
					
					Reverse engineering a USB device driver I already have the source for because apparently it runs on Donald Trumps hair magic.
- 
				    					
					
					Recipe for reverse engineering data structures / binary formats:
 
 1℅ understanding the theory.
 1℅ expections about what you will find.
 3% luck.
 45% trial and error.
 50℅ persistence.2
- 
				    					
					
					When you are trying to reverse engineering context free grammar rules from given sentences......
 Not possible. Worst assignment yet. 2 2
- 
				    					
					
					For my design thesis I'm gonna design a banking app for kids. And i'd like to have a look at competitors apps screendesign.
 Is it possible to open android and/or iphone apps in android studio/xcode in order to have a look at the screen designs?
 
 Because I'm no kid or parent so getting accsess the legit way is out of question.5
- 
				    					
					
					Hacking company product with reverse engineering ang bytecode instrumentation.
 
 The project I had to write integration test for was really not meant/written for testing. I ended up bytecode instrumenting an internal library to intercept the needed states and results.
- 
				    					
					
					Some business users have been chasing me all week to produce a report using some old report with some modifications.
 
 I didn't write the old code and have no context as to what the data is.
 
 My current reaction is:
 so you want a report that says X using some vague input which you haven't clearly defined or explained to me...
 
 Have you heard about black boxes and overfitting (i.e. reverse engineering a process based on sample data)?
 
 TLDR: I can generate a report that will say anything you want it to say... doesn't mean it will be right in future use cases.
 
 Why don't people (originally GBoard suggested peepee) understand "junk in = junk out"
- 
				    					
					
					Most fun i had was reverse engineering lg tone & talk where my headset would vibrate and talk to me on deployments or when something happened
- 
				    					
					
					I fucking agreed for this extension to my internship only because my fucking manager told me, I'd get to work on something exciting. It's been 3 weeks on this new project and I'm still stuck at reverse engineering, feasibility and writing docs !!!!
 
 I JUST WANT THIS THING TO BE OVER IT1
- 
				    					
					
					I just got an some ESP32 so I started playing with idf by espressif that it's released under apache 2.0.
 So i thought "it's open source"
 I spent 10 minutes searching for low level WiFi and BLE APIs on github.
 
 Then I found an old issue
 where an espressif dev says:
 
 "The low level Bluetooth & WiFi implementations are proprietary"
 
 FUCK!
 
 they distribute Binary files in another repo also under apache 2.0.
 
 any suggestion?
 -- (obviuosly) except reverse engineering.1
- 
				    					
					
					Is there any documentation on what is public API or not?
 
 @dfox or is reverse engineering the calls allowed? 13 13
- 
				    					
					
					Someone had created a program in VB that was used to properly format files for EFTs for a while. It wasn't working with a particular file, so I just ended up reverse-engineering it in Python.
- 
				    					
					
					Everytime I try to use company-wide libraries, I need to do damn reverse engineering. Why the fuck they don't put actual examples on the documentation!
- 
				    					
					
					I hate programmatic auto layout. It's such a mess! Simple shit like cells that can easily be defined in a .nib become spaghetti coded messes that violate every good programming practice ever. Want to recreate the same style of cell again? Good luck reverse engineering the hieroglyphics your teammate wrote when creating the layout by hand. Never mind a whole bunch of useless shit is done in code that could easily be defined via runtime attributes through the storyboard. But why learn a new approach? Cause job security. Or because for some reason Interface Builder tools are seen as "too hard" or "not scalable" to use.. fuck me.2
- 
				    					
					
					We've been working on a big application on-and-off for the last year (whenever we had time.) It was 99% working, and we left it to work on some other apps. We come back to it, only to find that some big features have magically stopped working. We dig into it and find thT some other dev team completely changed the functionality of one of the existing off-application microservices were utilizing without telling us, and then we had to spend days reverse-engineering what they did so we could retrofit our application to communicate with the microservice again.
 
 We were able to get it fixed, but I just know that they're going to change something else in the future without telling us and it's gonna break again. A little interdepartmental communication would be greeeeaaaat!1
- 
				    					
					
					I was introduced to disassembly/reverse engineering today. It's amazing how many production applications use isLicenseValid() or other helpful function signatures to assist in my practical learning :p I'm looking at you sublime text
- 
				    					
					
					I want to begin in reverse-engineering.
 Creating or beginning to create an emulator stimulates me. Can someone give me some tutorials, keywords, links to where I should search if anyone knows this kind of stuff ?2
- 
				    					
					
					Hmm I'm thinking of reverse engineering an old game client and trying to rebuild the backend server from scratch... In a different language..
 
 Quite a big idea 😅 but it should be very educational! Anyone got some tips and or tricks for reverse engineering? Or some pitfalls I should avoid?4
- 
				    					
					
					So I reverse engineered the
 protocol of QONQR: World in Play and made a mitmproxy addon running locally inside termux that can see when I launch in the game and uses Termux:API to notify me when my ingame resources are replenished.
 I direct the traffic through mitmproxy using Drony. I configured it so that by default Drony passes traffic directly to the internet except if it comes from the QONQR app.
 The problem is that while Drony is running, there is a chance of network traffic being corrupted so I often get spammed by connection and ssl errors.
 So I have to either continue sacrificimg my network integrity or stop getting assistance ppaying QONQR :-/
 
 Does anyone know an alternative to Drony (basically an app that can connect you to a proxy without root using the android vpn api, if possible with filtering by app or ip)?
 Also does anyone else have problems with drony on Android 9 or other versions? I don't really have an opportunity to test it.
 
 Edit: It only took 4 tries to post this yay3
- 
				    					
					
					why... WHY do I always attract all sorts of weird problems...
 
 I feel like it makes me look incompetent :/
 
 Like this side-gig. I had a client who brought us essentially half a rack (20 blade servers, 7 units of network equipment) and asked us to spin it up. No passwords, no topology - nothing. It was my first such "project".
 
 So I'm setting it all up, using chatgpt and notions of vlan theory from college years ago. I managed to make smth work. Went away for the rest of the day. Hours later I come back -- no longer can connect to ovpn running on a MikroTik router. wtf... connect to office router's vpn, winbox via mac to the router to see wtf. Everything seems alright, except when I try to `/ip route print` it just hangs there. Tried a few times. -- same result. As if routes just got borked while noone was touching it. Found someone who's working with networks wtf, he said he's NEVER seen this happening. A router reboot sorted this out. That's weird problem #1.
 
 I finished reverse-engineering and re-setting up the networking, sketched a topology with patching scheme and asked colleagues to take it all to the DC. They did it, connected it all up. 5 nodes aren't accessible via network. So I connect remotely to the router's openvpn and try to see what's up. Indeed, some servers are reachable, others aren't; even though MT switch (router's downlink) sees those servers plugged in with link up, servers don't see the link. I noticed some ports aren't trunking some VLANs. I started adding those ports when the winbox connection dropped out of the blue. 5-4-3-2-1-reconnecting... it reconnected. Yayy!! But wait, where is everything...? All interfaces -- gone (physical ones too). All IPs -- gone. All routes -- gone. Everything's gone. Half a minute later I'm disconnected again. The switch IP is no longer pingable. Servers plugged into it aren't reachable either. That's weird problem #2.
 
 Then I figured I might try to see whether I can see anything from the router level. Try to ssh to it -- attempt was dropped, as if 22/tcp was closed. wtf? It was working in the office. winbox into it -- yayy, that works. Try to open a terminal via winbox -- a dialog pops up "Terminal <1> - not permitted (9)". wtf..? I Google this error up, it says that user is a member of group that does not have telnet and ssh permission. Indeed, I loog into groups -- the group 'admin' does not have them. Try to add them -- also not permitted. And I'm the 'admin' user, a single user in the router after a factory reset. How the hell else do I change permissions if even admin is flipped a finger.
 That's weird problem #3
 
 And now I look like an incompetent prick with two left hands who is only breaking shit.
 And it's been like that my whole career
 
 Why... How... ffs, that's getting annoying. Maybe I should downgrade myself to a QA. Problems find me themselves, I don't even have to look for them2
- 
				    					
					
					Hello everyone, looking for some career advice here.
 
 First of let me list my credentials off here. I graduated in 2016 with a BS in Computer Science. While I was working on my degree I worked as an engineering for 3 years in a cell phone repair company. What this entailed was managing/reverse engineering a software solution of one of that companies vendors, writing documentation etc (it started as a summer internship and became a job that I worked full time over Summers and up to 30/week in the school year).
 
 Anyway, the vendor I acted as a point of contact offered me a job before I graduated and I started with them in May 2016 as a junior most Dev. Since then I have have maintained the same job tittle (software developer), however my duties have increased.
 
 Currently I maintain several of our build servers, manage software releases (as in I am the lead developer of this application) for the service that makes 90% of this companies money, and am the subject matter expert for everything regarding smartphone diagnostics. I've literally been entrusted with access to all of the company servers for if something goes wrong. I'm also training our newest developers and being told I'm doing a good job at doing so.
 
 Currently with my job on a day to day basis I'm working with Java, Android, C++, Golang, MongoDB, iOS in Objective C, and Python
 
 (Please note this is a small company of less than 50 people)
 
 Currently I'm only being paid 60k USD and am wondering if I should hold out for a raise or consider looking for a better job? ( Please note I live in the east coast in an area where the cost of living isn't absurd).
 Because this job was practically handed to me I don't know what to expect and feel imposter syndrome as I think I deserve better pay but think I don't have enough years experience. All advice is welcome4
- 
				    					
					
					Well one of my hobbies is making karaoke videos for songs I like to sing. So I'll look for an instrumental and if I cant find one make my own by reverse engineering an official audio track and removing the vocals xD then I use karaoke software to create the lyrics animation and stuff. It's pretty fun.
- 
				    					
					
					After 2 days of reverse engineering another developers code, I wish Laravel would go and die in a fire.3
- 
				    					
					
					How I hate all those people who think VisualStudio Code is Open Source. It's not! Read the f*cking license!
 https://code.visualstudio.com/licen...
 
 In fact, you aren't even allowed to inspect its network traffic. Not to mention reverse engineering. That's nowhere near OpenSource.
 
 You sure can download the source code, licensed as MIT, but building it won't give you the same piece of software.
 Don't believe in everything someone tells you. Use your brain and check the facts.12
- 
				    					
					
					6 hours of work before I actually wrote a line of code today. Reverse engineering stuff is interesting but not always fun
- 
				    					
					
					I think I've asked this before. Just cropped up again cuz I'm pushed to do some stuff in nextjs
 
 I Wonder how much longer before js framework devs realise they've been reverse engineering the browser this whole time, that the current browser spec was outdated since the dawn of Web fidelity and real time applications
 
 I wonder whether there are some guys who have seen this and are already cooking in the background. The browser still treats the Internet like front end and back end, whereas with the way apps are going (eg deprecation of the front/back end roles), it seems apparent the browser needs to scale up by fading whatever js is now
 
 I'm seeing "use server", which was one of php's infamous atrocities back in the day (lack of separation of concerns, everything in index.php). It's shocking how those who ridicule that language let this fly, but that's probably a separate thread. Point is, a bunch of these stuff done by front end frameworks seem like boilerplate but the syntax is far different from what I remember javaScript to be. I only vaguely recollect and understand what I'm reading
 
 Why not merge all the cryptic syntaxes struggling to achieve bare minimal expectations, into advanced markup language controlled by dom attributes? Overhaul and Rethink client - server communication to fit modern standard. Someone needs to step out of the box and take a good look at the rat race. I find our lives would be made much simpler if api integration into client side behaviour wasn't a separate thing altogether
 
 You have all these funny hoops and precarious bridges to cross. The reality is what we're fighting to overcome is the manner the architecture is setup. We need a Google/meta/amazon/apple to step in with a new browser since it's not a weekend gig and might need their reach to catch on with mainstream users. Sadly, they're the same guys rolling out new js frameworks1
- 
				    					
					
					Bitcoin malwares are everywhere.
 The hard part is doing reverse engineering and wondering why its feeding on only top of the stack in assembly
 Edit: Using IDA Pro
- 
				    					
					
					!Rant Now for some nice, relaxing (infuriating) reverse engineering.
 At least they were kind enough to use .Net1
- 
				    					
					
					Balancing final year CS with a startup that's that will be difficult and might end in a big payout, yay or nay?4
- 
				    					
					
					!rant
 
 Looking for some guidance on a final year college research project:
 
 I was going to look into hacking drones/toy helicopters/those Fitbit watch things or whatnot, but I'm not sure if it would go down well! Some technologies I'm looking to explore through this project include reverse engineering, machine learning and container technologies (docker, rkt) if that helps?
 
 Am I along the right lines or should I take a different approach with different topics? If so, an update on what's "hot" or upcoming at the moment would be helpful.
 
 Cheers!2
- 
				    					
					
					🚀 Vibe coding be like:
 👉 First 30 mins: "I don’t fully get what’s happening here…" 🤔
 👉 Next hour: magically works 💻✨
 👉 Then: you try one tiny change → AI confused → you confused → now you are reverse engineering your own code 😅
 But for real… AI is doing A LOT right now. The tricky part is knowing where to draw the line, discipline is the only guardrail. Sometimes you don’t even notice when you’ve crossed it.32
- 
				    					
					
					so, i tried following @ghost on daily.dev but there was no follow button so i did some reverse engineering and api fckery, all in 10 minutes. then got a whole ass undocumented api error code just for mr @ghost saying I can’t follow it. Then, the one follower before me: a daily.dev employee who probably admin abused and went into the database and followed to flex. when we all know, they suck. and they put such low effort into following such a rare account, then furthermore restricting others from doing it so he can be the only one. crazy. I wish I could do this: The exact opposite of what he did. Instead of denying following to one single account on daily.dev, allow anti-following (and deny following) one single account on daily.dev, which account to do that to? The employee who did this and their daily dev account… Anti-following in my idea is basically publicly saying “I hate you with a passion” on daily.dev. So, there. And since he made a custom api code restricting following the @ghost account, I’ll make a custom API code when trying to anti-follow another account or follow his: 3714957 (translating to “f…you” from old telephone language, if you’re confused, take each letter from the original word, get the number in the alphabet from the start it’s in. then divide it by 3. you’ll get a result close to each letter I made in that api code.) So yeah, nice day today. F. ck graphql and overprivileged employees. Ever heard of principle of the least privilege daily.dev CEO? I bet you give interns root. I regret signing up there. Peace :]3
- 
				    					
					
					Today after the week and a lesson time in an high-school I got back home and decided to play some sacred 2
 
 I had already installed some mods on it given that I have already finished it years ago and I wanted some challenge.
 
 It ends up that the mods add too much difficulty, so I open up the configuration files of the mod (some sort of Lua tables) and then spend like an hour and half doing some reverse engineering on it to find a middle way between the vanilla and the Uber difficult mod
 
 Wow!
- 
				    					
					
					Russians Engineer a Brilliant Slot Machine Cheat
 
 ...But as the “pseudo” in the name suggests, the numbers aren’t truly random. Because human beings create them using coded instructions, PRNGs can’t help but be a bit deterministic. (A true random number generator must be rooted in a phenomenon that is not manmade, such as radioactive decay.) PRNGs take an initial number, known as a seed, and then mash it together with various hidden and shifting inputs—the time from a machine’s internal clock, for example—in order to produce a result that appears impossible to forecast. But if hackers can identify the various ingredients in that mathematical stew, they can potentially predict a PRNG’s output. That process of reverse engineering becomes much easier, of course, when a hacker has physical access to a slot machine’s innards...
 
 https://wired.com/2017/02/... 1 1
- 
				    					
					
					What's the general process and toolset for reverse engineering a C++ DLL? I've never done this, but I may get a gig and I'm not about to reject it just because I don't know how to do the work.5
- 
				    					
					
					I was able to replace Okta Verify with an open source Python script and Android app and I wrote a tutorial for it:
 
 https://battlepenguin.com/tech/...
 
 Unfortunately it won't work for our companies VPN which requires Okta Push. After fighting with Security for a bit, it looks like I'll have to do a Part II where I reverse engineer the Okta Verify protocol.
- 
				    					
					
					Have you ever used Hibernate Tools for reverse engineering a database? Seems to work only on eclipse. Do you know of a process to configure eclipse to do what it's supposed to in a finite and predictable number of steps? Or the only way is an unpredictable trial and error process in which everythime a component is updated the stack stops working?
- 
				    					
					
					Anyone knows if u can make good money by reverse Engineering apks and looking for security holes? Anyone experienced in doing that and how much could u charge1
- 
				    					
					
					Reverse engineering with IDA, be like:
 Ow that makes sense, lets jmp there, nope thats not... aaah this must be the subroutine I was lookig for, nope thats not it, repeat.
- 
				    					
					
					HOW YOU CAN RECOVER YOUR CRYPTO FROM SCAMMERS // CONSULT DIGITAL TECH GUARD RECOVERY
 
 As a tech geek, I'm proud to be on the bleeding edge. So when I stored my Bitcoin in a "quantum-resistant" wallet, I was sure I was invincible, a Nostradamus of the modern age predicting the coming quantum computing apocalypse. "Hack-proof," the website had promised. "A fortress against the future."
 And then irony struck. A bug in the firmware shut me out altogether. No access. No backups. Only a chilly, machine-like error message mocking me like a bad guy in a sci-fi flick: "Invalid Signature. Please Reset." Reset? That would mean erasing my $860,000 in Bitcoin. Not exactly a pleasant choice.
 Furious, I did what any geek does when something is not right, I tweeted about it. My rant at the irony of a quantum-proof wallet crashing due to a widespread bug went viral. That is when a DM appeared. Digital Tech Guard Recovery's CTO had seen my tweet. "Let's fix this," he typed.
 Now, I’ve dealt with tech support before, but this was something else. Within hours, their engineers were deep in my wallet’s firmware, analyzing the cryptographic flaw. They approached the problem like time travelers fixing a paradox, reverse-engineering the bug to develop a workaround.
 It was a challenge. The wallet's special "quantum security" had locked it up so tightly that debugging tools couldn't even access it. But these guys were not your average IT support personnel; they were crypto Digitals.
 For ten days, I monitored their progress like a scientist awaiting a space probe signal. Finally, the breakthrough: a hacked firmware update, specifically tailored for my wallet model. With cautious steps, I executed their recovery protocol, and voilà, my money was restored.
 But they didn't leave it at that. Digital Tech Guard Recovery not only restored my Bitcoin but moved it to an even more secure, battle-tested storage system. No more cutting-edge vulnerabilities. Just solid, proven cryptography.
 The irony? My Bitcoin is now safer than ever, not because it's quantum-resistant, but because of the individuals who came to my aid.
 Lesson that was learned: The future is unpredictable, but having the right experts on speed dial? That's real security.
 
 WhatsApp: +1 (443) 859 - 2886
 
 Email @ digital tech guard . com
 
 Telegram: digital tech guard recovery . com
 
 Website link: digital tech guard . com1
- 
				    					
					
					HOW TO GET BACK LOST OR STOLEN CRYPTO / HIRE FUNDS RECLAIMER COMPANY
 
 WhatsApp +1 {361}250-4110
 
 Just last month, I passed through what every crypto investor dreads I lost 22 BTC to a sophisticated fake Bitcoin wallet app. It was a brutal and emotional blow. I had worked for years to build up that amount, only to watch it vanish in a matter of minutes. The scam was so convincing that I didn’t realize what had happened until it was too late. At first, I was overwhelmed with hopelessness, convinced I would never see my funds again. But then I discovered FUNDS RECLAIMER COMPANY, and everything changed. FUNDS RECLAIMER COMPANY is a specialized team of cryptocurrency investigators who focus on recovering stolen crypto assets. From the very first interaction, they were professional, empathetic, and transparent about what the process would involve. They didn’t make unrealistic promises, but they assured me they would do everything in their power to help. Their team began by reverse-engineering the malicious smart contract that had drained my wallet. They performed a deep dive into on-chain analysis, tracing the path of my stolen BTC through various blockchain networks. Using advanced Cryptocurrency forensics, they were able to pinpoint where my funds had been moved, which included several obscure Asian exchanges. Then came the negotiation stage, where they applied legal pressure and technical evidence to push these exchanges into freezing the accounts linked to the scammer. After nearly three intense weeks, FUNDS RECLAIMER COMPANY pulled off what I thought was impossible: they successfully recovered 20.9 BTC, which is about 95% of what I lost. I was stunned and deeply grateful. This taught me two things. First, scams in the crypto world are more common and complex than most people realize. Recovery is possible but only if you act quickly and work with FUNDS RECLAIMER COMPANY .If you or someone you know has been a victim of a crypto scam, don’t waste time in despair. Contact FUNDS RECLAIMER COMPANY immediately. Their skillset in digital forensics, and negotiation with exchanges is truly remarkable. Thanks to them, I not only recovered my Bitcoin but also regained my peace of mind. Don't give up help is out there , and FUNDS RECLAIMER COMPANY is the real deal. I strongly suggest FUNDS RECLAIMER COMPANY if you have lost money to a cryptocurrency fraud. They really save lives, and I am so appreciative of their assistance!2
- 
				    					
					
					HOW TO RECOVER CRYPTO ASSET THROUGH A RECOVERY FIRM //PASSCODE CYBER RECOVERY
 
 PASSCODE CYBER RECOVERY
 WhatsApp: +1(647)399-4074
 Telegram : @passcodecyberrecovery
 
 Just last month, I passed through what every crypto investor dreads. I lost 22 BTC to a sophisticated fake Bitcoin wallet app. It was a brutal and emotional blow. I had worked for years to build up that amount, only to watch it vanish in a matter of minutes. The scam was so convincing that I didn’t realize what had happened until it was too late. At first, I was overwhelmed with hopelessness, convinced I would never see my funds again. But then I discovered PASSCODE CYBER RECOVERY, and everything changed. PASSCODE CYBER RECOVERY is a specialized team of cryptocurrency investigators who focus on recovering stolen or lost crypto assets. From the very first interaction, they were professional, empathetic, and transparent about what the process would involve. They didn’t make unrealistic promises, but they assured me they would do everything in their power to help. Their team began by reverse-engineering the malicious smart contract that had drained my wallet. They performed a deep dive into on-chain analysis, tracing the path of my stolen BTC through various blockchain networks. Using advanced Cryptocurrency forensics, they were able to pinpoint where my funds had been moved, which included several obscure Asian exchanges. Then came the negotiation stage, where they applied legal pressure and technical evidence to push these exchanges into freezing the accounts linked to the scammer. After nearly three intense weeks, PASSCODE CYBER RECOVERY pulled off what I thought was impossible: they successfully recovered 20.9 BTC, which is about 95% of what I lost. I was stunned and deeply grateful. This taught me two things. First, scams in the crypto world are more common and complex than most people realize. Recovery is possible but only if you act quickly and work with PASSCODE CYBER RECOVERY .If you or someone you know has been a victim of a crypto scam, don’t waste time in despair. Contact PASSCODE CYBER RECOVERY immediately. Their skill set in digital forensics, and negotiation with exchanges is truly remarkable. Thanks to them, I not only recovered my Bitcoin but also regained my peace of mind. Don’t give up help is out there , and PASSCODE CYBER RECOVERY is the real deal.
 Britus Joshua2
- 
				    					
					
					How to Recover Lost Cryptocurrency or Access Your Wallet; VISIT CERTIFIED RECOVERY SERVICES
 
 Imagine this: A control room plastered with SpaceX posters, astronaut ice cream packets half-eaten, and me a self-proclaimed "Elon Lite", screaming at a frozen computer screen. My $680,000 Bitcoin stash, intended to be spent launching a satellite named Project Star bite, had just been left in the void of a glitched multi-sig wallet. Because of a firmware update so buggy, Windows 98 would seem solid by comparison. Tech support's solution? "Have you tried turning it off and on again? " Sir, I'm building hardware that is resistant to radiation belts. Your advice is a cosmic joke.
 The irony was galactic. My satellite could weather solar flares, but my crypto couldn't weather a run-of-the-mill update. The multi-sig setup of a fortress requiring three digital signatures had locked me out like an airlock seal. My co-founders panicked, flipping through code books like they were grimoires. Our mission control? A Slack channel with ???? emojis and increasingly more unhinged gifs.
 Then, a beacon: A coding board lurker who had survived a similar meltdown posted, "DM CERTIFIED RECOVERY SERVICES. They'll hack the Matrix." I slid into their inbox, praying for a bot. What I got was a reply sharper than the tip of a rocket: "Send us the debug logs of the wallet. And maybe a screenshot of the error before you rage-quit."
 Their engineers handled my case like a NASA anomaly investigation. They spent 17 days reverse-engineering the buggy code in the firmware, reconstituting lost signatures like repainting a shattered black box. I imagined them holed up in a command bunker, whiteboards filled with hex equations, complaining about "consensus algorithms" and "transaction malleability" between swigs of Red Bull. They danced around the bug by finding a loophole in the time-lock function of the wallet basically, beating time. Ha. Einstein didn't see that coming. When the email arrived in my inbox "Funds recovered. Proceed with launch." I nearly headbutted the ceiling. My Bitcoin reappeared on the screen, shining like a distant star long mapped home. The satellite team erupted. Someone popped champagne, soaking a $10,000 antenna prototype. Worth it.
 CERTIFIED RECOVERY SERVICES didn't just fix a bug; they re-wrote the code of catastrophe. Their blend of cryptographic genius and unflappable cool turned my facepalm-inducing defeat into a victory lap. Now, Project Star bite is on track again, and my wallet's firmware is secure like the nuclear codes.
 If your crypto ever gets lost in the stratosphere of tech failure, call the Wizards. They'll debug the abyss. Just possibly unplug the router before you update anything. And for the love of Mars, back up your keys.
 
 Here's Their Info Below:
 WhatsApp: (+1(740)258‑1417 )
 Telegram: https: //t.me/certifiedrecoveryservices3
- 
				    					
					
					Aren't we all, just pieces of pseudo softwares, reverse engineering our way to find our source code....🤔1
- 
				    					
					
					ETHEREUM AND USDT RECOVERY EXPERT- HIRE SALVAGE ASSET RECOVERY
 The moment my Bitcoin wallet froze mid-transfer, stranding $410,000 in cryptographic limbo, I felt centuries of history slip through my fingers. That balance wasn’t just wealth; it was a lifeline for forgotten libraries, their cracked marble floors and water-stained manuscripts waiting to breathe again. The migration glitch struck like a corrupted index: one second, funds flowed smoothly; the next, the transaction hung “Unconfirmed,” its ID number mocking me in glowing red. Days bled into weeks as support tickets evaporated into corporate ether. I’d haunt the stacks of my local library, tracing fingers over brittle Dickens volumes, whispering, “I’m sorry,” to ghosts of scholars past. Then, Marian—a silver-haired librarian with a crypto wallet tucked beside her ledger found me slumped at a mahogany study carrel. “You’ve got the blockchain stare,” she murmured, pressing a Post-it into my palm.
 Salvage Asset Recovery. “They resurrected my nephew’s Ethereum after a smart contract imploded. Go.”
 I emailed them at midnight, my screen’s blue glare mixing with moonlight through stained-glass windows. By dawn, their engineers had dissected the disaster. The glitch, they explained, wasn’t a hack but a protocol mismatch, a handshake between wallet versions that failed mid-encryption, freezing funds like a book jammed in a pneumatic tube. “Your Bitcoin isn’t lost,” assured a specialist named Leo. “It’s stuck in a cryptographic limbo. We’ll debug the transaction layer by layer.”
 Thirteen days of nerve-shredding limbo followed. I’d refresh blockchain explorers obsessively, clinging to updates: “Reverse-engineering OP_RETURN outputs…” “Bypassing nonce errors—progress at 72%...” My library blueprints, quotes for climate-controlled archives, plans for AR-guided tours sat untouched, their ink fading under my doubt. Then, on a frostbitten morning, the email arrived: “Transaction invalidated. Funds restored.” I watched, trembling, as my wallet repopulated $410,000 glowing like a Gutenberg Bible under museum lights.
 Salvage Asset Recovery didn’t just reclaim my Bitcoin; they salvaged a bridge between past and future. Today, the first restored library stands in a 19th-century bank building, its vault now a digital archive where blockchain ledgers track preservation efforts. Patrons sip fair-trade coffee under vaulted ceilings, swiping NFTs that unlock rare manuscript scans, a symbiosis of parchment and Python code.
 These assets are more than technicians; they’re custodians of legacy. When code fails, they speak its dead languages, reviving what the digital world dismisses as lost. And to Marian, who now hosts Bitcoin literacy workshops between poetry readings, you were the guardian angel this techno-hermit didn’t know to pray for.
 If your crypto dreams stall mid-flight, summon Salvage Asset Recovery. They’ll rewrite the code, rebuild the bridge, and ensure history never becomes a footnote. All thanks to Salvage Asset Recovery- their contact info
 TELEGRAM---@Salvageasset
 WhatsApp+ 1 8 4 7 6 5 4 7 0 9 6 1 1
- 
				    					
					
					🚀 “I Wanted GitHub Copilot in My Pocket — So I Built It Myself”
 
 For years, I’ve had this weird habit of coding from random places — cafés, buses, hospital waiting rooms, you name it. But every time inspiration hit, I found myself thinking the same thing:
 
 “Man, I wish I could just use Copilot on my phone.”
 
 It’s 2025. We’ve got AI writing novels, generating music, and summarizing 500-page research papers in 2 seconds — yet somehow, GitHub Copilot still refuses to leave the comfort of VS Code on desktop.
 
 So I decided to fix that.
 
 💡 The Idea
 
 It started as frustration — a “wouldn’t it be cool if” moment. I was halfway through an idea for a small project on a train, and my brain screamed:
 
 “Why can’t I just ask Copilot to finish this function right now?”
 
 VS Code was sitting at home, my laptop was dead, and all I had was my phone.
 
 That night, I scribbled this into my notes app:
 
 “Bridge Copilot from VS Code → phone → secure channel → no cloud.”
 
 At the time, it sounded insane. Who even wants to make their life harder by reverse-engineering Copilot responses and piping them into React Native?
 Apparently — me.
 
 🧩 The Architecture (aka “How to Lose Sleep in 4 Easy Steps”)
 
 The system ended up like this:
 
 VS Code Extension <-> WebSocket <-> Discovery API (Go + Redis) <-> React Native App
 
 Here’s how it works:
 
 The VS Code extension runs locally, listening to Copilot’s output stream.
 
 A Go backend acts as a matchmaker — helping my phone and PC find each other securely.
 
 The mobile app connects via WebSocket and authenticates with a 6-digit pairing code.
 
 Once paired, they talk directly. No repo data leaves your machine.
 
 It’s like a tiny encrypted tunnel between your phone and VS Code — only it’s not VPN magic, just some careful WebSocket dancing and token rotation.
 
 🛠️ The Stack
 
 Frontend (Mobile): React Native (Expo)
 
 Backend: Go + Redis for connection brokering
 
 VS Code Extension: TypeScript
 
 Security: JWT + rotating session keys
 
 AI Layer: GitHub Copilot (local interface)
 
 🧠 The Challenges
 
 There’s a difference between an “idea” and a “12-hour debugging nightmare that makes you question your life choices.”
 
 Cross-Network Discovery:
 How to connect phone and desktop on different networks?
 → A lightweight Redis broker that just handles handshakes.
 
 Security:
 I wasn’t making a mini TeamViewer for hackers.
 → Added expiring pairing codes, user-approval dialogs, and local-only token storage.
 
 Copilot Response Streaming:
 Copilot doesn’t have a nice public API.
 → Hooked into VS Code’s Copilot output and streamed it over WebSocket.
 (Yes, 2% genius and 98% madness.)
 
 UX:
 The first version had a 10-second delay.
 After optimizing WebSocket batching and Redis latency, it’s now near-instant.
 
 🤯 The “Holy Sh*t, It Works” Moment
 
 The first time my phone sent a prompt — and my VS Code actually answered with Copilot’s suggestion — I legit screamed.
 
 Like, full-on victory dance in the middle of the night.
 There’s something surreal about watching your phone chat with your desktop like they’re old coding buddies.
 
 Now I can literally say:
 
 “Copilot, write me a REST API,”
 and my phone responds with fully generated code pulled from my local VS Code instance.
 
 No VPN. No cloud syncing. Just pure, geeky magic.
 
 ⚡ The Lessons
 
 The hardest problems aren’t technical — they’re psychological.
 Fighting “this is impossible” is the real challenge.
 
 Speed matters more than perfection.
 Devs don’t want beauty; they want responsiveness. Anything over 1s feels broken.
 
 Security must never be an afterthought.
 I treated this like a bank tunnel between devices, not a toy.
 
 Build for yourself first.
 I didn’t make this for investors or glory — I made it because I wanted it.
 That’s the best reason to build anything.
 
 🧭 The Future
 
 Now that it’s working, I’m turning this experiment into something shareable.
 The dream: an app that lets every developer carry Copilot wherever they go — safely and instantly.
 
 Imagine debugging on your couch, or editing code in bed, or just whispering to your AI assistant while waiting for coffee.
 
 Phones today are more powerful than early NASA computers.
 Why shouldn’t they also be your code editor sidekick?
 
 So yeah, that’s my story.
 I built VSCoder Copilot — because I wanted to code from anywhere, and I refused to wait for permission.
 
 If you’ve ever built something just to scratch your own itch, you already know this feeling.
 That mix of frustration, caffeine, and late-night triumph that reminds you why you fell in love with coding in the first place.
 
 Because at the end of the day, that’s what we do:
 We make ideas real — one ridiculous hack at a time. 💻🔥9

















































































