Details
- 
						AboutSinger, calligrapher, reasonable cat lady
- 
						SkillsJavaScript, C, Python, React, Redux, Django, GraphQL, Mongo
- 
						LocationTexas!
- 
						Website
- 
						Github
Joined devRant on 9/9/2018
			Join devRant
Do all the things like
				++ or -- rants, post your own rants, comment on others' rants and build your customized dev avatar
				Sign Up
			Pipeless API
 
				From the creators of devRant, Pipeless lets you power real-time personalized recommendations and activity feeds using a simple API
				Learn More
			- 
				    
				    For those struggling with imposter syndrome, keep a record of your progress.
 
 Break it down into
 
 * used
 
 * learning
 
 * dont need a manual or cheat sheet
 
 * use every day
 
 You can also break it down per project:.
 
 "Project xyz (python: 2 years)"
 "Project ijk (js:6 months)".
 
 Etc.
 
 Critically, keep these in something physical, like a notebook or whatever you use *regularly and frequently* to keep notes. That's important because you should be glancing over your progress as a remainder.
 
 Each time you want to add a new line, rewrite your existing progress on a new page, before adding the new line.
 
 So as you flip through the pages you get a large and larger chronological list of your progress, and improvement, and experience.
 
 Add a date to the title for each and a brief note about something that you did or happened on that day or week.
 
 You wont second guess yourself so much once you can see how far you came.
 
 Like at one time I was actually competent at js! (Before I stopped the flash cards anyway).3
- 
				    
				    I absolutely love the email protocols.
 
 IMAP:
 x1 LOGIN user@domain password
 x2 LIST "" "*"
 x3 SELECT Inbox
 x4 LOGOUT
 
 Because a state machine is clearly too hard to implement in server software, clients must instead do the state machine thing and therefore it must be in the IMAP protocol.
 
 SMTP:
 I should be careful with this one since there's already more than enough spam on the interwebs, and it's a good thing that the "developers" of these email bombers don't know jack shit about the protocol. But suffice it to say that much like on a real letter, you have an envelope and a letter inside. You know these envelopes with a transparent window so you can print the address information on the letter? Or the "regular" envelopes where you write it on the envelope itself?
 Yeah not with SMTP. Both your envelope and your letter have them, and they can be different. That's why you can have an email in your inbox that seemingly came from yourself. The mail server only checks for the envelope headers, and as long as everything checks out domain-wise and such, it will be accepted. Then the mail client checks the headers in the letter itself, the data field as far as the mail server is concerned (and it doesn't look at it). Can be something else, can be nothing at all. Emails can even be sent in the future or the past.
 
 Postfix' main.cf:
 You have this property "mynetworks" in /etc/postfix/main.cf where you'd imagine you put your own networks in, right? I dunno, to let Postfix discover what your networks are.. like it says on the tin? Haha, nope. This is a property that defines which networks are allowed no authentication at all to the mail server, and that is exactly what makes an open relay an open relay. If any one of the addresses in your networks (such as a gateway, every network has one) is also where your SMTP traffic flows into the mail server from, congrats the whole internet can now send through your mail server without authentication. And all because it was part of "your networks".
 
 Yeah when it comes to naming things, the protocol designers sure have room for improvement... And fuck email.
 
 Oh, bonus one - STARTTLS:
 So SMTP has this thing called STARTTLS where you can.. unlike mynetworks, actually starts a TLS connection like it says on the tin. The problem is that almost every mail server uses self-signed certificates so they're basically meaningless. You don't have a chain of trust. Also not everyone supports it *cough* government *cough*, so if you want to send email to those servers, your TLS policy must be opportunistic, not enforced. And as an icing on the cake, if anything is wrong with the TLS connection (such as an MITM attack), the protocol will actively downgrade to plain. I dunno.. isn't that exactly what the MITM attacker wants? Yeah, great design right there. Are the designers of the email protocols fucking retarded?9
- 
				    
				    I just remembered the first time I set up a Linux-Server. It was a simple Apache webserver at my first internship anf I didnt have a clue about literally anything.
 
 My mentor guided me through and gave me literal step-by-step instructions (alright, now type... and now type...).
 
 At the end he told me "OK, now run 'sudo rm -rf /*' to finish setting up". Me, being the naive and clueless motherfucker I am, happily nuked the everloving shit out of my newly setup server. I was like "Alright, WTF just happened??" He then told me "Now that you know how it works, do the entire thing again all by yourself. And you just learned an important lesson: NEVER exexute commands you dont know what theyre doing". I really did learn a lot on that day and still follow that lesson :D8
- 
				    
				    Code review titles by year:
 
 1990 - your code is using to much memory
 1995 - your code is not running on window 95
 2000 - your code is slow
 2003 - your code don't have tests
 2005 - your code is not 64 bit
 2009 - your code is not using mvc patters
 2010 - your code is not horizontal scalable
 2011 - your code should be written in js
 2015 - your code is not mobile ready
 2020 - your code is racist24

