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 - "time for an upgrade"
		- 
				    					
					
					"You gave us bad code! We ran it and now production is DOWN! Join this bridgeline now and help us fix this!"
 
 So, as the author of the code in question, I join the bridge... And what happens next, I will simply never forget.
 
 First, a little backstory... Another team within our company needed some vendor client software installed and maintained across the enterprise. Multiple OSes (Linux, AIX, Solaris, HPUX, etc.), so packaging and consistent update methods were a a challenge. I wrote an entire set of utilities to install, update and generally maintain the software; intending all the time that this other team would eventually own the process and code. With this in mind, I wrote extensive documentation, and conducted a formal turnover / training season with the other team.
 
 So, fast forward to when the other team now owns my code, has been trained on how to use it, including (perhaps most importantly) how to send out updates when the vendor released upgrades to the agent software.
 
 Now, this other team had the responsibility of releasing their first update since I gave them the process. Very simple upgrade process, already fully automated. What could have gone so horribly wrong? Did something the vendor supplied break their client?
 
 I asked for the log files from the upgrade process. They sent them, and they looked... wrong. Very, very wrong.
 
 Did you run the code I gave you to do this update?
 
 "Yes, your code is broken - fix it! Production is down! Rabble, rabble, rabble!"
 
 So, I go into our code management tool and review the _actual_ script they ran. Sure enough, it is my code... But something is very wrong.
 
 More than 2/3rds of my code... has been commented out. The code is "there"... but has been commented out so it is not being executed. WT-actual-F?!
 
 I question this on the bridge line. Silence. I insist someone explain what is going on. Is this a joke? Is this some kind of work version of candid camera?
 Finally someone breaks the silence and explains.
 
 And this, my friends, is the part I will never forget.
 
 "We wanted to look through your code before we ran the update. When we looked at it, there was some stuff we didn't understand, so we commented that stuff out."
 
 You... you didn't... understand... my some of the code... so you... you didn't ask me about it... you didn't try to actually figure out what it did... you... commented it OUT?!
 
 "Right, we figured it was better to only run the parts we understood... But now we ran it and everything is broken and you need to fix your code."
 
 I cannot repeat the things I said next, even here on devRant. Let's just say that call did not go well.
 
 So, lesson learned? If you don't know what some code does? Just comment that shit out. Then blame the original author when it doesn't work.
 
 You just cannot make this kind of stuff up.104
- 
				    					
					
					Father bought a PC in 1997. Back then very few had it. I learned doing things like accessing the internet and sending emails, among others. I remember having added age on websites to be allowed to sign up at times :P My sisters used to play games on it sometimes. The first few ones we had were Tomb Raider: The Last Revelation, Tomb Raider Chronicles, American McGee's Alice(Which caused us to upgrade the PC xD)... And some others.
 
 I have a memory of this pseudo-3D-looking game where you move in a maze and try answering questions. I want to remember its name, but I cannot :(
 
 We literally have video evidence of me liking the computer as a child, yet my parents either say I'm addicted or deny I've ever liked it before. Not only that, but continuously limiting my time with the PC hasn't been a literal obstacle in my way of trying to do things in their opinion. Funny how my parents think the last few years I've been my worst when they've hurt me in those years so much that our relationship is guaranteed not working out. There were doubts in my head before, but now it's cemented and there is no way of going back. Father, for example, tells me it's too late to do anything with a PC now(As well as how I've been unable to use the PC. He looks at these pro players' footage in some TV show and he's like, „You've been unable to use your hobbies“, as if they have never ever screamed at me for perceived gaming and not actually cared to check), and I need to look for a „real“ job.
 
 Sorry. I went to bed at 2:00 in the morning. Feel like a zombie because of ongoing weirdly insufficient sleep, even though I sleep kinda more than normal. Even when I took Melatonine for that it didn't help at all.
 
 Childhood was where beating began. I was about 6/7. Right when I entered school. The first school that I attended was a private one and supposedly for „Wunderkinds“, while in reality I haven't seen a SINGLE teacher or psychologist approve of it, their argument being that children were basically drowned in work that wasn't age-appropriate(I don't mean anything bad. Just that teaching about Galaxies and all in first grade isn't the brightest idea). There was always a mountain of homework to do and as opposed to some other countries, we had to do it on a day to day basis. We didn't have a week-long deadline. I was predictably not keeping up with it as I could have, had it been a normal amount, so my parents decided I didn't want to study and began their methods of getting me to „study“. I have yet to see a person able to keep up with that school's tempo, no matter the age.
 
 This place was also where I got bullied. I felt I had nowhere to be: At home, the parents' situation, at school, the bully. I never really went outside to play with other children, so I missed that part of childhood.
 
 After the second year of school I was transferred to an advanced German school, called like that because they taught German and not English there. I also got to learn a bit of Russian before they removed it from school. In that period I used to attend ballet. But for less than a year. And piano, which I remember having attended for quite a long while, some years, if my memory isn't fried. I quit it because of it having been forced on me. Last piece I ever played fully was Beethoven's Marmotte.
 
 In this school I was once again the outcast of the class. I had some people to interact with. All of those interactions lasted a few years at most. Then, because of a part of my class choosing me as a laughing-stock N2 and another girl as the N1, I found my best friend, who I still have today. She's the only friend I have nearby.
 
 Most of the time I hated myself. Even today I struggle with that sometimes.
 
 After that came university. This us where I got something like a friend circle at last. But it still didn't last. I got in a relationship with one of the guys, but I was just attracted. There was another I couldn't dare getting close to. Turns out he also had something for me. Then he disappeared from our lives and a year after, I still cannot forget the person. If I want to, I have to deprive myself of my own personality. Not a thing I'm willing to give up. Then I broke up with the guy I was in a relationship with and completely disappeared from the friendship circle. To be honest, I had reasons to. They refused to even try to look for the guy and they called him a friend for years. Sometimes parents hitting me can occur even today, but if I REALLY piss them off.
 
 Now I'm here and oh, my God, I'm officially am aunt now! My sister gave birth to a daughter this morning... She's in Berlin with mother and both she and the child are doing great. I just hope she manages to be a good mother.20
- 
				    					
					
					Welcome back to practiseSafeHex's most incompetent co-worker!
 
 *sitcom audience cheers*
 
 Thank you, thank you. Ok so far we've had a developer from hell and a CEO who shot to fame for being the first rectum to receive a passport and be given a job.
 
 2 pretty strong entrants if you ask me. But its time to slow it down and make sure everyone gets a fair chance. Its not all just about the psychopaths and assholes, what about the general weirdo's and the stoners who just made life awkward?
 
 So here we go, Most incompetent co-worker, candidate 3, "A".
 
 "A" was a bit of an unusual developer, despite having a few years experience in his home country, he applied for an unpaid internship to come work with us ... probably should have rang alarm bells but hey we were all young and dumb back then.
 
 I had to say I felt very bad for A, as he suffered from 2 very serious, and job crippling personal conditions / problems
 
 - Email induced panic attacks
 - Extreme multifaceted attachment disorder (also known in layman terms as "get the fuck away from me, and do your job" syndrome)
 
 While he never openly discussed these conditions, it was clear from working with him, that he had gone undiagnosed for years. Every time an email would come in no matter how simple ... even the services team asking to confirm his staff ID, would send him into a panic causing him to drop everything he was doing and like a homing missile find me anywhere in the building and ask me what to do.
 
 Actually "A" also suffered from a debilitating literacy issue too, leaving him completely unable to read our internal wiki's himself. Every week we had to follow a set of steps to upgrade something and every week to mask his issue, he'd ask me what to do instead ... no matter how many times I sat with him previously ... must have been truly embarrassing for him.
 
 But "A"'s finest moment in the company, by far, was the day where out of the blue, at the top of his voice (as if wearing headphones ... without wearing headphones) he asked
 
 "DO YOU KNOW ANYONE WHO SELLS POT?"
 
 ... why no, manager of the entire department standing behind you, I do not
 
 ... why no, tech lead talking to manager, I do not
 
 ... why hello 50% of my team staring at me ... no "A", I do not!
 
 Needless to say all our team meetings were a little awkward for the next few weeks after that but hey who doesn't like being thought of as a stoner / drug dealer by their team mates huh?
 
 Will A make it to the top of the list of most incompetent? Well he has some truly logic defining competition yet to be announced.
 
 Tune in later for more practiceSafeHex's most incompetent co-worker!!!14
- 
				    					
					
					I'm not an iOS expert, I just wanted to get Google ads on my iOS app so that I could make a few petty dollars at the expense of my users. Is that too much to ask?
 
 I started by following Google's instructions: install cocoapods, copy and paste some swift code... Compile failed, app broke. Carefully retrace my steps. Nothing.
 
 Stackoverflow (praise be with them) suggests upgrading Xcode. Go to app store and click to upgrade Xcode. No progress bar, no status updates, just that pissy little spinner for several minutes. I become impatient try a few more times. It ain't happening.
 
 Stackoverflow (holy of holies, defender of the weak) points me to an alternate source for Xcode, on the app store dev console. 4GB and some time later, an attempt to unzip gives "unknown error". Genocide of sorts.
 
 Stackoverflow (all that is pure, all that is kind, all... I think you get it) says upgrade your OS. I tried months ago but I had issues with that pissy little spinner. Persist. 5GB and a "heavy-year" of time later (sorry), it installs. Then Xcode installs. Then bar a few errors, the app compiles.
 
 So after almost 24 hours, life resumes. The lesson.. respond to all obscure iOS errors by upgrading. If fully upgraded, calmly acquire a baseball bat and destroy your machine. Make sure you have a good book nearby in case of either event.
 
 Thank you for reading my rant. Now if you'll excuse me, I have to pay Apple
 $150 so that I may list my app in the app store.11
- 
				    					
					
					Things have been a little too quiet on my side here, so its time for an exciting new series:
 
 practiseSafeHex's new life as a manager.
 
 Episode 1: Dealing with the new backend team
 
 It's great to be back folks. Since our last series where we delved into the mind numbing idiocy of former colleagues, a lot has changed. I've moved to a new company and taken a step up as a Dev manager / Tech lead. Now I know what you are all thinking, sounds more dull and boring right? Well it wouldn't be a practiseSafeHex series if we weren't ...
 
 <audience-shouting>
 DEALING! ... WITH! ... IDIOTS!
 </audience-shouting>
 
 Bingo! so lets jump right in and kick us off with a good one.
 
 So for the past few months i've been on an on-boarding / fact finding / figuring out this shit-storm, mission to understand more about what it is i'm suppose to do and how to do it. Last week, as part of this, I had the esteemed pleasure of meeting face to face with the remote backend team i've been working with. Lets rattle off a few facts to catch us all up:
 
 - 8 hour time difference to me
 - No documentation other than a non-maintained swagger doc
 - Swagger is reporting errors and several of the input models are just `Type: String`
 - The one model that seems accurate, has every property listed as optional, including what must be the primary key
 - Properties go missing and get removed at the drop of a hat and we are never told.
 - First email I sent them took 27 days to reply, my response to that hasn't been answered so far 31 days later (new record! way to go team, I knew we could do it!!!)
 - I deal directly with 2 of them, the manager and the tech lead. Based on how things have gone so far, i've nick named them:
 1) Ass
 2) Hole
 
 So lets look at some example of their work:
 
 - I was trying to test the new backend, I saw no data in QA. They said it wouldn't show up until mid day their time, which is middle of the night for us. I said we need data in our timezone and I was told: a) "You don't understand how big this system is" (which is their new catch phrase) b) "Your timezone is not my concern"
 
 - The whole org started testing 2 days later. The next day a member from each team was on a call and I was asked to give an update of how the testing was going on the mobile side. I said I was completely blocked because I can't get test data. Backend were asked to respond. They acknowledged they were aware, but that mobile don't understand how big the system is, and that the mobile team need to come up with ideas for the backend team, as to how mobile can test it. I said we can't do anything without test data, they said ... can you guess what? ... correct "you don't understand how big the system is"
 
 - We eventually got something going and I noticed that only 1 of the 5 API changes due on their side was done. Opened tickets. 2 days later asked them for progress and was told that "new findings" always go to the bottom of the backlog, and they are busy with other things. I said these were suppose to be done days ago. They said you can't give us 2 days notice and expect everything done. I said the original ticket was opened a month a go *sends link* ......... *long silence* ...... "ok, but you don't understand how big the system is, this is a lot of work"
 
 - We were on a call. Product was asking the backend manager (aka "Ass") a question about a slight upgrade to the new feature. While trying to talk, the tech lead (aka "Hole") kept cutting everyone off by saying loudly "but thats not in scope". The question was "is this possible in the future" and "how long would it take", coming from management and product development. Hole just kept saying "its not in scope", until he was told to be quiet by several people.
 
 - An API was sending down JSON with a string containing a message for the user with 2 bits of data inside it. We asked for one of those pieces to also come down as a property as the string can change and we needed it client side. We got that. A few days later we found an edge case and asked for the second piece of data to be a property too. Now keep in mind, they clearly already have access to them in order to make the string. We were told "If you keep requesting changes like this, you are going to delay the release of the backend by up to 2 weeks"
 
 Yes folks, there you have it, the most minuscule JSON modifications, can delay your release by up to 2 weeks ........ maybe I should just tell product, that they don't understand how big the app is, and claim we can't build it on our side? Seems to work for them
 
 Thats all the time we have for today,
 
 Tune in for more, where we'll be looking into such topics as:
 
 - If god himself was an iOS developer ... not
 - Why automate when you can spend all day doing it by hand
 - Its more time-efficient to just give everything a story point of 5
 - Why waste time replying to emails ... when you can do nothing instead
 
 See you all next week,
 practiseSafeHex13
- 
				    					
					
					This is kind of a horror story, with a happing ending. It contains a lot of gore images, and some porn. Very long story.
 
 TL;DR Network upgrade
 
 Once upon a time, there were two companies HA and HP, both owned by HC. Many years went by and the two companies worked along side each one another, but sometimes there were trouble, because they weren't sure who was supposed to bill the client for projects HA and HP had worked on together.
 
 At HA there was an IT guy, an imbecile of such. He's very slow at doing his job, doesn't exactly understand what he's doing, nor security principles.
 
 The IT guy at HA also did some IT work for HP from time to time when needed. But he was not in charge of the infrastructure for HP, that was the jobb for one developer who didn't really know what he was doing either.
 
 Whenever a new server was set up at HP, the developer tried many solutions, until he landed on one, but he never removed the other tested solutions, and the config is scattered all around. And no documentation!!
 Same goes with network, when something new was added, the old was never removed or reconfigured to something else.
 
 One dark winter, a knight arrived at HP. He had many skills. Networking, server management, development, design and generally a fucking awesome viking.
 This genius would often try to cleanse the network and servers, and begged his boss to let him buy new equipment to replace the old, to no prevail.
 Whenever he would look in the server room, he would get shivers down his back.
 (Image: https://i.bratteng.xyz/Ie9x3YC33C.j...)
 
 One and a half year later, the powerful owners in HA, HP and HC decided it was finally time to merge HA and HP together to HS. The knight thought this was his moment, he should ask CEO if he could be in charge of migrating the network, and do a complete overhault so they could get 1Gb interwebz speeds.
 
 The knight had to come up with a plan and some price estimates, as the IT guy also would do this.
 The IT guy proposed his solution, a Sonicwall gateway to 22 000 NOK, and using a 3rd party company to manage it for 3000 NOK/month.
 "This is absurd", said the knight to the CEO and CXO, "I can come up with a better solution that is a complete upgrade. And it will be super easy to manage."
 The CEO and CXO gave the knight a thumbs up. The race was on. We're moving in 2 months, I got to have the equipment by then, so I need a plan by the end of the week.
 He roamed the wide internet, looked at many solutions, and ended up with going for Ubiquiti's Unifi series. Cheap, reliable and pretty nice to look at.
 
 The CXO had mentioned the WiFi at HA was pretty bad, as there was WLAN for each meeting room, and one for the desks, so the phone would constantly jump between networks.
 So the knight ended up with this solution:
 2x Unifi Securtiy Gateway Pro 4
 2x Unifi 48port
 1x Unifi 10G 16port
 5x Unifi AP-AC-Lite
 12x pairs of 10G unifi fibre modules
 All with a price tag around the one Sonicwall for 22 000 NOK, not including patch cables, POE injectors and fibre cables.
 
 The knight presented this to the CXO, whom is not very fond of the IT guy, and the CXO thought this was a great solution.
 But the IT guy had to have a say at this too, so he was sent the solution and had 2 weeks to dispute the soltion.
 Time went by, CXO started to get tired of the waiting, so he called in a meeting with the knight and the IT guy, this was the IT guys chance to dispute the solution.
 All he had to say was he was familiar with the Sonicwall solution, and having a 3rd party company managing it is great.
 He was given another 2 weeks to dispute the solution, yet nothing happened.
 
 The CXO gave the thumbs up, and the knight orders the equipment.
 At this time, the knight asks the IT guy for access to the server room at HA, and a key (which would take 2 months to get sorted, because IT guys is a slow imbecile)
 
 The horrors, Oh the horrors, the knight had never seen anything like this before.
 (Image: https://i.bratteng.xyz/HfptwEh9qT.j...)
 (Image: https://i.bratteng.xyz/HfptwEh9qT.j...)
 (Image: https://i.bratteng.xyz/hmOE2ZuQuE.j...)
 (Image: https://i.bratteng.xyz/4Flmkx6slQ.j...)
 
 What are all these for, why is there a fan ductaped to on of the servers.
 WHAT IS THIS!
 Why are there cables tied in a knot.
 WHY!
 These are questions we never will know the answers too.
 
 The knight needs access to the servers, and sonicwall to see how this is configured.
 After 1.5 month he gains access to the sonicwall and one of the xserve.
 What the knight discovers baffles him.
 All ports are open, sonicwall is basically in bridge mode and handing out public IPs to every device connected to it.
 No VLANs, everything, just open...10
- 
				    					
					
					I think I've shown in my past rants and comments that I'm pretty experienced. Looking back though, I was really fucking stupid. Since I haven't posted a rant yet on the weekly topics, I figure I would share this humbling little gem.
 
 Way back in the ancient era known as 2009, I was working my first desk job as a "web designer". Apparently the owner of this company didn't know the difference between "designer", which I'm not, and "developer", which I am, nor the responsibilities of each role.
 
 It was a shitty job paying $12/hour. It was such a nightmare to work at. I guess the silver lining is that this company now no longer exists as it was because of my mistake, but it was definitely a learning experience I hold in high regard even today. Okay, enough filler...
 
 I was told to wipe the Dev server in order to start fresh and set up an entirely new distro of Linux. I was to swap out the drives with whatever was available from the non-production machines, set up the RAID 5 array and route it through the router and firewall, as we needed to bring this Dev server online to allow clients to monitor the work. I had no idea what any of this meant, but I was expected to learn it that day because the next day I would be commencing with the task.
 
 Astonishingly, I managed to set up the server and everything worked great! I got a pat on the back and the boss offered me a 4 day weekend with pay to get some R&R. I decided to take the time to go camping. I let him know I would be out of town and possibly unreachable because of cell service, to which he said no problem.
 
 Tuesday afternoon I walked into work and noticed two of the field techs messing with the Dev server I built. One was holding a drive while the other was holding a clipboard. I was immediately called into the boss's office.
 
 He told me the drives on the production server failed during the weekend, resulting in the loss of the data. He then asked me where I got the drives from for the Dev server upgrade. I told him that they came from one of the inactive systems on the shelf. What he told me next through the deafening screams rendered me speechless.
 
 I had gutted the drives from our backup server that was just set up the week prior. Every Friday at midnight, it would turn on through a remote power switch on a schedule, then the system would boot and proceed to copy over the production server's files into an archive for that night and shutdown when it completed. Well, that last Friday night/Saturday morning, the machine kicked on, but guess what didn't happen? The files weren't copied. Not only were they not copied, but the existing files that got backed up previously we're gone. Why? Because I wiped those drives when I put them into the Dev server.
 
 I would up quitting because the conversation was very hostile and I couldn't deal with it. The next week, I was served with a suit for damages to this company. Long story short, the employer was found in the wrong from emails I saved of him giving me the task and not once stating that machine was excluded in the inactive machines I could salvage drives from. The company sued me because they were being sued by a client, whose entire company presence was hosted by us and we lost the data. In total just shy of 1TB of data was lost, all because of my mistake. The company filed for bankruptcy as a result of the lawsuit against them and someone bought the company name and location, putting my boss and its employees out of a job.
 
 If there's one lesson I have learned that I take with the utmost respect to even this day, it's this: Know your infrastructure front to back before you change it, especially when it comes to data.8
- 
				    					
					
					This is dedicated to all Webdevs, especially those WordPress fanboys.
 
 I was reflecting on some things since I do more frequent freelance jobs at the time. And I have to admit: people are fucking crazy.
 
 I had some serious talk with customers and some serious talk for people I work as subsidiary.
 
 The average customer thinks a nice webpage costs I'm 9-50 bucks. They got some shitty Webhosting for 1-5$/month including domain and think they are set.
 
 They have unclear visions about what they actually want, it all boils down to "I like the design". I made a page for someone who just posted images, no text nothing and I told him a trillion times NEEDS some text, even a fucking picture description would be sufficient, else he'll never score anything at google.
 
 Ofc it got denied, now he's bitching how nobody finds the site when they google his name. The other thing is that Wordpress became the solution for everything.
 
 I'm a fucking certified magento developer and I hate magento with a passion. Magento is an overabstracted clusterfuck and believe me, I did the certification I had to learn more than average about the core. But damn, don't slap woocommerce on everything.
 
 Narrowninded fucktards, the cheap out of the box solution isn't always the best.
 
 Don't cry if you got hacked because you were too dumb to upgrade your wordpress. Don't tell me to do some "enhancements" on a server you probably share with 100 other uses. I can't fix your Webserver with your shitty ftp account.
 
 I also hate WordPress with a burning passion. Cum guzzling cavetroll it is. It has it usages, but don't rely on a core So small every kind of extra functionality has to somehow tinkered on it and then expect it to work flawlessly and for 10$ price.
 
 Of course you can buy a theme that, if it would have been special made for you cost 800$ or more, but it wasn't. It just looks like it from the outside. If you want customization you are at the mercy of the option it provides. I can't even tell how many times i spent whole evenings explaining how their shiny template works. Just to do some crazy shit with JavaScript like rearranging domelements because it didn't work as expected.
 
 I still stay to my word. Nothing great has been nor will be created with a Wordpress core. Don't tell me how some great stuff has been achieved. Or wait, please do so. But before you do think about if that wouldn't been faster, cheaper, more reliable , etc... if done with a framework like symphony or laravel... or even zend or cake.
 
 And that brings me back to the point:
 Is cheap and "out of the box" really what you need and desire? As customer and as developer?6
- 
				    					
					
					#3 Worst thing I've seen a co-worker do?
 
 A 20-something dev, 'A', back in the early days of twitter+facebook would post all his extracurricular activities (drinking, partying, normal young-buck stuff). The dev mgr, 'J', at the time took offense because he felt 'A' was making the company look bad, so 'A' had a target on his back. Nothing 'A' did was good enough and, for example, 'J' had the source control czars review 'A's code to 'review' (aka = find anything wrong). Not sorting the 'using' statements, and extra line after the closing }, petty things like that. For those curious, orders followed+carried out by+led by 'T' in my previous rant.
 
 As time went on and 'T' finding more and more 'wrong' with A's code, 'J' put A on disciplinary probation. 'A' had 90 days to turn himself around, or else.
 
 A bright spot was 'A' was working on a Delphi -> C# conversion, so a lot of the code would be green-field development and by simply following the "standards", 'A' would be fine...so he thought.
 
 About 2 weeks into the probation, 'A' was called into the J's office and berated because the conversion project was behind schedule, and if he didn't get the project back on track, 'A' wouldn't make it 30 days. I sat behind 'A' and he unloaded on me.
 <'A' slams his phone on his desk>
 Me: "Whoa...whats up?"
 A: "Dude, I fucking hate this place, did you hear what they did?"
 <I said no, then I think we spent an hour talking about it>
 Me: "That all sucks. Don't worry about the code. Nobody cares what T thinks. Its not even your fault the project is behind, the DBAs are tasked with upgrades and it's not like anyone is waiting on you. It'll get done when it's done. Sounds like a witch hunt, what did you do? Be honest."
 A: "Well, um...I kinda called out J, T, and those other assholes on facebook. I was drunk, pissed, and ...well...here we are."
 Me: "Geez, what a bunch of whiney snowflakes. Keep your head down and you'll get thru it, or don't. Its not like you couldn't find another job tomorrow."
 A: "This is my first job out of college and I don't want to disappoint my dad by quitting. I don't even know what I'm supposed to be doing. All J told me was to get better. What the fuk does that even mean?"
 Me: "He didn't give you any goals? Crap, for someone who is a stickler for the rules, that's low, even for J."
 
 Fast forward 2 weeks, I was attending MS TechEd and I was with another dev mgr, R.
 
 R: "Did you hear? We had to let 'A' go today."
 Me: "What the hell? Why?"
 R: "He couldn't cut it, so we had to let him go."
 Me: "Cut what? What did he do, specifically?"
 R: "I don't know, 'A' was on probation, I guess he didn't meet the goals."
 Me: "You guess? We fire a developer working on a major upgrade and you guess? What were these so-called goals?"
 R: "Whoa...you're getting a little fire up. I don't know, maybe not adhering to coding standards, not meeting deadlines?"
 Me: "OMG...we fire people for not forming code? Are you serious!?"
 R: "Oh...yea...that does sound odd when you put it that way. I wish I'd talk to you before we left on this trip"
 Me: "What?! You knew they were firing him *before* we left? How long did you know this was happening?"
 R: "Honestly, for a while. 'A' really wasn't a team player."
 Me: "That's dirty, the whole thing is dirty. We've done some shitty things to people, but this is low, even for J. The probation process is meant to improve, not be used as a witch hunt. I don't like that you stood around and let it happen. You know better."
 R: "Yea, you're right, but doesn't change anything. J wanted to do it while most of us were at the conference in case 'A' caused a scene."
 Me: "THAT MAKES IT WORSE! 'A' was blindsided and you knew it. He had no one there that could defend him or anything."
 R: "Crap, crap, crap...oh crap...jeez...J had this planned all along...crap....there is nothing I can do no...its too late."
 Me: "Yes there is. If 'A' comes to you for a letter of recommendation, you write one. If someone calls for reference, you give him a good one."
 R: "Yea..yea...crap...I feel like shit...I need to go back to the room and lie down."
 
 As the sun sets, it rises again. Within a couple of weeks, 'A' had another job at a local university. Within a year, he was the department manager, and now he is a vice president (last time I checked) of a college in Kansas City, MO.10
- 
				    					
					
					This rant means YOU if you are one of those people that "fix" their family's computers.
 
 I was visiting my family over the holidays and while I managed to stay away from fixing their computers for the most time, I offered to help my grandfather to update the Garmin navigation device he wanted to gift my father. (They do not use smartphones for navigation, and my father doesn't want "these modern shitty phones".)
 
 When booting up my grandfather's laptop, I realized something odd: Linux Mint boot screen. Wut?
 
 And immediately I said: "It could be impossible to update your navigation device on this laptop."
 
 As true enough, the Garmin Express update software requires either a Windows PC or a Mac; and even though I vaguely hoped it might be possible to upgrade through Linux, I just could not be bothered to find out that day.
 
 What I wondered though is why did my grandfather of all people ran Linux!?
 
 Don't get me wrong, I use Linux myself on my work machine and I never want to work with something else when coding; yet my grandfather is an end user of the show-me-where-and-what-and-how-often-to-click-kind.
 
 What could he gain by it?
 
 As it turns out, the computer nerd's friend of my uncle managed his PC. And my uncle and he decided unanimously my grandfather should better run Linux. Is it something my grandfather needs? No. BUT IT'S RIGHT! Suck it up! (My father's laptop therefore also runs Linux Mint. So he can't upgrade his new device either.)
 
 This is the ugly kind of entitled nerd-dom I truly detest.
 
 When discussing things further, my grandfather told me that he had problems ever since with his printer. Under Windows, he knew how to print on the special photo paper. Under Linux, all he can barely manage is to print on normal papers. Shame, printing photos was the only thing he liked doing on that device. What did my uncle's friend tell him?
 
 "Get a decent printer!"
 
 Fuck that guy.
 
 It's fine if Linux works for you, but before you install it on a PC of a relative, you better make sure it fits their needs! If you have that odd member that only wants to write letters, read emails, use facebook, and wants to play that browser game, feel free to introduce them to Linux.
 
 Yet if they have any special wish, don't stand in their way.
 
 If they want to do something that requires a certain OS, don't just decide for them that their desire is wrong, but help them achieve their goal. If you can't align that with your ideology, then get the fuck out of my way and stop "helping".
 
 For some people, a computer is a device to achieve a certain goal, a work. They only get hindered by your ill-advised attempts at virtue signalling.8
- 
				    					
					
					This story starts over two years ago... I think I'm doomed to repeat myself till the end of time...
 
 Feb 2014
 [I'm thrust into the world of Microsoft Exchange and get to learn PowerShell]
 
 Me: I've been looking at email growth and at this rate you're gonna run out of disk space by August 2014. You really must put in quotas and provide some form of single-instance archiving.
 Management: When we upgrade to the next version we'll allocate more disk, just balance the databases so that they don't overload in the meantime.
 
 [I write custom scripts to estimate mailbox size patterns and move mailboxes around to avoid uneven growth]
 
 Nov 2014
 Me: We really need to start migration to avoid storage issues. Will the new version have Quotas and have we sorted out our retention issues?
 Management: We can't implement quotas, it's too political and the vendor we had is on the nose right now so we can't make a decision about archiving. You can start the migration now though, right?
 Me: Of course.
 
 May 2015
 Me: At this rate, you're going to run out of space again by January 2016.
 Management: That's alright, we should be on track to upgrade to the next version by November so that won't be an issue 'cos we'll just give it more disk then.
 
 [As time passes, I improve the custom script I use to keep everything balanced]
 
 Nov 2015
 Me: We will run out of space around Christmas if nothing is done.
 Management: How much space do you need?
 Me: The question is not how much space... it's when do you want the existing storage to last?
 Management: October 2016... we'll have the new build by July and start migration soon after.
 Me: In that case, you need this many hundreds of TB
 Storage: It's a stretch but yes, we can accommodate that.
 
 [I don't trust their estimate so I tell them it will last till November with the added storage but it will actually last till February... I don't want to have this come up during Xmas again. Meanwhile my script is made even more self-sufficient and I'm proud of the balance I can achieve across databases.]
 
 Oct 2016 (last week)
 Me: I note there is no build and the migration is unlikely since it is already October. Please be advised that we will run out of space by February 2017.
 Management: How much space do you need?
 Me: Like last time, how long do you want it to last?
 Management: We should have a build by July 2017... so, August 2017!
 Me: OK, in that case we need hundreds more TB.
 Storage: This is the last time. There's no more storage after August... you already take more than a PB.
 Management: It's OK, the build will be here by July 2017 and we should have the political issues sorted.
 
 Sigh... No doubt I'll be having this conversation again in July next year.
 
 On the up-shot, I've decided to rewrite my script to make it even more efficient because I've learnt a lot since the script's inception over two years ago... it is soooo close to being fully automated and one of these days I will see the database growth graphs produce a single perfect line showing a balance in both size and growth. I live for that Nirvana.6
- 
				    					
					
					November 2022
 
 *Wife*: What do you want for x-mas? A new phone maybe? Yours has lived through a lot already - perhaps it's time for an upgrade?
 *I*: Naah, thanks. My trusty S7 still works incredibly well. I also have all those 2FAs set up there and stuff I'm too lazy to transfer over to a new device.
 
 *Parents*: What do you want for–//–
 *I*: Naah, thanks. My tr–//–
 
 *in-laws*: What do you want for–//–
 *I*: Naah, thanks. My tr–//–
 
 *Siblings*: What do you want for–//–
 *I*: Naah, thanks. My tr–//–
 
 January 2023:
 *My phone*: 5 5
- 
				    					
					
					I did it: I built up another PC identical to my machine (https://devrant.com/rants/2923002/...) for my SO and installed Linux Mint for her, too. That had been my primary motive for an easy and stable distro in the first place.
 
 Now that didn't come out of the blue. We were discussing the end of Win 7 already two years ago where I brought up my concerns with Win 10 - mainly the forced, lousy updates and the integrated spyware, and that I was considering Linux as way out.
 
 I had expected quite some pushback because she had been exclusively on Windows since the 90s. However, I didn't sell Linux as upgrade. It's just that Win 7 is over, progress under Windows as well, and we're in damage control mode. Went down pretty well.
 
 Fast forward three weeks - remember, first time Linux user and no IT-geek:
 
 - it just works, including web, videos, and music.
 - she likes Cinnamon.
 - nice desktop themes.
 - Redshift is as good as f.lux.
 - software installation is just like an app store.
 - updates work via an easy tray icon.
 - quote: "Linux is great!"
 - given this alternative, she doesn't understand why people willingly put up with Win 10.
 - no drive letters: already forgotten.
 - popcorn for upcoming Win 10 disaster stories.
 - why do Windows updates take that long?
 - why does Windows need to reboot for every update?
 - why does Windows hang in that update boot screen for so long?
 
 I'm impressed that Linux has come so far that it's suitable for end users. Next in line is her father who wants to try Linux, but that will be a story for tomorrow.14
- 
				    					
					
					Yesterday (or the day before that depending on your timezone and day-night schedule - this Friday) my OnePlus 6T arrived. After only 2 days of time between placing the order and actually getting the phone, quite impressive!
 
 The DHL guy asked me upon receipt - is it the OnePlus 6T? - Yes it is!! - "An amazing device it is!", he said. And honestly.. he couldn't be more right.
 
 I might be a bit biased on this because after all I did just spend €630 on this phone. But it feels so snappy, high quality, the 8GB of RAM is just.. it blows my mind. But I'm sure that the other reviews did this sort of jazz already.
 
 The things that set this phone apart for me though were the following.
 
 When I get a new phone or tablet, usually the first thing I do is rooting it. This one was no different, about an hour after receipt it was successfully rooted and loaded with Magisk. Currently I'm still in the phase of "getting to know the phone", wherein fuckups are usual. This time again being no different - I removed some apps and apparently did something to it that the search engines - both Google and DuckDuckGo - didn't quite like, as both of them would crash upon application launch. Me in full panic mode of course, desperately trying to find the stock ROM (which doesn't seem to be present in its usual form) or a new set of GApps (which didn't resolve the issue). OnePlus does seem to offer its OTA updates in zip archives though. So I downloaded its latest update (same as what was on the device) and applied it.
 
 That's when the nerdgasm happened.
 
 The "update" was simply a matter of going into the settings, tapping this and that and applying the update. No recovery, no unrooting, no nothing. The update just went like that despite the phone being rooted and just having had TWRP flashed to it. I always wanted this sort of thing, which even the Nexus couldn't offer - having the cake and eating it too. Being able to root the device and muck around with it while still being able to update the device timely without too many hurdles. This fucking thing does it!!!
 
 That is to say, after my initial nerdgasm I did find that it bulldozed over my su binary (effectively unrooting the thing), custom emoji I've set (iOS 12 because fuck Google's most recent emoji set) and some other things. But those are easy to install back, much more so than it would've been to download a whole Android release and dirty flash it, as it was on the Nexus.
 
 Other than that, battery life, dash charging (edit: on that topic, it does remain cool like a cucumber despite getting 15-20W of power jammed into it, quite impressive!), snappiness, the usual jazz.. eh, as I said earlier that's the usual reviewer stuff. But this feature of being able to upgrade the phone while it's modified, that's something which seems to be severely underrated by those.
 
 Oh and during kernel builds, I couldn't quite get the source to work - probably due to my lack of experience with builds of Android kernels - but I did find that this phone actually exposes its kernel config through /proc/config.gz as it should. None of my MediaTek devices do this, so that's something that I found really appealing. Always nice to see when a manufacturer exposes this information to give you a stock sort of config that you can be rest assured will work configuration-wise. And it allows you to see what the stock kernel is actually built with, which again is really nice. I quite like this! It really encourages further development.11
- 
				    					
					
					I've caught the efficiency bug.
 
 I recently started a minimum wage job to get my life back in order after a failed 2 year project (post mortem: next time bring more cash for a longer runway)
 
 I've noticed this thing I do at every job, where I see inefficiency and I think "how can I use technology to automate myself out of this job?"
 
 My first ever application was in C++ for college (a BASIC interpreter) and it's been so long I've since forgotten the language.
 
 But after a while every language starts to look like every other language, and you start to wonder if maybe the reason you never seriously went anywhere as a programmer was because you never really were cut out for it.
 
 Code monkey, sure. Programmer? Dunno, maybe I just suffer from imposter syndrome.
 
 So a few years back I worked at a retail chain. Nothing as big as walmart, but they have well over 10k store locations. They had two IBM handscanners per store, old grungy ugly things, and one of these machines would inevitably be broken, lost or in need of upgrade/replacement about once a year, per location. District manager, who I hit it off with, and made a point of building report with, told me they were paying something like $1500 a piece.
 
 After a programming dry spell, I picked up 'coding' with MIT app inventor. Built a 'mostly complete' inventory management app over the course of a month, and waited for the right time.
 
 The day of a big store audit, (and the day before a multi-regional meeting), I made sure I was in-store at the same time as my district manager, so he could 'stumble upon' me working, scanning in and pricing items into the app.
 
 Naturally he asked about it, and I had the numbers, the print outs, and the app itself to show him. He seemed impressed by what amounted to a code monkeys 'non-code' solution for a problem they had.
 
 Long story short, he does what I expected, runs it by the other regionals and middle executives at the meeting, and six months later they had invested in a full blown in house app, cutting IBM out of the mix I presume.
 
 From what I understand they now use the app throughout the entire store chain.
 
 So if you work at IBM, sorry, that contract you lost for handscanners at 10k+ stores? Yeah that was my fault (and MIT app inventor).
 
 They say software is 'eating the world' but it really goes to show, for a lot of 'almost coders' and 'code monkeys' half our problem is dealing with setup and platform boilerplate. I think in the future that a lot of jobs are either going to be created or destroyed thanks to better 'low code' solutions, and it seems to be a big potential future market.
 
 In the mean while I've realized, while working on side projects, that maybe I can do this after all, and taken up Kotlin. I want to do a couple of apps for efficiency and store tracking at my current employer to see if I'm capable and not just an mit app-inventor codemonkey after all.
 
 I'm hoping, by demonstrating what I can do, I can use that as a springboard into an internal programming position at my current gig (which seems to be a company thats moving towards a more tech oriented approach to efficiency and management). Also watching money walk out the door due to inefficiency kinda pisses me off, and the thought of fixing those issues sounds really interesting. At the end of the day I just like learning new technologies, and maybe this is all just an excuse to pick up something new after spending so long on less serious work.
 
 I still have a ways to go, but the prospect of working on B2B, and being able to offer technological solutions to common and recurring business needs excites the hell out of me..as cringy and over-repeated as that may sound.7
- 
				    					
					
					So I'm back from vacation! It's my first day back, and I'm feeling refreshed and chipper, and motivated to get a bunch of things done quickly so I can slack off a bit later. It's a great plan.
 
 First up: I need to finish up tiny thing from my previous ticket -- I had overlooked it in the description before. (I couldn't test this feature [push notifications] locally so I left it to QA to test while I was gone.)
 
 It amounted to changing how we pull a due date out of the DB; some merchants use X, a couple use Y. Instead of hardcoding them, it would use a setting that admins can update on the fly.
 
 Several methods deep, the current due date gets pulled indirectly from another class, so it's non-trivial to update; I start working through it.
 
 But wait, if we're displaying a due date that differs from the date we're actually using internally, that's legit bad. So I investigate if I need to update the internals, too.
 
 After awhile, I start to make lunch. I ask my boss if it's display-only (best case) and... no response. More investigating.
 
 I start to make a late lunch. A wild sickness appears! Rush to bathroom; lose two turns.
 
 I come back and get distracted by more investigating. I start to make an early dinner... and end up making dinner for my monster instead.
 
 Boss responds, tells me it's just for display (yay!) and that we should use <macro resource feature> instead.
 
 I talk to Mr. Product about which macros I should add; he doesn't respond.
 
 I go back to making lunch-turn-dinner for myself; monster comes back and he's still hungry (as he never asks for more), so I make him dinner.
 
 I check Slack again; Mr. Product still hasn't responded. I go back to making dinner.
 
 Most of the way through cooking, I get a notification! Product says he's talking it through with my boss, who will update me on it. Okay fine. I finish making dinner and go eat.
 
 No response from boss; I start looking through my next ticket.
 
 No response from boss. I ping him and ask for an update, and he says "What are you talking about?" Apparently product never talked to bossmang =/ I ask him about the resources, and he says there's no need to create any more as the one I need already exists! Yay!
 
 So my feature went from a large, complex refactor all the way down to a -1+2 diff. That's freaking amazing, and it only took the entire day!
 
 I run the related specs, which take forever, then commit and push.
 
 Push rejected; pull first! Fair, I have been gone for two weeks. I pull, and git complains about my .gitignore and some local changes. fine, whatever. Except I forgot I had my .gitignore ignored (skipped worktree). Finally figure that out, clean up my tree, and merge.
 
 Time to run the specs again! Gems are out of date. Okay, I go run `bundle install` and ... Ruby is no longer installed? Turns out one of the changes was an upgrade to Ruby 2.5.8.
 
 Alright, I run `rvm use ruby-2.5.8` and.... rvm: command not found. What. I inspect the errors from before and... ah! Someone's brain fell out and they installed rbenv instead of the expected rvm on my mac. Fine, time to figure it out. `rbenv which ruby`; error. `rbenv install --list`; skyscraper-long list that contains bloody everything EXCEPT 2.5.8! Literally 2.5 through 2.5.7 and then 2.6.0-dev. asjdfklasdjf
 
 Then I remember before I left people on Slack made a big deal about upgrading Ruby, so I go looking. Dummy me forgot about the search feature for a painful ten minutes. :( Search found the upgrade instructions right away, ofc. I follow them, and... each step takes freaking forever. Meanwhile my children are having a yelling duet in the immediate background, punctuated with screams and banging toys on furniture.
 
 Eventually (seriously like twenty-five minutes later) I make it through the list. I cd into my project directory and... I get an error message and I'm not in the project directory? what. Oh, it's a zsh thing. k, I work around that, and try to run my specs. Fail.
 
 I need to update my gems; k. `bundle install` and... twenty minutes later... all done.
 
 I go to run my specs and... RubyMine reports I'm using 2.5.4 instead of 2.5.8? That can't be right. `ruby --version` reports 2.5.8; `rbenv version` reports 2.5.8? Fuck it, I've fought with this long enough. Restarting fixes everything, right? So I restart. when my mac comes back to life, I try again; same issue. After fighting for another ten minutes, I find a version toggle in RubyMine's settings, and update it to 2.5.8. It indexes for five minutes. ugh.
 
 Also! After the restart, this company-installed surveillance "security" runs and lags my computer to hell. Highest spec MacBook Pro and it takes 2-5 seconds just to switch between desktops!
 
 I run specs again. Hey look! Missing dependency: no execjs. I can't run the specs.
 
 Fuck. This. I'll just push and let the CI run specs for me.
 
 I just don't care anymore. It's now 8pm and I've spent the past 11 hours on a -1+2 diff!
 
 What a great first day back! Everything is just the way I left it.rant just like always eep; 1 character left! first day back from vacation miscommunication is the norm endless problems ruby6
- 
				    					
					
					Odd things that non-technically-inclined people do, say, or believe:
 
 "Back in my day we didn't have our faces planted in cell phones!" True, but they sure did love them some magazines and newspapers.
 
 "I don't need internet! I need that 'wee-fee'" -- from my wife's stories about one of her clients, who wanted to set up WiFi.
 
 A restaurant owner who, in 2017 mind you, refuses to upgrade his phone above a touch-tone with a handheld receiver.
 
 When my wife, son, and I were visiting her aunt and uncle in Florida, her uncle kept asking her help on how to configure his smart phone. She's a saleswoman and I'm a computer engineer. Not complaining, just an observation. Actually I'm glad because I can avoid a million questions that I won't ever have time for.
 
 When someone in line at the store causes a glitch in the chip reader because they don't know how to follow directions on-screen. Then they blame "those damn computers!" during a verybquick reboot.
 
 People who enjoy sunshine. I don't understand this obsession that non-technical people have with sunny days. Maybe if I were on a tropical beach drinking whisky all day, but I live in NYS so...
 
 When I'm describing a computer program I put a lot of effort into, only to have the conversation derailed adter thirty seconds by an hour-long family gossip section.2
- 
				    					
					
					DEAR CTOs, PLEASE ASK THE DEVELOPER OF THE SOFTWARE WHICH YOU ARE PLANNING TO BUY IN WHAT LANGUAGE AND WHAT VERSION THEY ARE WRITTEN IN.
 
 Background: I worked a LONG time for a software company which developed a BIG crm software suite for a very niche sector. The softwary company was quite successfull and got many customers, even big companies bought our software. The thing is: The software is written in Ruby 1.8.7 and Rails 2. Even some customer servers are running debian squeeze... Yes, this setup is still in production use in 2022. (Rails 7 is the current version). I really don't get it why no one asked for the specific setup, they just bought it. We always told our boss, that we need time to upgrade. But he told every time, no one pays for an tech upgrade... So there it is, many TBs of customer data are in systems which are totally old, not updated and with possibly security issues.9
- 
				    					
					
					Sometimes I really fucking hate this company
 
 The code is an absolute shitshow filled with static classes, untestable and duplicate code, on top of that my boss doesn’t like open source
 
 Yeah so i’m not allowed to use a mapping library or something because “Uhhh like uhh we don’t have a contract with the company so who knows what’ll happen when the maintainers leave the project”
 I understand his reasoning but it’s an absolutely retarded reasoning especially considering most of the .NET platform is open source nowadays
 
 Writing a webapp from scratch now as well and I HAVE to use vanilla javascript and AngularJS 1.5 even though all the developers here told me they would like to upgrade to Typescript and Angular 2+ but it’s never gonna happen I suppose
 
 Oh and he doesn’t like TDD and our only product is SAAS so imagine the amount of bugs being pushed simply because we don’t have time to write tests or even manually test, let alone refactor our horseshit codebase
 
 AND i have to pay for gas myself which takes 200€ out of my bank account a month just for driving to work whilst I’m only getting a mediocre pay
 
 Have a job interview tomorrow and another one on tuesday4
- 
				    					
					
					So here's my setup.
 Minimalist and clean, the only environment I can work in.
 
 My laptop spends way more time at home now-a-days since I bought the iPad Pro 12.9 2017... It's just so practical to take to lectures.
 
 As for my desktop... well my keyboard definitely needs an upgrade... Any suggestions on a good keyboard?
 
 My alcohol shrine, keeps me sane 😂😍. Let's see your setups. 12 12
- 
				    					
					
					I do not like the direction laptop vendors are taking.
 
 New laptops tend to feature fewer ports, making the user more dependent on adapters. Similarly to smartphones, this is a detrimental trend initiated by Apple and replicated by the rest of the pack.
 
 As of 2022, many mid-range laptops feature just one USB-A port and one USB-C port, resembling Apple's toxic minimalism. In 2010, mid-class laptops commonly had three or four USB ports. I have even seen an MSi gaming laptop with six USB ports. Now, much of the edges is wasted "clean" space.
 
 Sure, there are USB hubs, but those only work well with low-power devices. When attaching two external hard drives to transfer data between them, they might not be able to spin up due to insufficient power from the USB port or undervoltage caused by the impedance (resistance) of the USB cable between the laptop's USB port and hub. There are USB hubs which can be externally powered, but that means yet another wall adapter one has to carry.
 
 Non-replaceable [shortest-lived component] mean difficult repairs and no more reserve batteries, as well as no extra-sized battery packs. When the battery expires, one might have to waste four hours on a repair shop for a replacement that would have taken a minute on a 2010 laptop.
 
 The SD card slot is being replaced with inferior MicroSD or removed entirely. This is especially bad for photographers and videographers who would frequently plug memory cards into their laptop. SD cards are far more comfortable than MicroSD cards, and no, bulky external adapters that reserve the device's only USB port and protrude can not replace an integrated SD card slot.
 
 Most mid-range laptops in the early 2010s also had a LAN port for immediate interference-free connection. That is now reserved for gaming-class / desknote laptops.
 
 Obviously, components like RAM and storage are far more difficult to upgrade in more modern laptops, or not possible at all if soldered in.
 
 Touch pads increasingly have the buttons underneath the touch surface rather than separate, meaning one has to be careful not to move the mouse while clicking. Otherwise, it could cause an unwanted drag-and-drop gesture. Some touch pads are smart enough to detect when a user intends to click, and lock the movement, but not all. A right-click drag-and-drop gesture might not be possible due to the finger on the button being registered as touch. Clicking with short tapping could be unreliable and sluggish. While one should have external peripherals anyway, one might not always have brought them with. The fallback input device is now even less comfortable.
 
 Some laptop vendors include a sponge sheet that they want users to put between the keyboard and the screen before folding it, "to avoid damaging the screen", even though making it two millimetres thicker could do the same without relying on a sponge sheet. So they want me to carry that bulky thing everywhere around? How about no?
 
 That's the irony. They wanted to make laptops lighter and slimmer, but that made them adapter- and sponge sheet-dependent, defeating the portability purpose.
 
 Sure, the CPU performance has improved. Vendors proudly show off in their advertisements which generation of Intel Core they have this time. As if that is something users especially care about. Hoo-ray, generation 14 is now yet another 5% faster than the previous generation! But what is the benefit of that if I have to rely on annoying adapters to get the same work done that I could formerly do without those adapters?
 
 Microsoft has also copied Apple in demanding internet connection before Windows 11 will set up. The setup screen says "You will need an Internet connection…" - no, technically I would not. What does technically stand in the way of Windows 11 setting up offline? After all, previous Windows versions like Windows 95 could do so 25 years earlier. But also far more recent versions. Thankfully, Linux distributions do not do that.
 
 If "new" and "modern" mean more locked-in and less practical and difficult to repair, I would rather have "old" than "new".10
- 
				    					
					
					Coming back here after years to rant about... myself.
 TLDR: I fucked up and now have to call a thousand people as a dev, I'm not even getting paid for it and they all get crazy about a random ID that got assigned to them, so now I want to throw away all my electronics and become a skilift operator.
 
 Stupid me deployed a project shortly before we have the largest amount of orders in the year. (Like 90% of yearly orders in a couple minutes cause they are sold out fast and people wait to order first)
 
 I got this horrible legacy "plain self written framework php" project which I tried to upgrade state of the art.
 There was one piece missing to upgrade everything and nicely deploy it to some fresh new servers which can handle the high load which peaks at the time orders open.
 
 So I did it the day before orders open and... everything worked well! Nothing crashed.
 I wrote my client to wait a little before he confirms the orders, since after confirmation each of the people who ordered will receive an email where they can choose a unique number which they'll receive as a sticker with the order.
 
 Since it's an event my client is promoting, people will meet each other wearing those unique stickers and being able to identify each other online and in person with this number.
 
 Suddenly my clients call me that "customers are complaining about that there is something wrong"
 Turned out he confirmed all orders straight away and that part of the application which makes the number unique was broken on the update.
 So everyone could chose any number (also taken ones) as his "unique" number.
 
 In my panic, I told my client "It's my mistake, I'll deal with it of course and call the affected people in my free time, since it's my mistake you don't have to pay for it". (it's my largest client by far, am a freelancer)
 Realizing when people can chose any number it'll not be a few ones who have the same, it's like almost everyone did chose "69", "1", "420", "88 (a scary amount of people)",... (with 69 being the number being chosen by most people btw, even more then "1")
 
 So now I have to call about a thousand people telling them a new random ID will be assigned to them. I thought of course about mailing them, wrote a script that deals with the issue automatically, and FUCKED IT UP TOO so everyone is confused and the only way to deal with it is by a call basically.
 And while I'm sitting here now for 2 days straight calling people in my free time about their random ID will have to change, I realized that some people are quite crazy about random ID's.
 I'm talking about yelling and threatening because "is it too much to ask for a working website when ordering this expensive product".
 
 I hate my life right now and am getting quite serious about throwing all my electronic devices away and become a skilift operator instead. Fuck the higher pay, it's not worth the shit, I wanna have only responsibility about one button to press while watching people fall on their face.4
- 
				    					
					
					It is time... to rant about macs!
 
 No, seriously - I had such a different experience about which not many talk in real life or pretend that it never happens....
 
 Model: 2015 mid MBP 15" with second to highest specs (don't have dedicated gpu).
 
 Rattling fucking toy.... Yea, it rattles! If you shake/move ir sit in trait/bus - it non-stop rattles as a fucking toy. Worst part? It's confirmed issue by apple and it manifacturing issue that they are not keen on fixing!!!! WTF? We have 4 macs in our office - all of them fucking rattles... God help me how annoying that is. (Lose LCD control panel that unsticks from glue. Replacing it solves the issue for 1 month if you carry it anywhere).
 
 Constant fucking crashing/updates.... Every morning I wake up and don't have an app that requires confirmation for restart - it's restarted. YAY, turning on all apps once again.... Why you may ask? Well, because if you tinker with software in any way - it fails to update it and hell breaks lose. It's been a long time since High-Sierra came around and the issue is still there (not running Mojave as it conflicts with soft I have... Woo!). Tried few times - updates fail. Resolution? Reinstall OS!
 
 OS conflicts with applications - damn... People told me it works out of the box.... Yeah, as long as you don't upgrade the OS - then it breaks. Why? Well, because.
 
 Piece of shit power supply. With 4 of our office power supplies - 2 of them failed twice withing warranty and once afterwards... Really? Not to mention that all 4 are starting to shear the sleeve or already did (mine is just wrapped with white electrical tape to give it a support... lol).
 
 Bluetooth - who the hell needs that in mac, right? Well, people do. To start with - it conflicts with 2.4GHz wireless network - you might have one of those and not both at the same time. Next thing is using a device that needs constant connection (mouse, headphones, keyboard - non apple branded) - shit... They can't stay connected for more than an hour without any issues... Constant battle to re-connect it, to re-pair the device and all due to smart apple bluetooth settings. Hell, my mouse (logitech MX master) was even printing random symbols in some applications if moved. All of the issues went away after using a bluetooth dongle... WOO!!!!
 
 Xcode... Ahh, you may never prepare your mac if you don't download 17GB of fucking xCode libraries that enables some tools to be installed/runned as you can NOT get them in any other way and you have to install full xCode software in order to get them... YAY! 17GB wasted on my 256GB SSD that I can't upgrade. GREAT!
 
 OsX applications - ah, don't get offended but if you are using them and you are fine with them - you are probably a monkey that loves being told what to do. You can't customise any actions, you can't configure it the way you like - either you accept their default workflow or go kill yourself. Yep... Had issues with calendar, mail, iMessages, safari... None of them fit my needs :)
 
 Resolution scaling... Fucking hell, the display is 2880 x 1800 but all you let me to use is 1440x900 without scaling? Am I blind to you? Scaling the resolution means that you are fucked if some applications don't support scaling very well. Looking at you Jetbrains - your IDES suck at scaling and slows down the pc to a potato....
 
 Now the pros - keyboard is way better than the new ones, trackpad is GREAT - no need for mouse (using it on external 4k displays only), the battery life is great - getting around 6h of continues development time, 8 if using sublime instead of phpStorm and well, that's about it...
 
 To clarify:
 I've bought this device due to the fact that at that time mac and windows pc's with similiar specs costed the same while windows pc sucked with their quality of the device and trackpad... Now the situation is better and when time comes for a next upgrade - it's going to be one of these:
 Razer Blade 15, Dell XPS 15, Lenovo Carbon X1 series.
 And of course - LINUX. I've had enough issues with windows, and had enough of retardness of apple ecosystem, so switching it is a must for me.
 
 Disclaimer: I might be an unhappy customer, a bit picky but I'd like my device to be setted up as I like and continue to have that until I don't like, not until the company decides to break it. Not to mention that paying almost a yearly salary in my country for one device - I'd expect it to be at least reliable and work without issues....
 
 Rant over.
 
 ps. You can disagree with me, this is my personal experience with MBP over the last 3 years :)8
- 
				    					
					
					Oh look. The monitoring channel is in flames, smartphone is vibrating so hard it's having a seizure.
 
 Hm. Nah it's fine. Not my...
 
 Damn it. Incoming call. -.-
 
 I'm actually on vacation (more like you need to trim down overtime before management get's angry).
 
 They decided to test the new hardware / os stack I set up in the last weeks. I'd actually be happy about it If I wasn't on vacation and would be part in something that I invested a lot of time...
 
 Well now I am. Guess what. It's running too good.
 
 And that's not a joke. It's partly due to an upgrade in infrastructure (got rid of some last remaining 1 Gbps networks)… but also because I changed quite a lot on the OS / VM side plus we changed from XEN to Proxmox... With major tweaks, too.
 
 The whole stack can now handle peak traffic where it would choke before, and even go beyond the old peak traffic.
 
 Enough of introduction, the simple reason why shit burned down was because they tried out the current development branch and let it ran.
 
 The development branch had an currently unfinished ratelimiter framework, since I didn't had time for an full burn in and didn't knew what the maxima / limits were. And since I hadn't finished that, I didn't finish the traffic shaping either.
 
 Hm. Guess it's not good when you let a bunch of heavy parallelized data generators / analyzers run for free....
 
 In the end, we simply shotgunned the docker development machines, because thanks to network congestion / retransmissions and feedback, they were not really cooperative via network / REST.
 
 But hey: To infinity and beyond. XDrant darling i grilled the network it was just a test dumb ways to die never ask the guy who invented it oops2
- 
				    					
					
					I despise it when software developers remove features because "too few people use them".
 
 Is this what those shady telemetry features are for? So they can pick which useful features to get rid of because some computer rookies whined that it is "feature creep" rather than just ignoring it?
 
 Now I have to fear losing useful (or at least occasionally convenient) features each time I upgrade, such as Firefox ditching RSS, FTP, and the ability to view individual cookies. The third can be done with an extension, but compatibility for it might be broken at some point, so we have to wait for someone to come up with a replacement.
 Also, the performance analysis tool in the developer tools has been moved to an online service ("Firefox profiler"). I hope I don't need to explain the problems with that.
 
 But perhaps the biggest plunge in functionality in web browser history was Opera version 15. That was when they ditched their native "Presto" browsing engine for Chromium/Blink, and in the process removed many features including the integrated session manager and page element counter.
 
 The same applies to products such as smartphones. In the early 2010s, it was a given that a new smartphone should cover all the capabilities of its predecessors in its series, so users can upgrade without worrying a second that anything will be missing. But that blissful image was completely destroyed with the Galaxy S6. (There have been some minor feature removals before that, such as the radio and the three-level video recording bitrate adjustment on the S4, but that's nothing compared to what was removed with the S6.).
 
 Whenever I update software to a new version or upgrade my smartphone, I would like it to become MORE capable, not LESS (and to hell with that "less is more" nonsense).10
- 
				    					
					
					Anyone reading these emails we are sending?
 
 I work at a small place. A few users are using an application at our place that I develop and maintain. We all work remotely.
 
 I announce by email to these few users a new version release of said application because of low level changes in the database, send the timeline for the upgrade, I include the new executable, with an easy illustrated 2 minutes *howto* to update painlessly.
 
 Yet, past the date of the upgrade, 100% of the application users emailed me because they were not able to use the software anymore.
 
 ----------------
 
 Or I have this issue where we identified a vulnerability in our systems - and I send out an email asking (as soon as possible) for which client version users are using to access the database, so that I patch everything swiftly right. Else everything may crash. Like a clean summary, 2 lines. Easy. A 30 second thing.
 
 A week pass, no answer, I send again.
 
 Then a second week pass, one user answers, saying:
 
 > well I am busy, I will have time to check this out in February.
 
 ----------------
 
 Then I am asking myself:
 * Why sending email at all in the first place?
 
 * Who wrote these 'best practices textbooks about warning users on schedule/expected downtime?'
 
 *How about I just patch and release first and then expect the emails from the users *after* because 'something is broken', right? Whatever I do, they don't read it.
 
 Oh and before anyone suggest that I should talk to my boss about this behavior from the users, my boss is included in the aforementioned 'users'.
 
 Catch-22 much ? Haha thanks for reading
 
 /rant7
- 
				    					
					
					New cooler for CPU installed.
 
 Damn it. Was long overdue, old cooler was way undersized after an CPU upgrade.
 
 I knew it would be tricky. But damn... My motherfugging stubbornness.
 
 *sigh*
 
 1mm over RAM heatspreader, took a long time getting blindly the cooler fixed... Screwing blindly isn't fun. 13 13
- 
				    					
					
					Finally made good use of my RPi and setup pi-hole on it. After a painful 4hour long dist-upgrade and picking the right filters it is working like a charm. Why didn't I make this work earlier.
 
 I've also wrote a little script which queries the api and displays different info on the AMOLED screen that was lying around unused for some time.
 
 In case you are interested (from left to right and bottom), the traffic in the last 10 minutes with the max value on a graph, the most active clients query and blocked ratio as lines relative to the top one, and an overview of the total queries/ blocked queries and total clients.
 
 At least I've finally spent a weekend useful not just playing games and watching anime. 5 5
- 
				    					
					
					!rant
 I just found out that I can get 1000/1000 mbit fiber for approximately $50 a month where I live........ Time for an upgrade!5
- 
				    					
					
					Eric Thomas' Top 10 Rules For Success
 
 1- Know what you want.
 If you don’t know what you want, how will you know what to say yes to in your life? Stop taking every body else’s leftovers and step up and take what you deserve!
 
 2- Work on your gift.
 We all have our own individual talents, gifts and strengths. But those natural gifts will only become truly great by refining and nourishing them. Natural ability will get you started, but commitment and determination to achieve greatness is what will get you to where you want to be.
 
 3- No excuses.
 Stop using your circumstances, finances or current position in life as an excuse to justify why you aren’t working towards your goals. You are in charge. If you aren’t where you want to be, take a look in the mirror and ask yourself honestly- WHY? Take responsibility for you life once and for all.
 
 4- Upgrade your values.
 Your values dictate your behaviours. And your behaviours create your results. If you want to a different result, you need to change your behaviour.
 
 5- You reap what you sow.
 Nothing in life is free. It is up to you to determine the course of your life. If you want success, you need to do what it takes, daily, to get there. Don’t focus so much on being successful. Focus on solving problems, helping others, and adding value to people’s lives, and success will come.
 
 6- Education is the great equaliser.
 If you are at the bottom, you need to learn. If you are at the top, you still need to learn. Never, ever, ever stop growing and educating yourself.
 
 7- What is your WHY?
 Why do you wake up in the morning and hustle? Why do you do what you do? Knowing the answer to this question is the single most important thing to know about yourself if you want to become successful. When you know WHY you are doing what you do, you won’t ever quit, even on a bad day.
 
 8- Have boundaries.
 If you want to be a huge success, you have to be strict on yourself with how you spend your energy. Distractions will come in many forms, family, friends, TV, but you have to make sure that your time is being spent wisely.
 
 9- Speak from the heart.
 Transparency is attractive. Don’t be afraid to open up to the world and let yourself be seen.
 
 10- Succeed as bad as you want to breathe.
 Everybody wants to be successful. But not everybody is willing to do the work that it takes to become successful. When you are willing to get so uncomfortable, so out of your depth, so blind that you have no other choice but to be successful, THEN you will become successful. The only question you need to ask yourself is this. Am I willing?
 
 Credits: https://fearlessmotivation.com/2016... 2 2
- 
				    					
					
					Finally finished the longest ticket I've ever worked on in my life. The ticket title and description was a pretty simple and straightforward one: "Upgrade from PHP 7.4 to 8".
 
 If it was only so simple in real life. Our application is mostly done with API Platform framework, which is based on top of Symfony framework which is based on top of PHP language.
 
 Once I did PHP 7 => 8 upgrade I needed to upgrade API Platform 2 => 3. But of-course that couldn't have been done as before that I needed to upgrade from Symfony 5 => 6.
 
 This all was literally an equivalent of touching into a wasp nest - it took me a bit over 5 months and 800 hours of work and there was literally not a single source file left untouched.
 
 In the process of all of this I've ran into literally dozen undocumented feature-breaking changes, broken backwards-compatibility promises and inside out architectural changes - from both the frameworks and the language itself.
 
 Upgrading just one major version of anything SHOULD NOT be so hard. And to top it all up just to think I will need to do this again in a year or two..
 
 Experiences like these really set my hate for time-based model of releases and the state of today's development in general. 6 6
- 
				    					
					
					A Rant that took my attention on MacRhumors forum.
 .
 I pre-calculated projected actual overall cost of owning my i5/5/256 Haswell Air, which I got for $1500.
 
 After calculations, this machine would cost me about $3000 for 3 years of use.
 (Apple Care, MS Office Business, Parallels, Thunderbolt adapter to HDMI, Case... and so on).
 
 Yea... A lot of people think it's all about the laptop with Apple. nah... not at all. There's a reason Apple is gradually dropping the price of their laptops.
 
 They are slowly moving to a razor and blade business model... which basically is exactly what it sounds like - you buy the razor which isn't too expensive, but you've got no choice but to buy expensive additional blades.
 
 I doubt Apple is making much money from laptop sales alone... well definitely not as much as they were making 5 years or so ago (remember the original air was about $1800 for base model, and if i remember correctly - $1000 additional dollars to upgrade to 64GB SSD from the base HDD.
 
 Yes, ONE THOUSAND DOLLARS FOR 64GB SSD!
 
 Well, anyways, the point is that Apple no longer makes them BIG bucks from the laptop alone, but they still make good profits from upgrades. $300 to go to 512GB SSD from 256, $100 for 4GB extra ram, and $150 for a small bump in processor. They make good profits from these as well.
 
 But that's not where they make mo money. It's once you buy the Macbook, they've got you trapped in their walled garden for life. Every single apple accessory is ridiculously overpriced (compared to market standards of similar-same products).
 
 And Apple makes their own cables and ports. So you have to buy exclusively for Apple products. Every now and then they will change even their own ports and cables, so you have to buy more.
 
 Software is exclusive. You have no choice but to buy what apple offers... or run windows/linux on your Mac.
 
 This is a douche level move comparable to say Mircrosoft kept changing the usb port every 2-3 years, and have exclusive rights to sell the devices that plug in.
 
 No, instead, Intel-Microsoft and them guys make ports and cables as universal as possible.
 Can you imagine if USB3.0 was thinner and not backwards compatible with usb2.0 devices?
 
 Well, if it belonged to Apple that's how it would be.
 
 This is why I held out so long before buying an apple laptop. Sure, I had the ipod classic, ipod touch, and more recently iPad Retina... but never a laptop.
 I was always against apple.
 
 But I factored in the pros and cons, and I realized I needed to go OS X. I've been fudged by one virus or another during my years of Windows usage. Trojans, spywares. meh.
 
 I needed a top-notch device that I can carry with me around the world and use for any task which is work related. I figured $3000 was a fair price to pay for it.
 
 No, not $1500... but $3000. Also I 'm dead happy I don't have to worry about heat issues anymore. This is a masterpiece. $3000 for 3 years equals $1000 a year, fair price to pay for security, comfort, and most importantly - reliability. (of course awesome battery is superawesome).
 
 Okay I'm going to stop ranting. I just wish people factored in additional costs from owning an a mac. Expenses don't end when you bring the machine home.
 
 I'm not even going to mention how they utilize technology-push to get you to buy a Thunderbolt display, or now with the new Air - to get a time capsule (AC compatible).
 
 It's all about the blades, with Apple. And once you go Mac, you likely won't go back... hence all the student discounts and benefits. They're baiting you to be a Mac user for life!
 
 Apple Marketing is the ultimate.
 
 source: https://forums.macrumors.com/thread...3
- 
				    					
					
					Well it's a bit long but worth reading, two crazy stories in one rant:
 
 So there are 2 things to consider as being my first job. If entrepreneurship counts, when I was 16 my developer friend and I created a small local music magazine website. We had 2 editors and 12 writers, all music enthusiasts of more or less our age. We used a CMS to let them add the content. We used a non-profit organization mentorship and got us a mentor which already had his exit, and was close to his next one. The guy was purely a genius, he taught us all about business plans, advertising, SEO, no-pay model for the young journalists (we promised to give formal journalist certificates and salary when the site grows up)
 We hired a designer, we hired a flash expert to make some advertising campaigns and started filling the site with content.
 
 Due to our programming enthusiasm we added to the raw CMS some really cool automation: We scanned our country's radio charts each week using a cron job and the charts' RSS, made a bot to search the songs on youtube and posted the first search result as an embedded video using some reg-exps. This was one of the most fun coding times I've had. Doing these crazy stuff with none to little prior knowledge really proved me I can do anything with the power of will.
 
 Then my partner travelled to work in an internship in the Netherlands and I was too lazy to continue it on my own and it closed, not so surprisingly for a 16 years old slacker boy.
 
 Then the mentor offered my real first job. He had a huge forum (14GB of historical SQL) but it was dying, the CMS version was very old and he wanted me to upgrade it to the latest. It didn't seem hard at first, because there were very clear instructions in the CMS website on how to do that. However, the automation upgrade scripts didn't work well because the forum owners added some raw code (not MVC plugins but bad undocumented code) and some columns to the SQL tables. I didn't give up and decided to migrate between the versions without the scripts. I opened a new CMS and started learning by heart all of the database columns so I can make a script to migrate between the versions. The first tests ran forever because processing 14GB of data on a single home computer is not a task meant to be done. I didn't give up. I made an old forum and compared the table structures and code with my mentor's. I think I didn't exhaustively finish this solution, the task was too big on my shoulders and eventually I gave up. I still owe thanks for that mentor for teaching me how to bare with seemingly (and practically) impossible tasks, for learning not to fear from being a leader and an entrepreneur and also for paying me in time even though I didn't deliver anything 😂
- 
				    					
					
					Fuck Unity.
 Today the version that those monsters call stable, decided to not render UI text (canvas) in a project I had to upgrade from an older version.
 
 But it performs this practical joke (that stable software must do) only in the fucking editor.
 
 How am I making sure that the text aligns? Ah, just moving the anchor positions, changing the font size, binary fucking searching for the right position for alignment by moving n pixels at a time, and exporting a webgl build and running it to make sure it's aligned
 
 We're shifting to Unreal next year. I'll make sure of it3
- 
				    					
					
					Aaagh...... 2022 this year has been shity for real..
 So its now 1 year and I've been a fullstack developer for this mid tech company as the only developer
 
 so I've been trying to get these guys to hire a second developer. and try to also upgrade equipment and these guys didnt even bother to attend to my requests and during my evaluation meeting on friday these guys where down my neck about why projects are taking time to complete i MEAN WTF!!!!! told them its bcoz Im a 1 man army and most of the times Im chocked with the "any other duty" thing and how tha fuck do they expect them projects to be done on time
 I'm the only developer some times i get sick 2weeks and where i left off is were i continue from and thats 2 weeks work of progress down the drain
 I'm so fucking pieced off ryt now I feel like droping this shity job and find a much better organization
 they want me to build them a developer department and they dont even equip me with the necessary tools to do so WTF do they think they are doing they think they know better than me?
 so let them build their fucking dev department without me
 this has been a fucking stressful experiance
 wrote them a later to hire a second developer
 I dont fucking care how they are going to do it
 contracting or an internal dev if they dont in the next 3 months I fucking leaving this shit7
- 
				    					
					
					MySQL 5.5 end of life’d in 2010. In 2021 my company started an upgrade to 5.6. The outdated dependencies meant we needed 25 engineers for 2 months full-time to make the upgrade as invisible to users as possible. We still took about 90 minutes of downtime on cutover day. Not upgrading MySQL on time meant we paid way more in terms of engineering hours. The reason we call it debt, is because you pay interest when you don’t tKe care of it right away.4
- 
				    					
					
					Dual-booted Gaming Computer: A Saga of Frustration, Alcoholism*, and Relief
 
 So a while back my gaming computer was booting Antergos Linux and Windows 10. It took me a few months, but I finally became fed up with Windows 10's bullshit of putting ads in the OS (Suggested Apps, OneDrive, etc.) and reinstating all of their defaults after an upgrade (Edge, privacy settings, the People Button in 1709).
 
 So, I backed up my data and installed Windows 7. Windows 7 has a bright, consistent look, and in my opinion still holds up as a good operating system.
 
 However, I couldn't boot into Antergos after that. For whatever reason, no matter how hard I tried, I just wasn't able to. So, I decided to reinstall. Might as well, anyway.
 
 Now, I have an nVidia card, which does not play well with the OSS drivers, so it's basically normal for me to have to unplug my card and use the on-board graphics. So I do that and boot into the LiveUSB, do the install, boot into the desktop, install the nVidia drivers package, shut down.
 
 I reinstall the card, turn the computer on... and nothing. Just a black screen with a flashing underline. I can't even get into a TTY session.
 
 I ended up trying a few other distributions--Gecko Linux, Arch Labs, Manjaro--but all had the same issue. I was about to give up, but decided to try Antergos one more time, but with the newest install media.
 
 And it worked! I was so freaking happy! I can finally play my Linux games again!undefined dualboot why do i do this to myself linux arch wiki couldn't help me archlinux now to do it again with my 1060 windows1
- 
				    					
					
					The year was 2006. During the first half of my career, I use to work in the NOC. This was before I made my transition to software engineer. I worked on the third shift for a bank services company. The company was on a down turn. Just years earlier they just went public, and secured a deal with a huge well known bank. Eventually they entered a really bad contract with the bank and was put into a deal they couldn't deliver on. The partnership collapse and their stock plummeted. The CEO was dismissed, and a new CEO came in who wanted to "clean things up".
 
 Anyway I entered the company about a year after this whole thing went down. The NOC was a good stepping stone for my career. They let me work as many hours as I liked. And I took advantage of it, clocking in 80 hours a week on average. They gave me the nick name "Iron Man".
 
 Things started to turn around for the company when we were able to secure a support contract with a huge bank in the Alabama area. As the NOC we were told to handle the migration and facilitate the onboarding.
 
 The onboarding was a mess with terrible instructions that didn't work. A bunch of software packages that crashed. And the network engineers were tips off, as they tunnel between our network and the banks was too narrow, creating an unstable connection between us and them. Oh, and there were all sorts of database corruption issues.
 
 There was also another bank that was using an old version of our software. The sells team had been trying to get them off our old software for over a year. They refuse to move. This bank was the last one using this version, and our organization wanted to completely cut support.
 
 One of the issue we would have is that they had an overnight batch job that had an ETA to be done by 7 AM. The job would often get stuck because this version of the software didn't know how to fail when it was caught in an undesired state. So the job hung, and since the job didn't have logging, no one could tell if it failed unless the logs stopped moving for an hour. It was a heavily manually process that was annoying to deal with. So we would kill the JVM to "speed" the job up. One day I killed the JVM but the job was still late. They told me that they appreciated the effort, but that my job was only to report the problem and not fix it.
 
 This got me caught up in a major scandal. Basically they wanted the job to always have issues everyday. Since this was critical for them, all we needed to do was keep reporting it, and then eventually this would cause the client to have to upgrade to our new software. It was our sales team trying to play dirty. It immediately made me a menace in the company.
 
 For the next 6 months I was constantly harassed and bullied by management. My work was nitpicked. They asked me to come into work nearly everyday, and there was a point I worked 7 days with no off days. They were trying to run me so dry that I would quit. But I never did.
 
 On my last day at the company, I was on a critical call with a customer, and my supervisor was also on the line. My supervisor made a request that made no sense, and was impossible. I told her it wasn't possible. She then scalded me on the call in front of customers. She said "I'm your supervisor, you're just a NOC technician, you do what I say and don't talk back". It was embarrassing to be reprimanded on a call with customers. I never quite recovered from that. I could fill myself steaming with anger. It was one of the first times in my adult life that I felt I really wanted to be violent towards someone. It was such a negative feeling I quit that day at the end of my shift with no job lined up.
 
 I walked away from the job feeling very uncertain about my future, but VERY relieved. I paid the price, basically unable to find a job until a year and a half later. And even was forced to move back in with my mother. After I left, the company still gave my a severance. Probably because of the supervisor's unprofessional conduct in front of customers, and the company probably needed to save face. The 2008 crash kept me out of work until 2009. It did give me time to work on myself, and I swore to never let a job stress me out to that degree. That job was also my last NOC job and the last job where did shift work. My next few jobs was Application Support and I eventually moved into development full time, which is what I always wanted to do.
 
 Anyway sorry if it's a bit long, but that's my burnout story.
- 
				    					
					
					We've got a big legacy app which we have to rewrite. The current client applications are only working on XP(!). We have to move the clients to the browser so we can finally get rid of all XP vm-s. The db schema is complex but still 1000+ stored procedures and functions and about a hundred tables with 13 years of data.
 So I ask the guy responsible for maintaining the DB code. (he is ~25 years older than me)
 
 me - Where is the source of the database. Which project?
 he - Where would it be? It's in the db.
 me - So we've got a huge db without VCS, upgrade/downgrade scripts, etc?
 he - Yes. I don't get why young developers always want to use shiny new tech like git just because it is cool. It has nothing that an external usb backup drive can't do.
 me - VCS has been around since the early 1980's...
 he - If you really want, you can put it under git or whatever, so you can sleep better, but I still think it is stupid and a waste of time.
 
 I get that it's hard to keep up, but getting personal...
- 
				    					
					
					Proper rant tonight... I was getting an upgrade to my home entertainment today. It needed an engineer visit. What a useless clown he turned out to be.
 
 2 hrs after arriving, he left and things weren't working remotely right at all. But it was Saturday and he was off the clock so I had to suck it up. No option to back out either - it was all activated and I had to accept it.
 
 He spent most of the time arguing with me about my home network was set up and how it was wrong and how it was important for the overall system to work. Being a geek and having done research, I couldn't understand this - that wasn't how it was meant to be, I knew. I accept my home wiring is a bit odd, but I've had a working system for years because it's all necessary.
 
 After all the faffing about and purchase of some new powerline units (which I accept I needed anyway but where unrelated to this set up), looking more into it myself, it is now up and running correctly.
 
 I am thoroughly pissed at the ineptitude of the engineer. He clearly doesn't understand how the system works. He doesn't understand how powerline works and how it's a life saver for people with awkwardly shaped houses or thick walls where Wi-Fi is useless. If he had, we would have had far fewer issues and I wouldn't have had the stress of thinking I'd killed our home entertainment and internet and there was nothing I could do about it.
 
 I don't blame the provider (besides them clearly not providing adequate training). But this was arrogant uselessness. At least I had the knowledge to understand how it was meant to work and get it sorted myself.
 
 Maybe it could be a useful sideline job if I get fed up with developing.7
- 
				    					
					
					So working for a company and the dev team I’m apart of works on a legacy rails app. Technical debt is high, no automated tests, no proper routing and also running unsupported versions of the language.
 
 I joined seven months ago and got the current team doing automated testing so that’s a plus, they bought this app four years ago and there’s been no language updates, testing, cleanup, security updates, nothing, just adding to bad code.
 
 Now we’re looking to actually upgrade language versions, the language and the framework now this will cause a lot of stuff to break naturally due to how outdated it is.
 
 So I started putting proper routes into place how things should of been when things were being built as we have some spare time I decided to go out of my way to clear up some of the technical debt to get ahead of the curb. Re-done an entire section of the app, massive speed improvements, better views, controller, model, comment clean up and everything exactly how it should be.
 
 I push the PR,
 *other dev* - “why are we doing all of these other changes”
 *me* - “well to implement routes properly, we have to use the new routes I just did some extra cleanup along the way”
 *today, me* - “can you lend me a hand with one of the routes the ID isn’t getting passed”
 *today, other dev* - “this wouldn’t of happened if you didn’t redo all these files, let’s just scrap the changes”
 …
 
 Sooo, I’ve spend three weeks improving one section in the app, because I’m having issues with one route according to this dev I should scrap it? Wait come again, am I the only one in this team who cares about making this app better all round?
 
 Frustrating…4
- 
				    					
					
					TLDR; After my dad was lazy, I assembled the parts myself.
 
 As far back as I can remember, if I think of my father he is sitting behind his pc playing games. It was like me, his escape.
 
 When I was between 3-5 years old he upgraded his pc to one that supported windows 95. The most exciting thing I remember about his new pc is that it had a sound card or what passed as one anyway - think polyphonic ring tones in place of onboard beeps. It was fucking awesome.
 
 He gifted his old 386 to my brother and I which we spent a blissful year or so playing DOS games on until it finally died. I wouldn't have access to a home computer again until I was 11 - touching my fathers computer was out of the question, never mind actually using it.
 
 The reason I didn't have access to a pc was simply because he didn't replace his pc - he made minor upgrades to it until he died with a whopping 512mb of RAM. Seriously his pc specs were a bragging factor like geek porn - better than any else's I ever saw including his I.T friends (he was an electrical engineer), everyone knew this apparently aside from his boss...
 
 Auto-cad started becoming a thing and my father for the first time ever had a reason to actually do work on a computer, he immediately used the opportunity to leverage his company into paying for a pc. To get better "value" for the company he ordered the parts in place of a pre-built machine - in reality he blew 90% of the budget on a new motherboard and graphics card to upgrade his own pc and the cheapest entry level components for everything else. The day they arrived he upgraded his own pc, threw the excess parts into a box and told us it was our new computer which he would put together over the weekend. He didn't.
 
 After 3 months of nagging I was fed up and taking liberties with him that landed me more than one hiding, at some point he was over it and told me if I wanted something that badly I should do it myself. He walked into my room after becoming concerned if I had run away/hurt myself since he hadn't heard a whistle from me in 6 hours and I was battling my ass off trying to install windows 98.
 
 He inspected my assembly gave me an approving nod and showed me that the hard drives physical jumper was set to slave and the rest is history. I hadn't used windows before, or built a computer let alone used one in years but somehow I always knew, it just clicked and made sense to me.
 
 I didn't truly recognise just how much I had learn't watching him play DOS games over his shoulder and clean/upgrade his pc. It changed everything and thanks to only being allowed to watch him use a pc, once I finally had access to my own computer again I revered it and all it's possibilities. I knew I should use it to do something special.
- 
				    					
					
					After learning a bit about alife I was able to write
 another one. It took some false starts
 to understand the problem, but afterward I was able to refactor the problem into a sort of alife that measured and carefully tweaked various variables in the simulator, as the algorithm
 explored the paramater space. After a few hours of letting the thing run, it successfully returned a remainder of zero on 41.4% of semiprimes tested.
 
 This is the bad boy right here:
 tracks[14]
 [15, 2731, 52, 144, 41.4]
 
 As they say, "he ain't there yet, but he got the spirit."
 
 A 'track' here is just a collection of critical values and a fitness score that was found given a few million runs. These variables are used as input to a factoring algorithm, attempting to factor
 any number you give it. These parameters tune or configure the algorithm to try slightly different things. After some trial runs, the results are stored in the last entry in the list, and the whole process is repeated with slightly different numbers, ones that have been modified
 and mutated so we can explore the space of possible parameters.
 
 Naturally this is a bit of a hodgepodge, but the critical thing is that for each configuration of numbers representing a track (and its results), I chose the lowest fitness of three runs.
 Meaning hypothetically theres room for improvement with a tweak of the core algorithm, or even modifications or mutations to the
 track variables. I have no clue if this scales up to very large semiprime products, so that would be one of the next steps to test.
 
 Fitness also doesn't account for return speed. Some of these may have a lower overall fitness, but might in fact have a lower basis
 (the value of 'i' that needs to be found in order for the algorithm to return rem%a == 0) for correctly factoring a semiprime.
 
 The key thing here is that because all the entries generated here are dependent on in an outer loop that specifies [i] must never be greater than a/4 (for whatever the lowest factor generated in this run is), we can potentially push down the value of i further with some modification.
 
 The entire exercise took 2.1735 billion iterations (3-4 hours, wasn't paying attention) to find this particular configuration of variables for the current algorithm, but as before, I suspect I can probably push the fitness value (percentage of semiprimes covered) higher, either with a few
 additional parameters, or a modification of the algorithm itself (with a necessary rerun to find another track of equivalent or greater fitness).
 
 I'm starting to bump up to the limit of my resources, I keep hitting the ceiling in my RAD-style write->test->repeat development loop.
 I'm primarily using the limited number of identities I know, my gut intuition, combine with looking at the numbers themselves, to deduce relationships as I improve these and other algorithms, instead of relying strictly on memorizing identities like most mathematicians do.
 I'm thinking if I want to keep that rapid write->eval loop I'm gonna have to upgrade, or go to a server environment to keep things snappy.
 
 I did find that "jiggling" the parameters after each trial helped to explore the parameter
 space better, so I wrote some methods to do just that. But what I wouldn't mind doing
 is taking this a bit of a step further, and writing some code to optimize the variables
 of the jiggle method itself, by automating the observation of real-time track fitness,
 and discarding those changes that lead to the system tending to find tracks with lower fitness.
 
 I'd also like to break up the entire regime into a training vs test set, but for now
 the results are pretty promising.
 
 I knew if I kept researching I'd likely find extensions like this. Of course tested on
 billions of semiprimes, instead of simply millions, or tested on very large semiprimes, the
 effect might disappear, though the more i've tested, and the larger the numbers I've given it,
 the more the effect has become prevalent.
 
 Hitko suggested in the earlier thread, based on a simplification, that the original algorithm
 was a tautology, but something told me for a change that I got one correct. Without that initial challenge I might have chalked this up to another false start instead of pushing through and making further breakthroughs.
 
 I'd also like to thank all those who followed along, helped, or cheered on the madness:
 In no particular order ,demolishun, scor, root, iiii, karlisk, netikras, fast-nop, hazarth, chonky-quiche, Midnight-shcode, nanobot, c0d4, jilano, kescherrant, electrineer, nomad,
 vintprox, sariel, lensflare, jeeper.
 
 The original write up for the ideas behind the concept can be found at:
 https://devrant.com/rants/7650612/...
 
 If I left your name out, you better speak up, theres only so many invitations to the orgy.
 Firecode already says we're past max capacity!5
- 
				    					
					
					Updated to iOS 12.1.2 (sleazy release 2) after previously getting fucked up the ass by iOS 12.1.2 first release. Yes boys and girls, they tried to cover up their latest fuckup by re-releasing the same release with a modification.
 
 The first time I updated, it knocks my Apple ID out on all my Apple devices when I upgrade my iPhone to 12.1.2. Mother fuckers... gotta log back in for every device, iPads, iPhones, Apple TVs, Macs. And for each service iTunes Store, Messages, FaceTime on each device supporting. Oh yea, it knocks out my Wi-Fi calling and I have to reestablish that too. Then to really ice me, it knocks out my HomeKit system as the Apple ID is knocked out on the Apple TV.
 
 Now after updating just my iPhone to the second 12.1.2 "sleaze release", the thing knocks all my devices out again.
 
 Apple has taken away that which I loved; impeccable engineering and design that could be used as the model for an entire industry. The industry guru. (teacher, leader) Apple has become the new Microsoft.
 
 October 5, 2011, the day Apple died.4
- 
				    					
					
					Is it me or software subscriptions make developers lazy?
 
 There is a great photo editing software: Capture One. Every year they release a new major version, so users need to buy an upgrade. In the past developers packed a bunch of big changes into major update, also they released 3 minor updates yearly, and every minor update brought some cool features. But then they added subscription model which was cheaper then perpetual model. And at the same time major updates became not that cool. Developers started to add enterprise features needed by museums, features involving other camera brands users, changes targeted at newbies and so on. For perpetual model users most of these changes are not worth 80-255 EUR yearly (depends on license type and offs) but is ok for subscription model users because they continue using the software and even small updates and enhancements are fine for them.
 
 Not every major update is that weak but many of them are not worth upgrade. And developers are not motivated to do more cool stuff because subscription model users will continue paying for their subscriptions.1
- 
				    					
					
					In last episode of "How SystemD screwed me over", we talked about Systemd's PrivateTMP and how it stopped me from generating SSL certificates.
 
 In today's episode - SystemD vs CGroups!
 
 Mister Pottering and his team apparently felt that CGroups are underused (As they can be quite difficult to set up), and so decided to integrate them into SystemD by default. As well as to provide a friendlier interface to control their values.
 
 One can read about these interactions in the manual page "systemd.resource-control"
 
 All is cool so far. So what happened to me today?
 
 Imagine you did a major system release upgrade of a production server, previously tested on a standalone server. This upgrade doesn't only upgrade the distribution however, it also includes the switch from SysVInit to SystemD. Still, everything went smooth before, nothing to worry now then, right? Wrong.
 
 The test server was never properly stress-tested. This would prove to be an issue.
 
 When the upgrade finishes, it is 4 AM. I am happy to go to bed at last. At 6 AM, however, I am woken up again as the server's webservices are unavailable, and the machine is under 100% CPU load. Weird, I check htop and see that Apache now eats up all 32 virtual cores. So I restart it, casting it off to some weird bug or something as the load returns to normal.
 
 2 hours later, however, the same situation occurs. This time, I scour all the logs I can, and find something weird - Many mentions that Apache couldn't create a worker thread? That's weird.
 
 Several hours of research and tinkering later, I found out the following:
 1 - By default, all processes of a system that runs SystemD are part of several CGroups. One of these CGroups is the PID CGroup, meant to stop a runaway process from exhausting all PIDs/TIDs of a system.
 
 This limit is, by default, set to a certain amount of the total available PIDs. If a process exhausts this limit, it can no longer perform operations like fork().
 
 So now, I know the how and why, but how should I solve this? The sanest option would be to get a rough estimate of just how many threads the Apache webserver might need. This option, though, is harder, than apparent. I cannot just take the MaxRequestsWorkers number... The instance has roughly double the amount of threads already. The cause being, as I found out, the HTTP/2 module, which spawns additional threads that do not count towards this limit. So I have no idea what limit to set.
 
 Or I could... Disable the limit for just the webserver via the TasksAccounting switch. I thought this would work. And it did seem to... Until I ran out of TIDs again - Although systemctl status apache2.service no longer reported the number of tasks or a task limit of the process, the PID CGroup stayed set to the previous limit. Later I found out that I can only really disable the Task Accounting for all the units of a given slice and its parents.
 
 This, though, systemctl somewhat didn't make apparent (And I skimmed the manual, that part was my fault)
 
 So... The only remaining option I had was to... Just set the limit to infinite. And that worked, at last.
 
 It took me several hours to debug this issue. And I once again feel like uninstalling systemd again, in favor of sysvinit.
 
 What did I learn? RTFM, carefully, everything is important, it is not enough to read *half* the paragraph of a given configuration option...
 
 Oh, and apache + http/2 = huge TID sink.
- 
				    					
					
					My work product: Or why I learned to get twitchy around Java...
 
 I maintain a Java based test system, that tests a raster image processor. The client is a Java swing project that contains CORBA bindings to the internal API of the raster image processor. It also has custom written UI elements and duplicated functionality that became available in later versions of Java, but because some of the third party tools we use don't work with later versions of Java for some reason, it's not possible to upgrade Java to gain things as simple as recursive directory deletion, yes the version of Java we have to use does not support something as simple as that and custom code had to be written to support it.
 
 Because of the requirement to build the API bindings along with the client the whole application must be built with the raster image processor build chain, which is a heavily customised jam build system. So an ant task calls out to execute a jam task and jam does about 90% of the heavy lifting.
 
 In addition to the Java code there's code for interpreting PostScript files, as these can be used to alter the behaviour of the raster image processor during testing.
 
 As if that weren't enough, there's a beanshell interface to allow users to script the test system, but none of the users know Java well enough to feel confident writing interpreted Java scripts (and that's too close to JavaScript for my comfort). I once tried swapping this out for the Rhino JavaScript interpreter and got all the verbal support in the world but no developer time to design an API that'd work for all the departments.
 
 The server isn't much better though. It's a tomcat based application that was written by someone who had never built a tomcat application before, or any web application for that matter and uses raw SQL strings instead of an orm, it doesn't use MVC in any way, and insane amount of functionality is dumped into the jsp files.
 
 It too interacts with a raster image processor to create difference masks of the output, running PostScript as needed. It spawns off multiple threads and can spend days processing hundreds of gigabytes of image output (depending on the size of the tests).
 
 We're stuck on Tomcat seven because we can't upgrade beyond Java 6, which brings a whole manner of security issues, but that eager little Java updated will break the tool chain if it gets its way.
 
 Between these two components we have the Java RMI server (sometimes) working to help generate image data on the client side before all images are pulled across a UNC network path onto the server that processes test jobs (in PDF format), by reading into the xref table of said PDF, finding the embedded image data (for our server consumed test files are just flate encoded TIFF files wrapped around just enough PDF to make them valid) and uses a tool to create a difference mask of two images.
 
 This tool is very error prone, it can't difference images of different sizes, colour spaces, orientations or pixel depths, but it's the best we have.
 
 The tool is installed in both the client and server if the client can generate images it'll query from the server which ones it needs to and if it can't the server will use the tool itself.
 
 Our shells have custom profiles for linking to a whole manner of third party tools and libraries, including a link to visual studio 2005 (more indirectly related build dependencies), the whole profile has to ensure that absolutely no operating system pollution gets into the shell, most of our apps are installed in our home directories and we have to ensure our paths are correct for every single application we add.
 
 And... Fucking and!
 
 Most of the tools are stored as source bundles in a version control system... Not got or mercurial, not perforce or svn, not even CVS... They use a custom built version control system that is built on top of RCS, it keeps a central database of locked files (using soft and hard locks along with write protecting the files in the file system) to ensure users can't get merge conflicts by preventing other users from writing to the files at all.
 
 Branching is heavy weight and can take the best part of a day to create a new branch and populate the history.
 
 Gathering the tools alone to build the Dev environment to build my project takes the best part of a week.
 
 What should be a joy come hardware refresh year becomes a curse ("Well fuck, now I loose a week spending it setting up the Dev environment on ANOTHER machine").
 
 Needless to say, I enjoy NOT working with Java. A lot of this isn't Javas fault, but there's a lot of things that Java (specifically the Java 6 version we're stuck on) does not make easy.
 
 This is why I prefer to build my web apps in python or node, hell, I'd even take Lua... Just... Compiling web pages into executable Java classes, why? I mean I understand the implementation of how this happens, but why did my predecessor have to choose this? Why?2
- 
				    					
					
					My friend works for a subsidery of an event organization company.. the sole purpose of the subsidery is to develop/maintene and upgrade their products. The just Started redesigning frontend of the website for the 4th time in last 16 months, because their boss changes their mind every 5minutes.1
- 
				    					
					
					When I look at the hefty PC setup on my desk self-assembled ~8 years ago, the only thought crossing my mind is: "what the hell was I thinking..."
 
 time for an upgrade to free up 1 sq meter of space on my desk5
- 
				    					
					
					I have a small NUC-like machine in my home with an old external hdd connected to it. I use it to run my local gitlab, nextcloud and to test a few websites I build for the lolz.
 If you too have a homelab, whether it's a single raspberry or an entire room full or racks, you know damn well that everything you have running locally as a web service keeps going until it doesn't, for whatever fucking reason. This time, it was the turn of my nextcloud.
 The machine has arch linux running, I chose it since I already use it on my coding laptop and being a rolling release means I don't have to manually upgrade to a newer version, risking various fuck-ups and consequent screaming of profanity.
 The downside is that arch is a bleeding-edge distro, so, despite being pretty good for what concerns security, as updates are pushed out some packages may still require legacy software to work as intended, since obviously not all developers for all packages can release simultaneously.
 The problem was that php reached 8.2.x but nextcloud couldn't use anything beyond 8.1, so the highlighted solution was to download php-legacy, a package with a set of utilities which the cloud could use instead of mainline php.
 
 Pretty easy, right? fuck my life, here we go.
 
 I edited apache-httpd's configurations to link the new libraries, updated every reference in every virtual host that could possibly screw up the web server.
 
 Done.
 
 Then I went on and disabled the php-fpm mainline, creating a new systemd unit that would instead run the legacy executable and afterwards I edited nextcloud's additional configs so they use that instead.
 
 Done, getting a bit dizzy, but I reboot everything and breathe.
 
 At this point the migration should be complete, but wait, the server returns an error saying that the application is still trying to use php 8.2+...wait, what in the sysadmin Christ?
 
 Back to nextcloud config, everything is set, everything else in every other fucking php-legacy and web server is fine, the old fpm service is disabled, I am confused, and why in the FUCKING FUCK is the new php-fpm unit failing to start at boot with "error 78/config - directory not found"? Hello? Am I being trolled by a shitty dual-core amazon fake NUC?
 Maybe yes, cause it turns out that the unit was referencing a directory in the external hdd, which gets mounted at boot time after the unit itself starts, so nothing much, just a matter of tinkering with cron jobs, a reboot and at least this one is off my balls.
 
 But why still isn't the server responding correctly? why? WHY?
 
 After slamming my cock on the keyboard here and there scrolling back through all the config files I think to myself, hmmm, my gitlab is working flawlessly, well yeah, I didn't need to install the whole web stack, everything was nice and easy wrapped in a docker container...so why am I even here, why the fuck am I bothering with all this layered web-app bullshit, why don't I just run the up-to-date docker image that someone else has already set up for me, back up all the data and reupload them on the application?
 
 Oh joy, you can't imagine, after 3...almost 4 hours of pure computer-touching the relief I had from seeing the blue web page with the "welcome to nextcloud" title.
 
 Right now it's copying back all the files, and the external hdd is now linked to include the data folder.
 Like really, everything was solved in two lines of bash.
 
 I am still fuming, but at least I learned a valuable lesson, if you want a service up for yourself, implement it and deploy it as fucking easy straight-forward as you can, giving MAXIMUM priority to already fully-working options that are out there just waiting to be downloaded and used. I swing my scrotal sack on web-apps elegance as long as it's MY homelab in MY place.
 
 Eat a fat dick php.
 
 sudo pacman -Rns nextcloud
 sudo systemctl disable --now php-fpm-legacy
 sudo pacman -Rns php-legacy
 sudo pacman -Rns $(sudo pacman -Qdtq)2
- 
				    					
					
					This is an actual transcript...
 Since it's way too long for the normal 5000 characters, hence splitting it up...
 
 Infra Guy: mr Dev, could you please give some rational for update of jjb?
 Dev: sparse checkout support is missing
 Infra Guy: is this support mandatory to achive whatever you trying to do?
 Dev: yes
 Infra Guy: u trying to get set of specific folder for set of specific components?
 Dev: yes
 Infra Guy: bash script with cp or mv will not work for you?
 Dev: no
 Infra Guy: ?
 Dev: when you have already present functionality why reinvent the wheel
 Dev: jenkins has support for it
 Dev: the jjb is the bottle neck
 Infra Guy: getting this functionality onto our infra would have some implications
 Dev: why should I write bash script if jenkins allows me to do that
 Dev: what implications ??
 Infra Guy: will you commit to solve all the issues caused by new jjb?
 Dev: you show me the implications first
 Infra Guy: like a year ago i have tried to get new jjb <commit_url>
 Infra Guy: no, the implications is a grey area
 Infra Guy: i cant show all of them and they may hit like in week or eve month
 Dev: then why was it not tackled
 Dev: and why was it kept like that
 Infra Guy: few jobs got broken on something
 Dev: it will crop up some time later
 Dev: if jobs get broken because of syntax
 Dev: then jobs can be fixed
 Dev: is it not ???
 Infra Guy: ofc
 Infra Guy: its just a question who will fix them
 Dev: follow the syntax and follow the guidelines
 Dev: put up a test server and try and lets see
 Dev: you have a dev server
 Dev: why not try on that one and see what all jobs fails
 Dev: and why they fail
 Dev: rather than saying it will fail and who will fix
 Dev: let them fail and then lets find why
 Dev: I manually define a job
 Dev: I get it done
 Infra Guy: i dont think we have test server which have the same workload and same attention as our prod
 Dev: unless you test how would you know ??
 Dev: and just saying that it broke one with a version hence I wont do it
 Infra Guy: and im not sure if thats fair for us to deal with implication of upgrading of the major components just cause bash script is not good enough for u
 Dev: its pretty bad
 Infra Guy: i do agree
 Infra TL Guy: Dev, what Infra Guy is saying is that its not possible to upgrade without downtime
 Infra Guy: no
 Dev: how long a downtime are we looking at ??
 Infra Guy: im saying that after this upgrade we will have deal with consequences for long time
 Infra Guy-2: No this is not testing the upgrade is the huge effort as we dont have dev resources to handle each job to run
 Dev: if your jjb compiles all the yaml without error
 Dev: I am not sure what consequences are we talking of
 Infra Guy: so you think there will be no consequences, right?
 Dev: unless you take the plunge will you know ??
 Dev: you have a dev server running at port 9000
 Infra Guy: this servers runs nothing
 Dev: that is good
 Dev: there you can take the risk
 Infra Guy: and the fack we have managed to put something onto api doesnt mean it works
 Dev: what API ?
 Infra Guy: jenkins api
 Infra Guy: hmmm
 Dev: what have you put on Jenkins API ??
 Infra Guy: (
 Dev: jjb is a CLI
 Infra Guy: ((
 Dev: is what I understand
 Dev: not a Jenkins API
 Infra Guy: (((
 Dev: (((((
 Infra Guy: jjb build xmls and push them onto api
 Infra Guy: and its doent matter
 Dev: so you mean to say upgrading a CLI is goig to upgrade your core jenkisn API
 Dev: give me a break
 Infra Guy: the matter is that even if have managed to build something and put it onto api
 Infra Guy: doesnt mean it will work
 Dev: the API consumes the xml file and creates a job
 Infra Guy: right
 Dev: if it confirms to the options which it understands
 Dev: then everything will work
 Dev: I am actually not getting your point Infra Guy
 Infra Guy: i do agree mr Dev
 Dev: we are beating around the bush
 Infra Guy: just want to be sure that if this upgrade will break something
 Infra Guy: we will have a person who will fix it
 Dev: that is what CICD is supposed to let me know with valid reasons
 Dev: why can't that upgrade be done
 Infra Guy: it can be done
 Infra Guy: i even have commit in place3
- 
				    					
					
					yesterday, I just swapped my sim card for some time with another. Placed it back....and voila! I can't enable data connection. I lost all my apn settings. To add to this, neither is it auto fetching the apns, nor i can manually change it! It shows some fucking error "apn settings not available for this user". I have another phone with same android version (lollipop) and everything works smoothly on it. These guys just broke everything after giving an upgrade from kitkat. Auto brightness stops working after a few hours, random reboots.... This is it... bye bye stock rom!
- 
				    					
					
					It’s all a blur but in 5th grade I was using a TRS-80 with a cassette player for storage at the library where my mom worked. Also an Apple IIe at school in the computer lab. My first personal computer was an IBM XT clone with an 8086 processor and dot matrix printer. I bought it after having fun with my cousin’s Commodore 64 and wanting one, but his uncle sold me on the IBM platform as something that I could upgrade over time. I was 13 when I first learned Assembler and BASIC. Big Blue Disk was my favorite subscription software with all the games and other shareware stuff that came every month in the mail.1
- 
				    					
					
					I feel bad for bootcampers. Their schools tell them to apply for a job even if they don’t have all the qualifications because they will learn on the job. That’s fine if you’re applying for an upgrade in the same career path. But when you’re changing careers, a lot of jobs don’t necessarily have time to invest in you like that.
 
 I do have respect for those who DM me on Slack and ask if the job is open to new bootcamp grads. At least they are taking the initiative to ask and not sulking that they’re not good enough.
 
 I tell them “this role requires experience in x. If you have that, then apply” because I don’t actually know they’re not qualified.
 
 I was like them before. It’s hard to get the first job and sometimes it’s a lot of luck. But the first job will make getting the next one easier.
 
 At least they’re not recruiters trying to convince me to pay them to fill the role.1
- 
				    					
					
					Hey devRanters! I need some help looking for a powerful laptop around (or obviously less than) $1000. Cousin recently stepped on my old reliable laptop and figured it was time for an upgrade. Any suggestions / experiences with your own laptops?11
- 
				    					
					
					Anti climactic story time (as in there's no promotion in this story):
 
 Sometime ago there were some organizational changes happening in my company that put me in a very tricky place. Theoretically, I was put on a level that was supposed to be an upgrade from my previous level. Practically, it didn't come with any benefits and it was actually a downgrade because anyone who joined the company in the six months before these changes was in the same level as me (who'd been in for roughly 2 years).
 It felt really insulting because I was about to be actually promoted. My manager and his manager tried to gaslight me into believing that I'm not at all affected in any way, before giving in and agreeing that a mistake was made. I was promised that next year it'll be corrected and I'll be promoted two levels. Even the HR assured me of that. I knew it was too good to be true but I was too demotivated to find another job.
 Fast forward one year. My bosses are all praises for the work I put in. But, no two level promotion. Reason? They tried but couldn't get the management to agree. The boss apologized to me and asked me if I wanted him to try again. What an insolent arse!
 
 Fast forward one more, extremely glum year.
 This time I am part of a different team so the team lead is different but the manager is same. The team lead really went all out with showing appreciation for me. He talked for almost an hour(!) about how I exceeded his expectations and went on to claim that his app's release would have been impossible if it weren't for me, the new team member. It was really humbling and satisfying. But what did I get? A limp handshake from the manager with fucking loose change.
 Silver lining. At least the manager did away with the 'well wisher, on your side' pretense this time. No mentions of failed promises, just regular empty promises for the future.
 
 Fast forward 3 months.
 Still here. Recovering. I am mulling over a much better offer than what my current boss can give me. Thinking about how long it takes before I'm in the dumpster again. I have stopped giving any fucks about anything here. I try to do the minimum required unless it benefits me in some way.
 
 The end.4
- 
				    					
					
					Oh let the rant time begin…
 
 So previous post I mentioned about this dev who has resigned and how I was going to see about a Snr. position.
 
 Management is now scrambling to figure out what to do as this dev managed all the migration to AWS etc, I know servers but haven’t got too much familiarity with AWS.
 
 Anyways so I finally get a 1:1 with my new line manager. I ask about the position and he says they don’t know what there going to do yet. Hire a new dev in India to offset and with the same knowledge even though the guy leaving is in the U.K. Bad idea as the servers are in the U.K. so if we get downtime or the server crashes we have no one in the U.K. to reset or access to the servers. India are very cagey who gets access which is annoying to say the least even though us (three devs) in the U.K. are the principal engineering team so there looking at all options.
 
 Anyways we have a back and fourth, we discuss some of the plans for the app, some of which we are nowhere near ready to even conceptualise as the app in its current state sucks, (ruby 2.2.6 and rails 5 but not really). Needs major refactoring and rewrite, one thing they want to do is multi tendency which again given the state is laughable.
 
 So, as my manager is speaking my head is screaming being like “this is just going to be a massive disaster”. Then we go onto that he’s seeing what everyone’s strengths are etc. And then we get onto the upgrade and that he wants me to work on it.
 
 Yes.. the upgrade I’ve been trying to do for the past 4+ months but I keep getting told to stop and getting pushed backed.
 
 I’ve been told we have devOps looking into restructuring the app, not possible as how the app is written, we have India trying to multi tenant again disaster incoming as they’ll end up rushing it. Legal are going to have a field day. Every time I say the issues are the fundamentals with the app, here’s how we can sort it. In one ear out the other basically there patching the ship even though it’s still leaking.
 
 I have so many ideas, and things I can do to improve the app and get it back to not only working order, fix the performance issues, data issues and everything else. Brick wall.
 
 So rants ensue where I basically say I would love to do the upgrade but management gives me no time in the roadmap (we have no say in planning). At this point I’m just speaking to a brick wall.
 
 After the meeting I have a chat with the BAs, we all have the same issues so honestly it sucks we end up ranting to each other for an hour.
 
 I’m being under-utilised, being told do this, do that even though I’ve had two stabs but told to stop and pushed back, I know what benefits I can bring to the app with a refactoring, ideas and how to properly lead the team because honestly we’re working on an old legacy app, and management are clueless and there priorities are all wrong, the company is getting frustrated and it’s a sinking ship. They would rather patch issues without solving them and everything I say goes in one ear and out the other.
 
 Frustrating is not the word.1
- 
				    					
					
					I finally configured my VPS. (haven't used linux before that)
 Now when I installed my laravel 5.2 project and wanted to use composer to get all the dependencies I came across an deprecated dependency. So now I'll either do a quick fix and update the dependency or upgrade to laravel 5.3. The second option is obviously better but takes more time. If only someone else could do this shit for me and I'd just be busy writing code. : /1
- 
				    					
					
					!dev
 
 I used to stick to the iPhone SE for the last year because it’s the only small phone, i can use it with one hand without doing acrobatic stuff with that hand.
 But it’s time for an upgrade.
 There are no small phones out there anyone (3.5 to max 4“)
 
 I understand that I need to get a bigger phone, but I never had one (except for the iPhone 6 which I didn’t like and switched back to iPhone 4)
 
 So what do you guys suggest? I read good things about the new Xperia.. is it any good?
 
 Important to me is:
 - No Samsung or google
 - not huuuuge (like iPhones plus models)
 - Android (wanna develop for ten and don’t use a Mac anymore)
 - reasonable can, mic, speakers etc.
 - Robust, has to last for 3-4 years
 
 You guys told me to get a dell xps13 as a daily and it was the best decision ever so I hope you can help me with this one as well..7
- 
				    					
					
					It happened again. I wanted to purchase an in-app upgrade for the first time in my life and the button was bugged. Then just say that you are tired of your job and you wanna see your company fail
- 
				    					
					
					People of devRant, I need your help! I am finally buying a new laptop - ive been using a Dell N4140 for the past 4 years and I absolutely love it. But it's about time to retire the machine and upgrade.
 
 I'm a programmer, I don't play games and haven't used windows in the last 2 years. Im looking for a 4-8GB RAM under $1000K. I plan to replace the HDD with an SSD. 13' is too small a screen and i feel 15.6' is slightly on the large side. I have a 21' external monitor anyway. My old dell was 14' and i loved it. And looks really matter for me. Alsooo, I dislike having a number pad. Its useless for me.
 
 I know I'm picky. I can't afford a MacBook right now (about to graduate from university), but if you could help me in finding the right laptop, I'd be really grateful!14
- 
				    					
					
					Woke up yesterday morning from a dream where I was explaining what needed to be done to upgrade a Drupal 6 site. It hasn't been supported officially for years and I was explaining how there isn't a decent port of the main module we use Audio. And even the guy I was explaining this too seemed somewhat exasperated. So yeah, this is reality.
 
 I could probably write a real upgrade path for the Drupal module and take all of our content into a new version of Drupal. But it would involve a fair amount of learning and outdated syntax and then learning Drupal 8. This would be all volunteer and take away from my time working on my other open source radio automation project.
 
 All the while I've been learning Ruby on Rails for a class and I could just upgrade the app right out of Drupal, but this would require me to support the site into perpetuity. Which I already more or less do.
 
 Drupal at this point is like an ex- girlfriend who I've grown away from, we did cool things but always got into fights about stupid things. Now I have to revisit my past mistakes and decide what to clean up and what to take into the future. I'm a better programmer now but I'm still not sure if it is worth my time to rekindle my romance with Drupal or it would just distract me from my current pursuits. Anyone who has been through the transition of a Drupal site from one major version to the next should feel my pain. At least it's not Word Press.
- 
				    					
					
					Been working on redoing my desktop lately. Currently the specs are:
 -FX-8350
 -Gigabyte GA-970A-DS3P motherboard with a broken USB 3.0 header lmao
 -GTX 660 (Gonna upgrade to an RX 580 at some point, I don't do any hardcore gaming so I know I don't need a top of the line GPU)
 -Crucial BX500 240gb SSD
 -WD 500gb HDD (gonna upgrade to a bigger one eventually)
 -Some like $60 Dynex PSU I bought a while ago, waiting on my Corsair RM650x to come in
 
 At this very moment, it's running Windows 7 Ultimate x64. Once I get to a point where I'm happier with the build, I'll switch it over to Linux and start ricing. It has Windows right now cause I'm just using it for some games and when I last fucked with the hardware, it was the middle of the night so I didn't want to spend too much time setting up a Linux distro the way I want it and everything right then, just putting that off for later (especially cause I use Arch btw)
 
 I have been playing some Half Life 2 lately. I forgot how fucking fun that game is.
 
 Aside from my PC, my birthday was technically yesterday (it's about 2:30AM as of writing this, and I've been up for a while, so I still consider it today). Now I'm 2 years away from being able to legally drink (and smoke since the law change, although I still do both anyways).
 
 I'm gonna stop rambling. Life is fairly decent right now. Not too much to "rant" about except for shit with my roommates, but I won't bore everyone with that1
- 
				    					
					
					CRYPTO RECOVERY COMPANIES FOR HIRE CONTACT ADWARE RECOVERY SPECIALIST
 
 It felt like fate when I first encountered the automated trading system that promised to transform small investments into substantial wealth over time. The marketing was aggressive, bombarding my social media feeds with images of people lounging on exotic beaches, driving fancy cars, and celebrating their newfound financial freedom. WhatsApp info:+12723328343 As a recent college graduate struggling to make ends meet, I was desperate for a way out of my financial rut, and the allure of easy money was too tempting to ignore. On a whim, I decided to take the plunge. I borrowed from my meager savings and even took out a small loan to fund my excitement. The rush I felt when signing up was like nothing I had ever experienced—an intoxicating thrill, like hopping onto a rollercoaster at full speed. At first, everything seemed to be going exactly as promised. My investment seemed to grow almost overnight, doubling and tripling in value.
 My skepticism began to fade, replaced by a sense of confidence and hope for the future. I even shared my success with friends and family, excitedly telling them about the platform that was going to change my life. I imagined a future free from financial worries, a life of luxury and freedom, all thanks to this “revolutionary” trading system. But soon, a familiar sense of unease began to settle in. What had been an impressive surge in profits suddenly plateaued, and I found myself facing unexpected hurdles when trying to withdraw my funds. Pop-up messages about my “account needing an upgrade” and “market tightening” explained away the issues, but the discomfort grew. Still, I convinced myself that success required patience and continued to hold out hope that the system would recover. As weeks turned into months, my investment continued to dwindle. The once-promising account balance plummeted, and each attempt to reach customer support went unanswered. The promises of easy wealth had turned into an unsettling nightmare. Email info: Adwarerecoveryspecialist@auctioneer. net Desperate for answers, I began scouring the internet for any information or advice. That’s when I stumbled across reviews of ADWARE RECOVERY SPECIALIST , a service that seemed to specialize in helping people like me recover lost funds from fraudulent platforms. I felt a glimmer of hope as I read about others who had managed to retrieve their investments with the help of ADWARE RECOVERY SPECIALIST. Perhaps, after all, there was still a way out of this mess. I reached out to their team, and to my relief, they were able to assist me in recovering a portion of the money I thought I had lost for good. ADWARE RECOVERY SPECIALIST gave me the guidance and support I needed to navigate this complicated process, helping me regain control of a situation that had seemed hopeless. Their professionalism and expertise allowed me to salvage what I could, and for that, I am incredibly grateful. 5 5
- 
				    					
					
					4Remodel Florida: Your Trusted Partner for Full Home Renovation, Bathroom Remodeling, and Bathroom Renovation
 When it comes to transforming your home into a beautiful and functional space, 4Remodel Florida is the name you can trust. Whether you're looking for a full home renovation near me, a bathroom remodeling project, or a complete bathroom renovation, our expert team is here to help. We proudly serve Deerfield Beach, Broward County, and the surrounding areas, offering high-quality, customized renovation solutions that enhance both the style and functionality of your home.
 
 Located at 213 Goolsby Blvd, Deerfield Beach, FL 33442, 4Remodel Florida is dedicated to delivering exceptional results, ensuring that your renovation dreams come to life. Our team of experienced professionals is committed to providing the best in home remodeling and renovation, whether you're upgrading a single room or undertaking a major transformation.
 
 Why Choose 4Remodel Florida for Your Renovation?
 At 4Remodel Florida, we understand the importance of having a space that not only looks great but also functions seamlessly. Here’s why we are the go-to choice for full home renovation near me, bathroom remodeling, and bathroom renovation services:
 
 Expert Full Home Renovation Services
 A full home renovation near me is a big decision, and we’re here to help make it a smooth and successful experience. From updating your living room to remodeling your kitchen or adding extra rooms, we handle every aspect of your home’s renovation. We take the time to understand your needs and design solutions that fit your lifestyle and budget.
 
 Specialized Bathroom Remodeling
 4Remodel Florida is a leading provider of bathroom remodeling services in Deerfield Beach and beyond. If you're looking to upgrade your bathroom, whether it’s with new fixtures, tile, or an entire redesign, we have the expertise to create a stylish, functional space. Our team works closely with you to bring your bathroom vision to life.
 
 Complete Bathroom Renovation
 A bathroom renovation can be the perfect way to transform an outdated or inefficient bathroom into a modern, luxurious retreat. Whether you want to install a new shower, upgrade your tub, or enhance your storage, we provide comprehensive renovation services that will meet your needs and exceed your expectations.
 
 Custom Solutions Tailored to Your Needs
 Every renovation project is unique, and at 4Remodel Florida, we offer custom solutions tailored to your exact specifications. We collaborate with you to design and execute a plan that reflects your style while improving the functionality of your space. Whether it's a complete full home renovation or a smaller bathroom remodeling project, our team ensures that every detail is perfect.
 
 High-Quality Craftsmanship and Materials
 We believe that quality should never be compromised. That's why we use only the best materials and work with skilled craftsmen who are dedicated to delivering superior results. When you choose 4Remodel Florida, you can expect your renovation to last for years to come.
 
 Affordable and Transparent Pricing
 At 4Remodel Florida, we believe that quality renovations should be accessible. We offer competitive pricing with no hidden fees, so you know exactly what to expect. We work within your budget while maintaining the highest standards of quality and craftsmanship.
 
 Exceptional Customer Service
 From the initial consultation to the final walk-through, we’re with you every step of the way. Our team is committed to ensuring a smooth renovation process, and we’re always available to answer your questions and address any concerns.
 
 Our Renovation Services
 As a trusted provider of full home renovation near me, bathroom remodeling, and bathroom renovation services, we offer a wide range of home renovation solutions to meet your needs:
 
 Full Home Renovations: Whether you want to update a few rooms or completely renovate your home, we offer comprehensive services that cover everything from design to construction.
 
 Bathroom Remodeling: Update your bathroom with modern features, such as new vanities, fixtures, flooring, and showers. We specialize in creating stylish, functional bathrooms that fit your lifestyle.
 
 Bathroom Renovation: A complete bathroom renovation involves everything from structural changes to aesthetic improvements. Whether you’re looking for a spa-like retreat or a more practical space, we can help you achieve your dream bathroom.
 
 Kitchen Remodeling: Upgrade your kitchen with custom cabinetry, countertops, and new appliances that improve functionality and style.
 
 Room Additions: Need more space? We can design and build room additions that seamlessly integrate with your existing home.7
- 
				    					
					
					I have been working on a long time, low progress project of mine that keeps on giving and giving.
 
 Let's begin like two years ago where I dipped my toes into "more then gigabit" networking thanks to a Linus Techtips video about infiniband.
 I had the dream of booting my Workstation from my NAS, a so called diskless setup.
 
 Well, since I run FreeNAS on my Nas , a very nice Freebsd based Nas OS, everything's gonna be good.
 
 In the beginning, there was no infiniband support.
 Turns out, you don't need it, since the mellanox CX2 nics can do ETH too.
 Yay.
 Just took me a few weeks of anger.
 
 So, to be able to boot something over the network, you need firmware that finds the bookable stuff and loads it.
 That protocol and firmware is called PXE.
 PXE needs a DHCP telling it what to do, and what is where and etc.
 
 Freenas here I come! Installing dnsmasq on the actual freenas install turned out to be not that great of an idea because freenas thinks of itself as being an "appliance" that you don't fiddle with. So things work, until you update/ upgrade when everything will basically be wiped, except what you have done through the ui.
 Ok. So I gona use a jail, a container like thing for that.
 Everything is great, jail has internet, everything Installs fine, what could go wrong?
 Dnsmasq can launch and work, but not as dhcp server. Some thing about permissions.
 Turns out, jails have permission like things.
 A few days of head scratching later, it has ALL the permissions.
 Dnsmasq still can't work as DHCP server though, why you ask?
 Because it needs a specific kernelmodule that isn't contained in the jail. Since jails are kind of like a docker container, they run on the same OS kernel, who does not have this module, I'd need to patch the freenas, which is an appliance, so fuck that.
 
 Like a year later, freenas has finally added good VM support, so why not make a VM for the dhcpserver?
 
 Well, about a year ago, I didn't know that the virtual Intel nic is a fucken unstable piece of garbage, crashing nearly any OS at some point.
 
 So that was it for a while again.
 
 Now to the last few weeks.
 Finally dnsmasq is running in a freebsd VM with a good and working configuration which is rather simple, if those tutorial fuckers out there would explain shit instead of just telling you to copy, paste and replace X.
 
 Now back to the PXE side.
 I'm using iPXE because I have no clue how to boot anything over tftp so iSCSi it is, since that is what I can relate too.
 The idea behind iscsi is to fake a SCSI disk over the network. Attached devices appear as if they are actually directly connected to the machine instead of over the network.
 
 iPXE gets a lease from the server, can connect to it, everything is fucken great. Finally.
 Except that if it "sanBoots" the iscsi drive, it can't find anything to boot.
 Well fuck.
 If I attach a Linux live USB over iscsi, it boots, finds grub, and crashes because the live iso isn't configured for network-boot.
 But it boots.
 So what's so different?
 
 Well iPXE is booted in legacy mode, where as the content of the target is windows 10 in efi mode.
 Ffff.
 
 Ok. Can I get iPXE to boot in EFI mode?
 
 Well yes, after like 3 days fiddling with it.
 But it only finds the onboard Intel nic instead of the new Mellanox CX3 cards, and can't even connect to the target....
 
 Sooo, I guess my options are as follows.
 Either, get PXE efi to work on the network cards directly, its called flexboot and might be able to since I just found some firmware options for that.
 
 Or give up on efi and install windows in legacy mode.
 Which isn't that easy when it has to end up on a drive on my nas.
- 
				    					
					
					Top Recovery Services for Scam Victims//Cranix Ethical Solutions Haven
 
 It was on Monday when a friend reached out to me through Reddit, sharing an enticing story about how he had invested $1,000 and received a staggering $5,000 return. His excitement was palpable, and he encouraged me to contact an Instagram account called dollar_fx to start earning money as well. Intrigued by the promise of high returns and the allure of quick wealth, I decided to message dollar_fx. They presented themselves as knowledgeable Bitcoin miners and account managers, claiming to work with a trading company named dollar_fx. Their professionalism and confidence convinced me that this was a legitimate opportunity. After some back-and-forth communication, I sent $2,000 worth of Bitcoin to dollar_fx. To my astonishment, my account on their platform soon displayed a profit of $21,800. The excitement was overwhelming, and I eagerly attempted to withdraw my funds. However, I was met with a request for a withdrawal fee of $3,650. Although this seemed unusual, I complied, believing it was a standard procedure in the world of cryptocurrency trading. Encouraged by the apparent growth of my investment, dollar_fx convinced me to invest another $1,000 in Bitcoin, promising even higher returns. A week later, my account balance soared to $45,800, but once again, I was faced with another withdrawal fee this time, it was $3,700. Desperate to access my funds, I borrowed money to pay the fee, but my withdrawal status remained pending. When I sought clarification, dollar_fx instructed me to grant the Support Team access to my Instagram account, including backup codes. Alarmed yet trusting their explanation, I complied, thinking it was necessary for the process. Soon after, the Support Team demanded an additional $12,400, claiming it was essential to upgrade my account due to SEC regulations. At this point, a sinking feeling settled in. I tried calling dollar_fx, but they had ghosted me. It became painfully clear: I had been scammed. In a panic, I immediately reset my Instagram account to lock out the fraudsters. Later, I discovered that my friend’s Reddit account had been hacked; the initial message that lured me in was sent by scammers posing as him. Devastated by the loss, I sought help from CRANIX ETHICAL SOLUTIONS HAVEN to investigate and hopefully recover my funds. To my relief, CRANIX ETHICAL SOLUTIONS HAVEN successfully recovered all the money I had lost. I am incredibly grateful for their excellent work.
 EMAIL: cranixethicalsolutionshaven @ post . com
 WHATSAPP: +.4.4.7.4.6.0.6.2.2.7.3.02
- 
				    					
					
					Black Sheep Construction LLC: Your Trusted Roofing Company and Expert Roofers in Holly Springs, NC
 When it comes to the safety and longevity of your home, the roof is one of the most critical elements. At Black Sheep Construction LLC, we are proud to be one of the leading roofing companies in Holly Springs, NC. Whether you need a minor roof repair or a complete roof replacement, our team of expert roofers is here to provide you with high-quality, reliable services that ensure your home is protected for years to come.
 
 Trusted Roofing Company: Quality You Can Depend On
 As a well-established roofing company, Black Sheep Construction LLC has built a reputation for delivering top-notch roofing solutions in the Holly Springs area. We understand that your roof is an investment, and we treat it with the care and attention it deserves. Our team works with a variety of roofing materials, including asphalt shingles, metal roofing, and more, ensuring that you get the best solution for your needs.
 
 Our roofing services include:
 
 Roof Installation: Whether you're building a new home or replacing an old roof, our skilled roofers provide efficient and durable roof installations.
 Roof Repairs: From minor leaks to significant storm damage, we quickly assess and repair your roof to restore its integrity.
 Roof Inspections: Regular roof inspections help identify potential problems before they become costly issues. We offer thorough inspections to ensure your roof is in top condition.
 Roof Maintenance: Keeping your roof in great shape with routine maintenance is crucial. Our team provides maintenance services to extend the lifespan of your roof and keep it performing well.
 At Black Sheep Construction LLC, we pride ourselves on providing reliable, affordable roofing solutions that are designed to last.
 
 Expert Roofers: Skilled, Experienced, and Ready to Help
 When it comes to roofing, experience matters. As expert roofers, our team at Black Sheep Construction LLC is equipped with the knowledge and skills to handle all types of roofing projects. Whether you're dealing with a roof leak, need a complete replacement, or are looking to upgrade to a more energy-efficient roof, we are here to help.
 
 What sets our roofers apart?
 
 Professional Expertise: Our team is highly trained and stays up-to-date with the latest roofing techniques and materials to provide the best service possible.
 Attention to Detail: We take great care in every aspect of our work, from proper installation to precise repairs, ensuring that no detail is overlooked.
 Customer Satisfaction: We value your home as much as you do. Our team works hard to ensure your roofing project is completed to your satisfaction, on time, and within budget.
 Safety and Cleanliness: We adhere to the highest safety standards and maintain a clean job site throughout the duration of your project.
 Why Choose Black Sheep Construction LLC?
 Local Expertise: As a locally-owned and operated business in Holly Springs, NC, we understand the unique roofing needs of our community and offer services tailored to local weather conditions and building codes.
 Quality Materials: We only use top-quality roofing materials that are durable, long-lasting, and designed to withstand the elements.
 Affordable Solutions: Our pricing is competitive, and we offer free, no-obligation estimates so you can make an informed decision.
 Comprehensive Services: Whether you need a roof inspection, repair, replacement, or installation, we provide all the roofing services you need in one place.
 Get in Touch with Black Sheep Construction LLC Today
 If you’re looking for reliable roofing companies or skilled roofers in Holly Springs, NC, Black Sheep Construction LLC is here to help. We are committed to providing top-quality service that ensures your roof is in excellent condition, keeping your home safe and secure.
 
 Call us today at +1 (919) 946-3013 or visit our office at 350 Raleigh St, Holly Springs, NC 27540. Let us help you with all your roofing needs!1
- 
				    					
					
					Trusted Locksmith Services by Local Locksmiths
 When it comes to securing your property and ensuring that you can access your home, business, or vehicle without stress, having a reliable locksmith on hand is crucial. At Local Locksmiths, we provide professional, fast, and affordable locksmith services in Hallandale Beach, FL, and the surrounding areas. Whether you need help in an emergency or are looking to upgrade your security systems, our expert team is here to assist you.
 Your Go To Locksmith Experts
 Located at 1000 NE 12th Ave, Hallandale Beach, FL 33009, Local Locksmiths is committed to delivering high quality locksmith services for residential, commercial, and automotive needs. Our experienced technicians are well equipped to handle a wide variety of services with precision and care. We understand how important it is to feel safe and secure, and our goal is to make sure you can trust us with your locksmith needs.
 Comprehensive Locksmith Services
 Local Locksmiths offers a wide range of locksmith services designed to meet the diverse needs of our clients. Whether you're locked out of your home or need new locks installed at your business, our skilled technicians have got you covered.
 Residential Locksmith Services
 We offer lockout assistance, rekeying services, lock replacements, and home security upgrades. Protecting your family and belongings is our priority, and we provide solutions to ensure your home remains secure at all times.
 Commercial Locksmith Services
 For business owners, we offer high security lock systems, master key systems, keyless entry installations, and access control solutions to help you maintain a secure and efficient environment. Our team can handle the specific needs of your business, ensuring that your property and assets are well protected.
 Automotive Locksmith Services
 Locking yourself out of your car or losing your keys can be a frustrating experience. Local Locksmiths offers automotive locksmith services, including car key replacements, transponder key programming, and ignition repairs, so you can get back on the road quickly.
 Emergency Locksmith Services
 Lock and key issues can occur at any time, and that’s why we offer 24/7 emergency locksmith services. Whether you're locked out of your home, office, or car, our team is ready to respond quickly and get you the help you need, no matter the time of day or night.
 Why Choose Local Locksmiths?
 Experienced and Professional Technicians
 At Local Locksmiths, we only employ fully trained and experienced locksmiths who are equipped with the knowledge and tools necessary to complete every job to the highest standard. No job is too big or too small for our team.
 Fast and Reliable Service
 We understand the urgency of lock and key problems, which is why we prioritize fast and efficient service. Our locksmiths respond quickly to emergencies, and we always aim to resolve your issue on the spot.
 Affordable and Transparent Pricing
 When you choose Local Locksmiths, you can expect competitive prices and no hidden fees. We provide upfront quotes and ensure that our pricing is clear and fair.
 Contact Local Locksmiths Today
 Whether you're in need of urgent assistance or just want to ensure that your property is secure, Local Locksmiths is here to help. Contact us at +1 754-551-1841 to speak with a friendly representative, or visit our office at 1000 NE 12th Ave, Hallandale Beach, FL 33009.
 Trust Local Locksmiths for all your locksmith needs your security is our priority!2
- 
				    					
					
					Trusted Locksmith Services by Local Locksmiths
 
 When it comes to securing your property and ensuring that you can access your home, business, or vehicle without stress, having a reliable locksmith on hand is crucial. At Local Locksmiths, we provide professional, fast, and affordable locksmith services in Hallandale Beach, FL, and the surrounding areas. Whether you need help in an emergency or are looking to upgrade your security systems, our expert team is here to assist you.
 
 Your Go-To Locksmith Experts
 Located at 1000 NE 12th Ave, Hallandale Beach, FL 33009, Local Locksmiths is committed to delivering high-quality locksmith services for residential, commercial, and automotive needs. Our experienced technicians are well-equipped to handle a wide variety of services with precision and care. We understand how important it is to feel safe and secure, and our goal is to make sure you can trust us with your locksmith needs.
 
 Comprehensive Locksmith Services
 Local Locksmiths offers a wide range of locksmith services designed to meet the diverse needs of our clients. Whether you're locked out of your home or need new locks installed at your business, our skilled technicians have got you covered.
 
 Residential Locksmith Services
 We offer lockout assistance, rekeying services, lock replacements, and home security upgrades. Protecting your family and belongings is our priority, and we provide solutions to ensure your home remains secure at all times.
 
 Commercial Locksmith Services
 For business owners, we offer high-security lock systems, master key systems, keyless entry installations, and access control solutions to help you maintain a secure and efficient environment. Our team can handle the specific needs of your business, ensuring that your property and assets are well-protected.
 
 Automotive Locksmith Services
 Locking yourself out of your car or losing your keys can be a frustrating experience. Local Locksmiths offers automotive locksmith services, including car key replacements, transponder key programming, and ignition repairs, so you can get back on the road quickly.
 
 Emergency Locksmith Services
 Lock and key issues can occur at any time, and that’s why we offer 24/7 emergency locksmith services. Whether you're locked out of your home, office, or car, our team is ready to respond quickly and get you the help you need, no matter the time of day or night.
 
 Why Choose Local Locksmiths?
 Experienced and Professional Technicians
 At Local Locksmiths, we only employ fully trained and experienced locksmiths who are equipped with the knowledge and tools necessary to complete every job to the highest standard. No job is too big or too small for our team.
 
 Fast and Reliable Service
 We understand the urgency of lock and key problems, which is why we prioritize fast and efficient service. Our locksmiths respond quickly to emergencies, and we always aim to resolve your issue on the spot.
 
 Affordable and Transparent Pricing
 When you choose Local Locksmiths, you can expect competitive prices and no hidden fees. We provide upfront quotes and ensure that our pricing is clear and fair.
 
 Contact Local Locksmiths Today
 Whether you're in need of urgent assistance or just want to ensure that your property is secure, Local Locksmiths is here to help. Contact us at +1 754-551-1841 to speak with a friendly representative, or visit our office at 1000 NE 12th Ave, Hallandale Beach, FL 33009.
 
 Trust Local Locksmiths for all your locksmith needs—your security is our priority!1
- 
				    					
					
					MCIA-LEVEL-1 MuleSoft Certified Integration Architect - Level 1 test is one of the MuleSoft affirmation tests, which can upgrade your position and work on your life. However, how do get ready for the MCIA-LEVEL-1 test well and pass it effectively? While scanning on the web asset for MCIA-LEVEL-1 MuleSoft Certified Integration Architect - Level 1 test, DumpsCafe strongly prescribes you pick an online MCIA-LEVEL-1 practice test. MuleSoft Certified Integration Architect - Level 1 MCIA-LEVEL-1 test questions are kept in touch with the best expectations of specialized exactness, given by our guaranteed well-informed authorities and distributed creators for advancement. You will pass MCIA-LEVEL-1 MuleSoft Certified Integration Architect - Level 1 test with online review materials, 100% cashback included.
 Get ready to pass the exam with the help of the MuleSoft MCIA-LEVEL-1 exam:
 
 Readiness of accreditation tests could be covered with two asset types. The first is the review guides, reference books, and study discussions that are explained and suitable for developing data starting from the earliest stage. Aside from the video instructional exercises and talks are a decent choice to facilitate the aggravation of through study and are somewhat make the review cycle really fascinating in any case these interest time and fixation from the student.
 
 Brilliant up-and-comers who wish to make a strong establishment out and out assessment themes and associated advancements commonly blend video addresses with a concentrate on advisers for harvest the upsides of each, however, practice tests or practice test motors is one significant review device that goes ordinarily unnoted by most competitors.
 
 Practice tests are planned with our specialists to make test possibilities test their insight on abilities accomplished in the course, just as possibilities become agreeable and acquainted with the genuine test climate. Measurements have shown test uneasiness assumes a lot greater part in an understudy's disappointment in the test than the dread of the obscure.
 Confirmation questions master group suggests setting up certain notes on these subjects alongside it remember to rehearse MuleSoft MCIA-LEVEL-1 dumps which had been composed by our master group, each of these can help you loads to clear this test with superb imprints.
 
 DumpsCafe gives you the latest MCIA-LEVEL-1 exam questions:
 
 DumpsCafe has in addition presented two or three supporting devices and learning modes that will help you in having a fitting enthusiasm for the fundamental limits and to additional work with your MCIA-LEVEL-1 dumps status association with getting MuleSoft Architect attestation with a guarantee. A couple of up-and-comers need to further develop abilities to get movements or others need to have a promising beginning in the MuleSoft MCIA-LEVEL-1 dumps announcement world and with this part, they can plan as shown by their singular basics.
 DumpsCafe MCIA-LEVEL-1 test dumps are similarly open in the pdf plan so you can use this report in any of your splendid devices whether it is a PDA, tablet, or even a PC. We have made this relationship in the pdf record so it can end up being less difficult for you to utilize and you can start perusing for your MuleSoft Certified Integration Architect - Level 1 test wherever.
 MuleSoft MCIA-LEVEL-1 content makes you ready for the real exam:
 
 Rather than following the ages-old idea of MuleSoft Certified Integration Architect - Level 1 test readiness utilizing voluminous books and notes, DumpsCafe has presented a brief, direct, and most important substance that is incredibly useful in passing any accreditation MuleSoft Certified Integration Architect - Level 1 test. For an occurrence, their MCIA-LEVEL-1 refreshed review guide covers the whole prospectus in a particular number of inquiries and replies. The data, given in the review questions, is streamlined to the level of a normal test competitor. Any place, it is fundamental, the appropriate responses have been clarified further with the assistance of reproductions, diagrams, and additional notes.
 
 Conclusion:
 
 Need to pass your MuleSoft MCIA-LEVEL-1 test in the primary attempt? Download the most recent MuleSoft Certified Integration Architect - Level 1 MCIA-LEVEL-1 dumps and invest however much energy as could be expected to rehearse before your MuleSoft Certified Integration Architect - Level 1 exam. Passcert group profoundly proposes everybody purchase MuleSoft Certified Integration Architect - Level 1 MCIA-LEVEL-1 dumps when you will take your test in several weeks. Please keep sufficient opportunities to practice. DumpsCafe guarantees 100% passing your MuleSoft certificate MCIA-LEVEL-1 test effectively.
 
 For more info: www(dot)dumpscafe(dot)com/Braindumps-MCIA-Level-1.html1
- 
				    					
					
					Alber Sign Company: Your Trusted Provider of Privacy Film, Business Signs, and Sign Services in Rockledge, PA
 
 Welcome to Alber Sign Company, your local expert in business signs, privacy film, sign installation, and comprehensive sign services. Located in Rockledge, PA, we are dedicated to helping businesses of all sizes create the perfect signage solutions to enhance their visibility, privacy, and overall professional appearance. Whether you need stylish signs for your storefront, office, or a custom privacy film solution, we have the expertise and experience to meet your needs.
 
 Why Choose Alber Sign Company?
 Enhance Your Privacy with Professional Privacy Film Solutions
 Privacy is essential, especially in business settings. Whether you're looking to shield confidential office spaces or create a more secluded environment, privacy film is an excellent solution. Our privacy films provide you with the ideal balance of privacy and natural light, transforming your workspace into a more secure and comfortable environment. From office partitions to storefront windows, we offer custom privacy film that helps reduce glare while maintaining the aesthetics of your space.
 
 Custom Business Signs Tailored to Your Brand
 Business signs are a vital tool in establishing your brand's identity and attracting customers. At Alber Sign Company, we specialize in creating business signs that reflect your brand's unique style and message. Whether you need interior signs for your office, exterior signs for your storefront, or a combination of both, we offer custom designs that will make your business stand out. From bold and illuminated signs to sleek, professional displays, we help your business get noticed.
 
 Professional Sign Installation for Maximum Impact
 Proper sign installation is crucial to ensuring that your signage not only looks great but also functions effectively. Our experienced team handles all aspects of sign installation, ensuring your signs are securely mounted and positioned for maximum visibility. Whether you're installing business signs on your storefront, privacy film in your office, or directional signs inside your building, we make sure everything is done right the first time.
 
 Comprehensive Sign Services to Support Your Business
 At Alber Sign Company, we offer a full range of sign services to meet your needs. Our services include design, manufacturing, installation, maintenance, and repair of all types of signage. Whether you’re looking to refresh your existing signs or require new signage solutions, we provide professional service every step of the way. We’re here to ensure that your signage remains in top condition and continues to support your business growth.
 
 Affordable and Reliable Signage Solutions
 We believe that high-quality signage should be accessible to businesses of all sizes. At Alber Sign Company, we offer competitive pricing without compromising on the quality of our work. Whether it's a privacy film for your office, a custom business sign, or a complete sign installation and sign service package, you can count on us for affordable, reliable, and durable solutions.
 
 Our Services
 Privacy Film: Custom privacy films for office spaces, conference rooms, and storefront windows.
 
 Business Signs: Custom interior and exterior signs to boost your business's visibility and brand identity.
 
 Sign Installation: Professional installation for all types of signage, ensuring secure and effective placement.
 
 Sign Services: Comprehensive sign repair, maintenance, and design upgrade services.
 
 Contact Us Today
 Ready to take your business to the next level with high-quality business signs, privacy film, and expert sign installation? Alber Sign Company is here to help. Our team of professionals is dedicated to providing the best signage solutions for your business, tailored to your specific needs.
 
 Contact Information
 Address: 902 Fox Chase Rd, Rockledge, PA 19046, United States
 Phone: +1 (267) 847-47355
- 
				    					
					
					Transform Your Kitchen with JR Stone Design Inc: Leading Kitchen Contractors in Palm Beach County and Boca Raton
 
 Your kitchen is the heart of your home, and when it’s time to update or remodel, you want to ensure you’re working with a reliable, skilled team of professionals. That’s where JR Stone Design Inc comes in. As trusted kitchen contractors serving Palm Beach County and Boca Raton, we specialize in transforming kitchens into beautiful, functional spaces. With years of experience, a commitment to quality, and an eye for detail, we are your go-to team for all things kitchen remodeling.
 
 Why Choose JR Stone Design Inc as Your Kitchen Contractors?
 At JR Stone Design Inc, we know that every kitchen is unique. Whether you're planning a small upgrade or a complete kitchen remodel, we provide personalized solutions to meet your needs and vision. We proudly serve Palm Beach County and Boca Raton, offering expert kitchen design, high-quality materials, and craftsmanship you can trust.
 
 Here’s why homeowners choose us as their kitchen contractors:
 
 1. Customized Kitchen Design
 We believe that your kitchen should reflect your personal style and work seamlessly with your home’s layout. Our expert designers work with you to create a kitchen that fits your vision, functional needs, and lifestyle. Whether you’re looking for a modern, sleek design or a more traditional, cozy feel, we bring your ideas to life with customized design solutions.
 
 2. Top-Quality Materials
 At JR Stone Design Inc, we prioritize quality. We use only the best materials for your remodel, ensuring that your kitchen not only looks stunning but is also durable and built to last. From premium countertops, cabinetry, and backsplashes to flooring and lighting, we source high-quality materials to bring your kitchen dreams to life.
 
 3. Experienced Kitchen Contractors
 Our team consists of experienced kitchen contractors who bring their extensive expertise to every project. With years of experience in the industry, we understand what it takes to create a kitchen that is both beautiful and functional. Our skilled contractors ensure that every detail is executed with precision, and we handle all aspects of the remodel from start to finish.
 
 4. Comprehensive Kitchen Remodeling Services
 We offer a full range of kitchen remodeling services for homeowners in Palm Beach County and Boca Raton, including:
 
 Custom Cabinet Design and Installation
 Our team designs and installs custom cabinetry that fits your space and maximizes storage. Whether you prefer classic wood cabinetry or modern sleek designs, we tailor the cabinetry to suit your style.
 
 Countertop Installation
 Choose from an array of countertop options, including granite, quartz, marble, and more. Our team ensures flawless installation and provides expert guidance in selecting the best material for your needs.
 
 Backsplash Design and Installation
 A backsplash can instantly transform the look of your kitchen. We offer a wide selection of tiles, patterns, and designs to create a backsplash that complements your kitchen’s style and enhances its aesthetic.
 
 Flooring Solutions
 We install a variety of durable and stylish flooring options, including hardwood, tile, and stone, to create a kitchen floor that perfectly matches your design and functionality needs.
 
 Lighting and Fixtures
 Lighting plays a critical role in creating ambiance and functionality in your kitchen. From task lighting to accent lighting, we help you choose and install the perfect lighting and fixtures to elevate your space.
 
 5. On-Time and On-Budget Remodeling
 We understand that kitchen remodels can be a big undertaking, and we’re committed to completing your project on time and within budget. Our team works efficiently, staying on schedule and providing transparent pricing so you can plan accordingly. We don’t believe in hidden fees, and we keep you informed throughout every stage of the process.
 
 6. Personalized Customer Service
 At JR Stone Design Inc, customer satisfaction is our top priority. We take the time to understand your specific needs and work closely with you to ensure that every detail of your kitchen remodel is executed to perfection. From the initial consultation to the final walkthrough, we provide exceptional customer service every step of the way.
 
 Why Homeowners in Palm Beach County and Boca Raton Choose Us
 Here’s why homeowners in Palm Beach County and Boca Raton trust JR Stone Design Inc for their kitchen remodeling projects:
 
 Locally Owned and Operated: As a local business, we understand the specific needs and preferences of homeowners in Palm Beach County and Boca Raton.
 Comprehensive Kitchen Services: We handle every aspect of kitchen remodeling, from custom cabinetry to lighting and flooring installation. 1 1
- 
				    					
					
					Bob's Landscape & Irrigation Solutions LLC: Expert Installation of New Irrigation Systems in Fort Worth, TX
 
 At Bob's Landscape & Irrigation Solutions LLC, we specialize in the design and installation of new irrigation systems that ensure your lawn and garden stay healthy, lush, and vibrant throughout the year. Whether you’re looking to install a system for a new property or upgrade an old, inefficient system, our team of professionals is here to provide reliable and efficient solutions in Fort Worth, TX.
 
 Why Choose Bob's Landscape & Irrigation Solutions for Your New Irrigation System?
 Located at 1465 Mil Oaks Ln, Fort Worth, TX 76135, Bob's Landscape & Irrigation Solutions LLC is the trusted name in new irrigation system installations. We are dedicated to delivering high-quality, sustainable irrigation systems tailored to meet the specific needs of your property. Here’s why we are the best choice for installing a new irrigation system:
 
 1. Custom Design & Consultation
 We understand that every lawn and garden is unique, and so are your irrigation needs. Our team works closely with you to design a new irrigation system that fits the layout of your property, ensuring your plants, lawn, and garden beds get the right amount of water. We take into account factors like plant types, soil conditions, and sun exposure to create a customized solution.
 
 2. Efficient & Sustainable Systems
 At Bob's Landscape & Irrigation Solutions LLC, we’re committed to sustainability. Our new irrigation system installations are designed to minimize water waste and maximize efficiency. We use the latest technology, such as smart controllers, water-efficient sprinkler heads, and sensors, to help you conserve water while keeping your landscape healthy.
 
 3. Expert Installation
 Our experienced technicians handle every step of the installation process with precision and care. From setting up the system and digging trenches to testing the system for efficiency, we ensure that your new irrigation system is installed correctly and functions optimally from day one.
 
 4. Affordable & Transparent Pricing
 We believe in providing high-quality services at competitive rates. Our transparent pricing ensures there are no hidden fees, and we offer free consultations and estimates to help you make an informed decision about your new irrigation system. We’ll work with you to stay within your budget without compromising on quality.
 
 5. Ongoing Support & Maintenance
 After your new irrigation system is installed, we don’t leave you hanging. We offer ongoing maintenance and support to ensure your system continues to operate efficiently year after year. From seasonal adjustments to troubleshooting, our team is always available to help.
 
 The Benefits of Installing a New Irrigation System
 Installing a new irrigation system comes with many advantages. Here are just a few reasons why you should consider upgrading or installing a new system:
 
 Water Conservation: A professionally installed irrigation system reduces water waste by delivering the right amount of water directly to your plants, promoting healthy growth while saving water.
 
 Consistent Lawn Care: With a new irrigation system, you can ensure that your lawn and garden receive consistent watering, even when you’re busy or away.
 
 Time-Saving: A smart irrigation system can be programmed to water your landscape automatically, saving you time and effort compared to traditional manual watering.2
- 
				    					
					
					mail: contactus @ hacksavvy technology . com
 
 Website: https : // hacksavvy techrecovery . com
 
 Whatsapp : +79998295038
 
 My name is Agustin , a seasoned game developer based in Tokyo. I've spent years immersed in the world of tech and innovation, and back in 2017, when Bitcoin was making waves in the tech community, I knew it was something I had to explore. Being someone who stays ahead of the curve, I decided to invest, carefully tracking the market and watching my portfolio grow steadily. By 2023, my Bitcoin holdings had reached an impressive $920,000—a significant achievement that I was proud of. But one day, during a routine system upgrade, the unthinkable happened. I accidentally deleted my entire Bitcoin wallet. At first, I couldn’t believe it. I didn’t even know it was possible to lose access so easily, and worse, in the chaos of managing work and personal projects, I had misplaced my recovery codes. I was devastated. All those years of smart investment, my carefully built savings—gone in an instant. It felt like a catastrophic mistake, and I was kicking myself for not being more careful. After days of searching for solutions, I stumbled upon Hack Savvy Tech through a well-regarded tech blog I frequently read. At first, I was skeptical. After all, could they really retrieve something that seemed so irreversibly lost? But as a professional who understands the importance of expertise, I decided to trust them. I figured if anyone could fix this, it would be people with a deep knowledge of cryptocurrency and digital recovery. I’m beyond glad I reached out. The team at Hack Savvy Tech was incredibly responsive and professional from the very first contact. They were patient, took the time to understand my problem in detail, and reassured me that they had handled cases like mine before. Their communication was top-notch, and I felt like I was in capable hands the entire time.Within just a few weeks, they did the impossible—they recovered my Bitcoin wallet. Seeing that $920,000 safely restored was one of the most relieving moments of my life. I can’t express enough how thankful I am to the team for their expertise and dedication. If you’re like me, someone deeply knowledgeable about tech but still caught off guard by unexpected situations, I urge you not to panic. Whether you’re in Japan or anywhere else in the world, Wizard Web Recovery is your best bet. They’re the real deal, and I wouldn’t hesitate to recommend them to anyone facing a similar crisis.
- 
				    					
					
					Transform Your Space with Expert Vinyl Installation from Herman Renovations in Florida
 
 At Herman Renovations, we understand that choosing the right flooring for your home is essential to both its style and functionality. Vinyl installation is a popular choice for homeowners who want a durable, cost-effective, and stylish option that can withstand high traffic and everyday use. If you're considering updating your floors, our expert vinyl installation services in Florida are here to help you achieve a stunning, long-lasting result.
 
 Why Choose Vinyl Flooring for Your Home?
 Vinyl flooring has grown in popularity for its versatility, affordability, and durability. At Herman Renovations, we specialize in vinyl installation that enhances the look of your home while providing the benefits you need. Here are just a few reasons why vinyl flooring is a great choice for your home:
 
 Durability: Vinyl is incredibly durable and resistant to scratches, stains, and water damage. This makes it an ideal choice for high-traffic areas such as kitchens, bathrooms, and hallways, as well as rooms exposed to moisture.
 Affordable: Vinyl flooring is a budget-friendly option compared to hardwood, stone, and other premium flooring materials. It gives you the look of high-end flooring without breaking the bank.
 Variety of Styles: Vinyl flooring comes in a wide range of styles, including designs that mimic wood, stone, tile, and more. Whether you want the look of hardwood floors or a sleek stone design, vinyl can achieve your desired aesthetic.
 Easy Maintenance: Vinyl is easy to clean and maintain. Simply sweep or mop the floors, and they’ll look great for years to come. This low-maintenance feature makes it perfect for busy homeowners.
 Comfortable Underfoot: Unlike harder flooring materials like tile or stone, vinyl offers a softer, more comfortable surface to walk on. It’s an excellent option if you stand for long periods or want a cozy, warm floor for your living space.
 Our Vinyl Installation Services
 At Herman Renovations, we specialize in professional vinyl installation for residential and commercial properties in Florida. Whether you want to upgrade a single room or your entire home, our skilled team is here to provide high-quality installation with attention to detail. Here's what we offer:
 
 Residential Vinyl Installation
 From living rooms and bedrooms to kitchens and bathrooms, we install vinyl flooring throughout your home. Our team helps you choose the perfect style and finish that suits your space and ensures a flawless installation every time.
 
 Commercial Vinyl Installation
 We also provide vinyl installation services for businesses and commercial properties. Vinyl is an excellent choice for offices, retail spaces, and more, thanks to its durability and easy maintenance. Our team works around your schedule to minimize disruption to your business.
 
 Custom Vinyl Flooring Designs
 Looking for something unique? We can create custom vinyl flooring designs that match your aesthetic. Whether you're interested in a specific pattern or want a bold, eye-catching design, we can help bring your vision to life.
 
 Vinyl Plank and Vinyl Sheet Installation
 We offer both vinyl plank and vinyl sheet installation options to suit your preferences. Vinyl planks are ideal for creating a wood-look finish, while vinyl sheets are great for achieving seamless, water-resistant floors in bathrooms and kitchens.
 
 Vinyl Tile Installation
 If you’re looking for the look of natural stone or ceramic tiles, vinyl tiles are a great option. Our team will install vinyl tiles with precision, ensuring an elegant and durable result.
 
 Benefits of Choosing Herman Renovations for Vinyl Installation
 When you choose Herman Renovations for your vinyl installation, you're partnering with experienced professionals who are committed to delivering excellent results. Here’s why our services stand out:
 
 Expert Installation: Our skilled installers have years of experience with vinyl flooring, ensuring that your floors are installed correctly and last for years. We ensure every plank or tile is aligned perfectly, creating a flawless finish.
 High-Quality Products: We work with top-quality vinyl flooring brands that are durable and designed to withstand everyday wear. Our team ensures that your floors not only look great but also stand up to the test of time.
 Affordable Pricing: We understand the importance of staying within budget. Herman Renovations offers competitive pricing for vinyl flooring installation with no hidden fees, so you can transform your space without breaking the bank.
 Personalized Service: We take the time to understand your specific needs and preferences. Whether you want a modern look or a more classic design, we help you choose the perfect vinyl flooring option that suits your home or business. 1 1
























































