Details
- 
						About.NET developer
- 
						SkillsC#
Joined devRant on 12/22/2018
			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
			
- 
				    
				    A fresh graduate software engineer applied to the company and passed the coding exam.
 
 Manager: Wow you got a very high score. Good job.
 
 Applicant: Thank you sir. So am I hired?
 
 Manager: Yes of course. You will be the team lead for one of the project.
 
 Applicant: Wait wut????8
- 
				    
				    So the job was for a web developer, specifically.
 We needed a person who was very confident with PHP, JS, HTML, CSS.
 
 This dude comes in, he says he's confident with all of them, we ask him how he would solve a problem we're having and he answers just like we answered the first time. Which is a good start.
 
 By the end of the interview, he just says: "ok, but like I'm not here to work as a developer"
 "WTF are you even here for, then?"
 "To work on anything else than that"
 "But we just need that"
 "I won't do it"
 "Ok, then, bye"8
- 
				    
				    "FOAAS (Fuck Off As A Service) provides a modern, RESTful, scalable solution to the common problem of telling people to fuck off."
 https://foaas.com/
 
 I think the world needed this13
- 
				    
				    My girlfriend is amazing:
 
 After a long uphill battle trying to finish a huge open source project I started months ago. She noticed I was getting a little deflated.
 So she donated a small amount to the donation page to lift my spirits.
 She wanted to do it secretly but didn't know that it wasnt anonymous.
 
 The little things spur us on.40
- 
				    
				    At the office at 7am when no one is around. It's huge, open, and empty, with that classic morning peace-and-quiet vibe. Lasts about 2 hours
- 
				    
				    I've found and fixed any kind of "bad bug" I can think of over my career from allowing negative financial transfers to weird platform specific behaviour, here are a few of the more interesting ones that come to mind...
 
 #1 - Most expensive lesson learned
 
 Almost 10 years ago (while learning to code) I wrote a loyalty card system that ended up going national. Fast forward 2 years and by some miracle the system still worked and had services running on 500+ POS servers in large retail stores uploading thousands of transactions each second - due to this increased traffic to stay ahead of any trouble we decided to add a loadbalancer to our backend.
 
 This was simply a matter of re-assigning the IP and would cause 10-15 minutes of downtime (for the first time ever), we made the switch and everything seemed perfect. Too perfect...
 
 After 10 minutes every phone in the office started going beserk - calls where coming in about store servers irreparably crashing all over the country taking all the tills offline and forcing them to close doors midday. It was bad and we couldn't conceive how it could possibly be us or our software to blame.
 
 Turns out we made the local service write any web service errors to a log file upon failure for debugging purposes before retrying - a perfectly sensible thing to do if I hadn't forgotten to check the size of or clear the log file. In about 15 minutes of downtime each stores error log proceeded to grow and consume every available byte of HD space before crashing windows.
 
 #2 - Hardest to find
 
 This was a true "Nessie" bug.. We had a single codebase powering a few hundred sites. Every now and then at some point the web server would spontaneously die and vommit a bunch of sql statements and sensitive data back to the user causing huge concern but I could never remotely replicate the behaviour - until 4 years later it happened to one of our support staff and I could pull out their network & session info.
 
 Turns out years back when the server was first setup each domain was added as an individual "Site" on IIS but shared the same root directory and hence the same session path. It would have remained unnoticed if we had not grown but as our traffic increased ever so often 2 users of different sites would end up sharing a session id causing the server to promptly implode on itself.
 
 #3 - Most elegant fix
 
 Same bastard IIS server as #2. Codebase was the most unsecure unstable travesty I've ever worked with - sql injection vuns in EVERY URL, sql statements stored in COOKIES... this thing was irreparably fucked up but had to stay online until it could be replaced. Basically every other day it got hit by bots ended up sending bluepill spam or mining shitcoin and I would simply delete the instance and recreate it in a semi un-compromised state which was an acceptable solution for the business for uptime... until we we're DDOS'ed for 5 days straight.
 
 My hands were tied and there was no way to mitigate it except for stopping individual sites as they came under attack and starting them after it subsided... (for some reason they seemed to be targeting by domain instead of ip). After 3 days of doing this manually I was given the go ahead to use any resources necessary to make it stop and especially since it was IIS6 I had no fucking clue where to start.
 
 So I stuck to what I knew and deployed a $5 vm running an Nginx reverse proxy with heavy caching and rate limiting linked to a custom fail2ban plugin in in front of the insecure server. The attacks died instantly, the server sped up 10x and was never compromised by bots again (presumably since they got back a linux user agent). To this day I marvel at this miracle $5 fix.1
- 
				    
				    A huge project came my way at work. Old spaghetti code, no source control, no test env and every other possible challenge you could think of. Based on my initial quote a deadline of June 19th was approved. Two days ago the president of the company tells my boss it needs to be done by Friday, no excuses. Horrible timing since I'm moving tomorrow and am off all next week. Not to mention I'm the only dev at the company that understands/knows how to work on this code. We also don't have a budget to contract out. Literally not possible to do in 2 days. I proposed a "quick fix" solution and new design which was approved. I Spent 2 straight days working on it with overtime, no lunch hour, and the president checking on me every hour for status updates. Managed to implement my "quick fix" and just put it live 2 hours ago. President approved, and said "thanks". He then sent an email to the company and all our agents across the country anouncing the change. In the email he directly thanks the Marketing dept and the "senior leadership team" for "making the quick turnaround of this request possible". He proceeds to name specific people responsible for making this happen. No where does he mention my name or my department. Not that I'm actually surprised but it would have been nice to get some recognition considering this literally wouldn't have worked without me. Guess I should be used to it by now. I'm also now on call during my week off in case anything breaks.12
- 
				    
				    dear api author at my company pt. 2:
 
 If you're gonna create an api method that takes some arguments.
 
 And one of those arguments is an array.
 
 THEN MAKE THE FUCKING ARGUMENT'S NAME PLURAL YOU FUCKING PIECE OF SHIT.
 
 REPEAT WITH ME, MOTHERFUCKER.
 ARRAY, PLURAL, NON-ARRAY, SINGULAR.
 
 I need to pass a shitload of filters for the data for this table, and for every suckin fuckin filter I need to singularize this shit. Thank god for es6.
 
 I know this sounds like nitpick, but I swear to fucking alpha omega this guy is inconsistent as fuck.
 
 Every time it feels like he makes up a new rule.
 
 Sometimes I need to send arrays of ids, other times arrays of objects with an id property on each.
 
 He uses synonyms too, sometimes it's remove, other times erase.
 
 PICK ONE MOTHERFUCKER.
 
 If you can't do the basic things well, then what is to expect of more advanced stuff?
 
 Naming conventions you fucking idiot, follow them. It's programming 101.
 
 You're already sending them as plural in the fucking response. Why change them for the request?
 
 And that's just style, conventions.
 
 This idiot asshole also RARELY DOES ANY FUCKING CHECK ON THE ARGUMENTS.
 
 "Oh, you sent a required argument as null? 500"
 
 We get exceptions on sentry UP THE ASS thanks to this useless bone container.
 
 YOU'RE SEEING THE EXCEPTIONS TOO!!!!! 500'S ARE BUGS YOU NEED TO FIX, YOU CUMCHUGGER
 
 And sometimes he does send 400, you know what the messages usually are?
 "Validation failed".
 
 WHYYYYYY YOU GODDAMN APATHETIC TASTELESS FUCK???
 WHAT EXACTLY CAUSED THE FUCKING VALIDATION TO FAIL????
 
 EXCEPTIONS HAPPEN AND THANKS TO YOU I HAVE NO IDEA WHY.
 
 The worst of all... the worst of fucking all is that everytime I make a suggestion to change shit, every time, you act like you care.
 You act like the api is the way it is because you designed it in a calculated manner.
 
 MOTHERFUCKER. IF A USER HAS ONLY PRODUCT A, THEN HE SHOULDN'T BE ABLE TO ACCESS DATA FOR PRODUCT B. IT IS NOT ENOUGH TO JUST RESTRICT SHIT WITH ADMIN ROLES. IDIOT!!!!!
 
 This is the work of someone who has no passion for programming.10
- 
				    
				    Well look at me, high as fuck and drunk past reasoning fixing the production environment. Wish me luck.1




