How to Design a REST API That Doesn’t SUCK| Issue #10


Hi there,

Want to improve your REST API design? Then this week’s video is for you! 🌟

I’ll share 6 easy tips for creating user-friendly, consistent, and easily integrated REST APIs.

We’ll dive into often-overlooked aspects of REST API design, including:

  • Following standards like OpenAPI specs and OAuth for authentication 🛠️
  • Ensuring consistency in formats and naming conventions 📏
  • Keeping things simple with sensible defaults, and much more! ✨

Even big companies sometimes miss these crucial details, making their APIs harder to use. 😅

Stick around until the end for BONUS tips! 🎁

Enjoy the video and happy coding! 🚀

Cheers,

Arjan

video preview

# News

Secure Python Projects

This week, learn how to securely manage configurations and sensitive information using environment variables and dotfiles.

Protect your API keys, manage database connections, and centralize configurations effortlessly. Click here to read the blog and enhance your workflow. 🔗

Understanding Code Coverage 🧑‍💻

Marcus Buffett recently published an insightful blog post exploring the nuanced role of abstractions in programming. 🖥️

He breaks down how abstractions can make code safer and more flexible, but also warns about potential downsides like fragility and complexity.

This article is a must-read for developers looking to master the balance between abstraction and practical coding. Click here to find out more. 🛠️

# Community

Curious about the pros and cons of type hinting and static typing? 💭

Our community recently had an engaging discussion on this topic, exploring insights from industry experts and sharing personal experiences. The conversation covers how type hints can improve code clarity, support from IDEs, and reduce the need for extensive documentation. There’s also a lively debate on whether type annotations adhere to the DRY (Don’t Repeat Yourself) principle or add unnecessary redundancy.

Dive into the full discussion and enhance your understanding of type hinting! Read the full thread here. 📚


Do you enjoy my content on YouTube and would you like to dive in deeper? Check out my online courses below. They've helped thousands of developers take the next step in their careers.

🚀 The Mindset Online Course Series

The goal of this series is to help junior developers grow their skills to become senior developers faster.

💥 Other Courses

💡 If you’re part of a development team at a company, I offer special packages for companies that give your team the tools to consistently write high-quality code and dramatically increase your team's productivity.

🪄 Learntail

My team and I created an AI quiz generator designed to accelerate your learning, called Learntail. You can try it for free or unlock even more capabilities and features with the monthly subscription. Take a look here.

Unsubscribe | Send by ArjanCodes

Wolvenplein 25, Utrecht, UT 3512 CK

The Friday Loop

Every Friday, you'll get a recap of the most important and exciting Python and coding news. The Friday Loop also keeps everyone posted on new ArjanCodes courses and any limited offers coming up.

Read more from The Friday Loop

Hey everyone, I was reviewing some of the projects I’ve worked on over the past year, and I noticed something interesting: I almost never use Python’s @dataclass anymore. Not because it’s bad. In fact, dataclasses are still a great feature of the language. But as my projects have grown more complex, especially with tools like FastAPI, Pydantic, and SQLAlchemy, I’ve found that dataclasses just… don’t fit the way I design software anymore. In my latest video, I dive into this in detail. You’ll...

Hi there, You’ve probably heard that serverless is the easiest way to deploy code to the cloud. And on the surface, it is. With Google Cloud Functions, you can literally deploy a simple Python function like this: def hello(request): return "Hello from Cloud!" A few lines of code. No servers. No infrastructure. But... there are quite a few limitations: No FastAPI or async support One route per function requirements.txt only, no pyproject.toml Cold starts for large dependencies No custom...

Hey there, Heard of MCP? It stands for Model Context Protocol: an open standard that lets AI models like Claude or ChatGPT connect to real tools and data. In my latest video, I explain what MCP actually is, and show a working example where Claude can search YouTube videos using MCP. In the video you’ll learn: Why AI models can’t just call your API How MCP bridges that gap Two ways to structure your MCP integration Happy coding! Cheers, Arjan # News Upcoming Python Documentary CultRepo...