FastAPI 101

FastAPI 101

August 13, 2025

TL;DR

Ive been working with PB, DBs lately, within a FastAPI Python BackEnd and wanted to write about new concepts.

There are few tools to understand APIs as you work with them.

Intro

If you want to create your own Python Web Apps, you might have heard about FastAPI as one of the options you have.

Also, If you have ever used Reflex Python, you were using a wrap over FastApi and SQLalchemy for the backend!

Stay to see how to install the Py version you want.

FastAPI

FastAPI is a modern, high-performance web framework for building APIs (Application Programming Interfaces) with Python.

It’s designed to be fast, easy to use, and to automatically generate API documentation.

interactive API documentation out of the box…

It automatically generates two different documentation UIs based on the OpenAPI standard.

  • Swagger UI: Accessible at /docs, this is a fully interactive interface where you can see all your API endpoints, their expected parameters, and their response models. You can also make live requests directly from the browser to test your endpoints.

This is what you see at http://localhost:3900/docs in your example.

  • ReDoc: Accessible at /redoc, this is a more compact and elegant documentation UI that is better for viewing the API reference. It is designed to be read like a single-page document.

This automatic documentation is a core feature of FastAPI and is enabled by default.

It’s a key advantage because it eliminates the need for manual documentation, ensuring your API docs are always up-to-date with your code.

Whats that cool SWAGger UI…

A Swagger UI is an interactive, web-based documentation interface for an API.

It automatically generates a visual representation of your API, allowing developers to interact with and understand the endpoints without needing to write any code.

Why it Matters

The Swagger UI is a crucial tool for modern API development because it directly addresses several common challenges:

  • Discoverability: It makes an API’s functionality immediately discoverable. Developers can browse a complete list of endpoints, their methods (GET, POST, PUT, DELETE), and the paths they use, all in one place.
  • Ease of Use: It turns API documentation into a live, interactive tool. Users can try out the API directly from the UI by filling out forms for parameters and request bodies, then executing the request to see the response. This dramatically simplifies the process of learning and testing an API.
  • Consistency: When a framework like FastAPI generates a Swagger UI, it does so directly from the code. This ensures that the documentation is always up-to-date with the latest version of the API, eliminating the risk of outdated or inaccurate docs.
  • Collaboration: It serves as a single source of truth for the API’s contract.

Both front-end and back-end developers can use it to agree on data models and endpoints, which improves collaboration and reduces miscommunication.

How FASTAPI Relates to Redux, Dexie, and Local Storage… πŸš€

FastAPI, Redux, and Dexie/local storage all deal with data.

But they operate at completely different levels of the application stack.

  • FastAPI is the backend. πŸ’» It’s the server-side technology that runs on a remote machine.

Its job is to handle requests from clients (like a web browser), interact with a database (like PostgreSQL, MySQL, etc.), and send back responses.

It doesn’t run in the user’s browser!

  • Redux, Dexie, and local storage are front-end technologies. 🌐 They all run directly in the user’s browser and manage data on the client side.

  • FastAPI provides the data, and the others manage it. A typical workflow would look like this:

    1. A user visits a web page.
    2. The front-end (built with a framework like React) makes a request to the FastAPI backend to get some data.
    3. FastAPI receives the request, queries its database, and sends the data back to the front-end.
    4. The front-end receives the data. It might then:
      • Store the data in Redux to manage the application’s current state and update the UI.
      • Store a persistent copy of the data in a Dexie database to allow the user to view it offline.
      • Store a small piece of user-specific data, like a user ID or a preference, in local storage.

In short, FastAPI is the server that provides the data, while Redux, Dexie, and local storage are different ways the client (the user’s browser) can store and manage that data.

They are not competing technologies but are often used together in a modern web application.

This might be your case in some app architecture with app settings, chat histories and session management: The BE stores global data and generally, anything that the user can edit, you might not want it into the BE with PB, as PB works better for reads than for writes.


Concepts

What is an API Endpoint?

An API endpoint is a specific URL where a client application can access a web service.

Think of it as a digital address where your application sends requests to get or modify data.

For example, the following command uses an endpoint to check the service’s status:

curl -X GET "http://localhost:3900/healthcheck" -H "accept: application/json"

The endpoint’s anatomy can be broken down into three main components:

  • HTTP Method: The action to be performed (e.g., GET, POST, PUT, DELETE).
  • Base URL: The server’s address (e.g., http://localhost:3900).
  • Path: The specific resource’s location (e.g., /api/settings).

A complete endpoint request combines these parts, for example: GET http://localhost:3900/api/settings.

Endpoints and the Real World 🏠

You can think of endpoints like addresses in a city.

Each address serves a different purpose, and the HTTP method tells the server what to do at that address.

  • GET /api/settings: “Go get the user’s settings.”
  • PUT /api/settings: “Go update the user’s settings.”
  • GET /api/settings/health: “Go check if the service is working.”

This structure, where a unique combination of method and URL defines an action, makes it easy to understand and interact with a web service.

HTTP Methods Explained

MethodPurposeExample
GETRetrieve dataGet user settings
PUTUpdate/replace dataUpdate user settings
POSTCreate new dataCreate new user
DELETERemove dataDelete user account
More http methods…Head / options / patch… πŸš€

There are other HTTP methods beyond the common four (GET, POST, PUT, DELETE).

While the four you mentioned are the most frequently used for building RESTful APIs, the HTTP/1.1 standard defines a number of others.

Here are some of the other HTTP methods and their purposes:

  • HEAD: This method is similar to a GET request, but the server only sends back the headers and not the actual message body. This is useful for checking if a resource exists or verifying its size or modification date without downloading the entire content.

  • OPTIONS: This method is used to describe the communication options for the target resource. A client can use it to find out what other methods (like GET, POST, etc.) are supported by a specific URL. It’s often used by browsers for preflight requests in Cross-Origin Resource Sharing (CORS).

  • PATCH: This method is used to apply partial modifications to a resource. Unlike PUT, which typically replaces the entire resource with new data, PATCH only sends the changes. This can be more efficient, especially for large resources where only a small part needs to be updated.

  • CONNECT: This method is used to establish a tunnel to the server identified by the target resource. It’s often used by clients to communicate with a proxy server that can then forward the request to the final destination.

  • TRACE: This method is used for diagnostics. It performs a message loop-back test, where the server reflects the received request back to the client. This is helpful for debugging and seeing how requests are being modified by intermediate proxies.

These methods are essential because they define the type of operation you want to perform on the resource specified by the endpoint’s path.

You need an API (Application Programming Interface) in a web app to allow the front-end (what the user sees in their browser) to communicate with the backend (the server where the business logic and database live). πŸ–₯️

An endpoint is a specific URL where a server or API can be accessed by a client.

It’s essentially the address for a web service’s functionality!

Front-End (FE) Engineer’s Perspective

From a front-end perspective, an endpoint is the target of an API call. It’s the URL the application uses to send and receive data from the back-end.

The front-end engineer doesn’t typically worry about how the endpoint is implemented, but rather how to interact with it.

For example, an FE engineer building a social media app might interact with these endpoints:

  • GET /api/users/profile/123: To retrieve user data for a profile page.
  • POST /api/posts: To create a new post.
  • DELETE /api/posts/456: To delete a specific post.

The front-end engineer’s focus is on correctly forming the request (e.g., including the right headers, body, or query parameters) and then handling the response from the endpoint, whether it’s successful data or an error.

Back-End (BE) Engineer’s Perspective

For a back-end engineer, an endpoint is the entry point into the server-side code that performs a specific action.

The BE engineer is responsible for designing, building, and maintaining the logic that runs when an endpoint is hit.

For example, a BE engineer would create the code that handles a request to POST /api/posts. This code would:

  1. Receive the request from the client.
  2. Validate the data sent in the request (e.g., check if the post content is not empty).
  3. Process the data (e.g., save the new post to a database).
  4. Send back a response to the client (e.g., a success message with the new post’s ID).

The back-end engineer’s focus is on the robustness and security of the endpoint, ensuring it performs its function correctly and efficiently while protecting against vulnerabilities.

Py Frameworks for APIs

FastAPI, Flask, and Django are all popular Python frameworks used to create API endpoints.

You’ll often see them used for building web services and applications.

FrameworkPhilosophyBest for…ProsCons
FlaskMicro-framework 🀏Small, simple APIs and web apps, rapid prototyping, and learning.Lightweight, highly flexible, easy to learn and get started with, and a vast ecosystem of extensions.Requires manual setup for many features (e.g., database, validation, etc.), and it’s synchronous by default which can be a bottleneck for I/O-bound tasks.
FastAPIModern API-focused πŸš€High-performance APIs, microservices, and applications that require modern features like asynchronous operations and automatic documentation.Extremely fast, built-in data validation and serialization (thanks to Pydantic), automatic interactive API documentation (OpenAPI/Swagger), and native support for asynchronous programming.Newer framework with a smaller community than Flask or Django, and the asynchronous programming model can have a steeper learning curve for beginners.
Django“Batteries-included” πŸ”‹Large, complex web applications, especially those that need a full-featured backend with a database, admin panel, and user authentication out-of-the-box.Comes with everything you need: a powerful ORM (Object-Relational Mapper), a built-in admin interface, and robust security features.It’s a large, opinionated framework with a steeper learning curve for small projects. It can be overkill if all you need is a simple API.
  • Choose Flask if you want maximum control and flexibility. It’s perfect for when you have a very specific vision and don’t want the framework to dictate how you build things. It’s a great choice for beginners due to its simplicity.
  • Choose FastAPI if performance and developer experience are your top priorities. Its automatic data validation and documentation save a lot of time and reduce bugs, making it ideal for building robust, high-performance APIs.
  • Choose Django if you’re building a large-scale, full-stack application and want a mature, well-supported framework that handles most of the boilerplate code for you. It’s the go-to for many established, data-driven web projects.

The heart of what makes FastAPI so fast and modern.

The key is that not all API stuff is synchronous; in fact, a lot of it is perfect for asynchronous processing.

Why Asynchronous APIs?

The traditional synchronous model for a web server is like a single-lane road. The server handles one request at a time.

When it hits a slow operation, like waiting for a database query to complete or fetching data from another API (an I/O-bound task), it sits there and waits.

No other requests can be processed.

An asynchronous model, on the other hand, is like a highway with many lanes.

When the server hits a waiting period (an I/O-bound task), it doesn’t wait.

It parks that request and starts working on another one. When the slow operation for the first request is finished, the server comes back to it and completes the task.

This is much more efficient, especially for APIs that have many concurrent users and perform many of these I/O-bound operations.

How FastAPI Achieves Asynchronicity

FastAPI uses Python’s built-in asyncio library to enable this.

ℹ️
It’s built on top of ASGI (Asynchronous Server Gateway Interface), which is a modern standard for Python web servers.

Here’s how it works:

  1. async def: You define your endpoint functions using async def. This tells FastAPI that the function is an asynchronous coroutine.
  2. await: Inside your async function, you use the await keyword for any operation that needs to wait, such as calling a database or a third-party API. The await keyword tells the server, “I’m going to wait here, so go handle other requests in the meantime.”
  3. Automatic Handling: FastAPI handles all the low-level details for you. It runs your asynchronous code in an event loop, allowing it to manage thousands of concurrent connections with minimal overhead. It can also run traditional, synchronous code in a separate thread pool so that you don’t have to rewrite everything.

This approach makes FastAPI incredibly efficient and perfect for high-performance applications that need to handle a lot of concurrent requests without getting bogged down by slow I/O operations.

Why an API is Necessary

A web app is typically split into two parts:

  1. front-end: The client-side code (HTML, CSS, JavaScript) that runs in the user’s browser. It’s responsible for the user interface, handling user input, and displaying data.

  2. Backend: The server-side code that runs on a remote server. It’s responsible for managing the database, performing complex calculations, handling security, and other crucial tasks.

The front-end cannot directly access the backend’s database or run its code.

The API acts as a middleman, a set of rules and protocols that defines how the front-end can request data from and send data to the backend.

Without an API, the front-end would be static and unable to interact with any dynamic data or services.

For example, when you post a comment on a social media site, the front-end uses an API to send your comment to the backend, which then saves it to a database.

REST Endpoints and Other Types

Yes, a common type of API call is to a REST endpoint.

REST (Representational State Transfer) is a widely used architectural style for building APIs.

A REST endpoint is a specific URL that the front-end can call to perform an action.

These endpoints are designed to be intuitive and stateless. For example, a REST API for a blog might have the following endpoints:

  • GET /posts: Retrieves a list of all blog posts.
  • POST /posts: Creates a new blog post.
  • GET /posts/123: Retrieves the post with the ID 123.
  • PUT /posts/123: Updates the post with the ID 123.
  • DELETE /posts/123: Deletes the post with the ID 123.

Other EndPoints

This is not the only type of API, though.

Other common types include:

  • SOAP (Simple Object Access Protocol): An older, more rigid protocol that relies on XML and is often used in enterprise environments. It’s more complex than REST and generally requires more bandwidth.

  • GraphQL: A newer query language for your API. With GraphQL, the client can request exactly the data it needs from a single endpoint, avoiding over-fetching or under-fetching data. This is in contrast to REST, where you often have to make multiple calls or get more data than you need from a single endpoint.

If you ever heard about Ghost…

Ghost is an open-source publishing platform that provides a robust REST API for its core functionality.

However, it also offers a GraphQL layer specifically for working with front-end frameworks like Gatsby (surprise, another SSG!)

This allows developers to build static sites or dynamic front-ends using Ghost as a “headless CMS” and get exactly the data they need with GraphQL queries.

⚠️
Dont confuse endpoints with message brokers!

Kafka and RabbitMQ are message brokers or message queue systems.

Their purpose is to act as a middleman for communication between different parts of an application, often called microservices.

Instead of a direct request-response cycle, they use a publish-subscribe (or producer-consumer) model.

  • A producer sends a message to the broker.
  • The broker stores the message.
  • A consumer subscribes to a specific topic or queue and receives the message.

The key difference is that this is asynchronous communication:

  • The producer doesn’t wait for a response from the consumer - It sends the message and moves on.
  • This is great for tasks that don’t need an immediate response, like processing background jobs or handling a stream of real-time events.
ℹ️
A REST API, by contrast, is a synchronous request-response model where the client waits for the server to reply.

With a synchronous method like a REST API built with FastAPI, a click on the front-end initiates a request-response cycle.

Here’s how it works:

  1. front-end Action: The user clicks a button or performs an action in the browser. This triggers a JavaScript function.

  2. Request Sent: The JavaScript function sends an HTTP request (e.g., GET, POST) to a specific API endpoint on your FastAPI backend. The front-end is now “waiting” for a response.

  3. Backend Processing: FastAPI receives the request, processes it (e.g., retrieves data from a database, performs a calculation), and prepares a response.

  4. Response Sent: FastAPI sends the response back to the front-end.

  5. front-end Receives & Renders: The JavaScript code on the front-end receives the response, extracts the data (usually in JSON format), and uses that data to update the UI. The user sees the result of their click.

This entire process is synchronous from the front-end’s perspective in the sense that the code flow for that particular request waits for the response before proceeding to update the UI.

The user’s browser, however, is not blocked.

Most modern JavaScript environments handle these network requests asynchronously so the user can continue to interact with other parts of the page.


Conclusions

Definitely, FastAPI is something that I will consider and try to combine with Astro and/or Pocketbase.

You might see that in some webapps, TS does the job of FastAPI.

Proper Py and uv

Make your Python have the version you want to: in my case, I wanted 3.12.11

sudo apt update
sudo apt install -y build-essential wget \
  libssl-dev zlib1g-dev libbz2-dev libreadline-dev libsqlite3-dev \
  libncursesw5-dev xz-utils tk-dev libxml2-dev libxmlsec1-dev \
  libffi-dev liblzma-dev

wget https://www.python.org/ftp/python/3.12.11/Python-3.12.11.tgz
tar -xzf Python-3.12.11.tgz
cd Python-3.12.11
./configure --enable-optimizations
make -j"$(nproc)"
sudo make altinstall   # installs as /usr/local/bin/python3.12
python3.12 --version
python3.12 -m pip install --upgrade pip setuptools wheel

If you are using uv, do:

#uv lock --python 3.12.11

If you had another one, change the default python to the new installed:

# verify current PATH order (expect /usr/local/bin before /usr/bin)
echo "$PATH"
which -a python3

# create symlink (adjust source if you installed under /opt)
sudo ln -s /usr/local/bin/python3.12 /usr/local/bin/python3

# verify it takes precedence
which -a python3
python3 --version   # should show 3.12.11

FAQ

APIs

Whenever you will be playing around with APIs, you will hear about PostMan.

Postman (the API platform) has a free tier, which is open source in the sense that it’s freely available for anyone to download and use for their API development and testing needs.

However, Postman as a whole is not entirely open source under a standard open-source license like Apache, MIT, or GPL.

Why would you need Postman?

Postman is an incredibly popular and powerful tool for API development, testing, and documentation.

More about Why Postman? πŸ‘‡
  • Postman Free Tier: This is the most commonly used version and offers a wide range of features for individuals and small teams. It’s free to download and use.
  • Postman Core Functionality: The core functionality for sending requests, inspecting responses, creating collections, and basic testing is available in the free tier.
  • Postman Cloud and Collaboration Features: Postman also offers paid plans that unlock more advanced collaboration features, larger team sizes, advanced monitoring, and more. These paid features are proprietary.
  • Newman (Command-Line Collection Runner): Newman, Postman’s command-line Collection Runner, is open source and available under the Apache 2.0 license. This allows you to run and test your Postman Collections from the command line and integrate them into CI/CD pipelines.

1. API Testing:

  • Ease of Use: Provides a user-friendly graphical interface to send HTTP requests (GET, POST, PUT, DELETE, etc.) without needing to write code.
  • Request Building: Easily construct requests with headers, request bodies (JSON, XML, form-data, etc.), and parameters.
  • Response Inspection: View and analyze API responses, including status codes, headers, and the response body (formatted for readability).
  • Assertions and Testing: Write tests and assertions to automatically verify the correctness of API responses.
  • Environment Management: Create and manage different environments (e.g., development, staging, production) with their own sets of variables.

2. API Development:

  • Prototyping: Quickly prototype and explore APIs you are building.
  • Debugging: Helps in debugging API issues by allowing you to inspect requests and responses.
  • Collaboration: Share collections and environments with team members for collaborative API development.

3. API Documentation:

  • Collection Documentation: Postman allows you to document your APIs directly within collections, making it easier for others (or your future self) to understand how to use them.
  • Publishing Documentation: You can publish interactive API documentation from your Postman Collections.

4. API Exploration:

  • Learning New APIs: Easily explore and understand third-party APIs without needing to write code.

5. Workflow Automation:

  • Collection Runner: Automate the execution of API tests within collections.
  • Newman Integration: Integrate API tests into your development and deployment pipelines.

Postman’s free tier provides a robust set of tools for interacting with APIs and is widely used by developers for testing, development, and exploration.

OSS API Tools

There are several totally and fully open-source alternatives to Postman.

These tools offer similar functionality for API testing and development but are released under open-source licenses, giving you more freedom and control.

Here are some popular and actively maintained fully open-source alternatives to Postman:

  1. Insomnia (Kong/insomnia on GitHub): This is a very popular and feature-rich open-source API client that supports REST, GraphQL, WebSockets, Server-Sent Events (SSE), and gRPC.

It offers a clean and intuitive interface, collections, environments, code generation, and a plugin ecosystem.

It has a free tier with unlimited private projects and collaboration for one project, but the core is open source.

  1. Hoppscotch (hoppscotch/hoppscotch on GitHub): Formerly known as Postwoman, Hoppscotch is a fast, lightweight, and beautifully designed open-source API development ecosystem.
ℹ️
You can test FastAPI (RESTapi) with: Postman, Hoppscoth…

Hoppscotch is indeed similar to Postman in its core functionality. Both are tools designed to help developers work with APIs (Application Programming Interfaces).

Think of them as specialized tools for sending and receiving messages to different software services.

What Hoppscotch Does:

  • API Testing: It allows you to send various types of HTTP requests (GET, POST, PUT, DELETE, etc.) to APIs. You can specify headers, parameters, and request bodies (data).
  • Response Inspection: You can view the responses from the API, including status codes, headers, and the response body (often in JSON or XML format). This helps you understand how the API works and debug any issues.
  • Collaboration: Hoppscotch, like Postman, often offers features to collaborate with other developers, sharing API collections, environments, and tests.
  • Documentation: It can be used to generate or interact with API documentation.

How Hoppscotch is Similar to Postman:

  • Core Functionality: Both tools serve the same primary purpose: simplifying API development and testing.
  • User Interface: Both provide a user-friendly interface to construct and send requests, inspect responses, and manage API collections.
  • Collaboration Features: Both offer ways to share your work with team members.

How Hoppscotch is Different from Postman:

  • Open Source: Hoppscotch is an open-source project, while Postman has a free version but also offers paid plans for advanced features. This means Hoppscotch is free to use and modify.
  • Focus on Simplicity: Hoppscotch often emphasizes a cleaner, more streamlined interface, aiming to be easier to learn and use, particularly for those new to API testing. Postman, while powerful, can have a steeper learning curve due to its extensive feature set.
  • Real-time Collaboration: Hoppscotch has a greater focus on real-time collaboration features, making it easier for teams to work together on API development simultaneously.
  • Web-Based vs. Desktop App: Hoppscotch is primarily a web-based application, accessible directly in your browser. Postman, while also having a web version, started as a desktop application.

In essence:

Hoppscotch is a strong contender and alternative to Postman, especially if you prioritize open-source software, a simpler interface, and real-time collaboration.

Postman remains a very powerful and feature-rich tool, but Hoppscotch provides a compelling option for many developers.

It’s available as a web application and a desktop app, supporting REST, GraphQL, WebSockets, and Server-Sent Events.

It emphasizes ease of use and real-time collaboration through workspaces (though the collaboration features might have some non-fully-open-source aspects in their cloud offering).

MIT | Open source API development ecosystem - https://hoppscotch.io (open-source alternative to Postman, Insomnia)

wget https://github.com/hoppscotch/releases/releases/latest/download/Hoppscotch_linux_x64.deb
sudo apt install ./Hoppscotch_linux_x64.deb #https://hoppscotch.com/download
  1. Bruno (usebruno/bruno on GitHub): Bruno is a relatively new but promising open-source API client that aims to be a direct alternative to Postman. It focuses on a local-first approach, storing your collections directly in a file system (using a simple markup language called Bru) and emphasizing privacy. It supports REST and GraphQL and has a clean, developer-centric interface. It also plans to integrate with Git for collaboration.

  2. HTTPie (httpie/httpie on GitHub): This is a command-line HTTP client that is known for its user-friendly syntax. While it’s a CLI tool and doesn’t have a GUI like Postman, it’s excellent for quick API testing and automation within scripts. It’s fully open source and widely used. There’s also a desktop app in development.

  3. Restfox (flawiddsouza/Restfox on GitHub): Restfox is a lightweight and fast open-source REST API client available as a desktop application for Windows, macOS, and Linux. It offers a clean interface, collections, history, and basic authentication.

  4. Firecamp (firecamp-dev/firecamp on GitHub): Firecamp is an open-source API development platform with a focus on a developer-centric UI. It supports various protocols like REST, GraphQL, and WebSockets and aims to streamline the API development workflow.

  5. Yaade (apidoc7/yaade on GitHub): Yaade is an open-source, self-hosted, collaborative API development environment. It aims to provide a complete platform for designing, developing, and testing APIs.

  6. Reqable - Reqable implements the core features of traffic analysis and API testing, and deeply integrates them.

One app is worth multiple apps: Advanced API Debugging Proxy and REST Client

Reqable = Fiddler + Charles + Postman

flatpak install flathub com.reqable.Reqable

FastAPI vs TS

Just in case you wonder about the difference between FastAPI endpoints and api.ts endpoints.

While they both deal with creating APIs, they are fundamentally different because they operate in different programming languages and contexts.

  • FastAPI is a Python web framework for building APIs.

  • You might be involved in some project with api.ts files.

    • It’s a file name (api.ts) commonly used in projects that use TypeScript to define API endpoints, often within a larger framework or system.

🐍 FastAPI Endpoints

FastAPI is a complete web framework in Python.

When you create an endpoint, you’re building the server-side logic that handles HTTP requests.

The framework handles many tasks for you automatically, like:

  • Routing: Mapping a URL path (e.g., /items/{item_id}) to a specific Python function.
  • Data Validation: Using Python’s type hints and the Pydantic library, FastAPI automatically validates incoming request data (from URL paths, query parameters, or the request body). If the data doesn’t match the expected type, it returns a clear error.
  • Automatic Documentation: FastAPI automatically generates interactive API documentation (using Swagger UI and ReDoc) based on your code. This is one of its biggest selling points.
  • Asynchronous Support: Built on modern Python standards, it supports asynchronous code (async/await) out of the box, making it highly performant for I/O-bound tasks.

FastAPI endpoints are the producers of the API. They are the backend functions that receive requests and send back responses.

πŸ“ api.ts Endpoints

The file name api.ts indicates a TS file.

In this context, it typically serves one of two purposes:

  1. Defining API routes in a TS-based backend framework: Frameworks like Next.js or Directus use api.ts files to define API routes. In this case, it’s doing a similar job to a FastAPI endpointβ€”it’s the server-side code that handles requests.

The key difference is the language and the ecosystem it’s part of.

These frameworks leverage TS’s static typing to provide type safety for your API logic.

  1. Defining the API client on the frontend: In many frontend projects, api.ts is a file that defines the structure and functions for making API calls to a separate backend.

This file acts as a consumer of the API, containing functions like getUsers() or createPost(), often with type definitions to ensure the data received from the backend is correctly typed.

This is a common practice for maintaining type safety across the entire application stack.

This distinction is crucial: FastAPI is a backend framework, while a file named api.ts could be a backend implementation, but is often a frontend client.

Summary of Similarities and Differences

FeatureFastAPI Endpointsapi.ts Endpoints
Primary RoleBackend (API Producer)Can be Backend or Frontend (API Consumer)
Core TechnologyPython web frameworkTS file/module
LanguagePythonTS
PurposeTo handle incoming HTTP requests and generate responsesTo define API routes (backend) or make API calls (frontend)
Key AdvantageHigh performance, automatic validation, and automatic API documentation.Type safety across the codebase, catching errors before runtime.

No, an api.ts file doesn’t have to be part of a Server-Side Rendering (SSR) application.

It’s a common file name used to define an API layer, and its location and function depend entirely on the project’s architecture.

In a Client-Side Rendered (CSR) App

In a traditional single-page application (SPA) built with React or Vue, the api.ts file is part of the client-side code.

It defines functions that make network requests from the user’s browser directly to the backend API.

The data is fetched and the UI is rendered after the page has loaded on the client.

In a Server-Side Rendered (SSR) App

In an SSR framework like Next.js or Nuxt.js, an api.ts file can exist in a few different places:

  1. Frontend API Client: Just like in a CSR app, it can be a file that makes requests to the backend. In SSR, these requests might happen on the server (during the initial page load) and also on the client (for subsequent data fetching).

  2. API Routes: Frameworks like Next.js have a feature called “API Routes.” In this case, an api.ts file would be located in a specific directory (e.g., pages/api or app/api) and would act as the backend itself. It defines a serverless function that handles HTTP requests.

This part is running on the server, not the client, and serves a similar purpose to a FastAPI endpoint.

So, while api.ts can be used in an SSR context, it’s not exclusive to it, and its function depends on whether it’s part of the client-side code or a server-side API route.

Yes, a CSR (Client-Side Rendered) application can absolutely make calls using an api.ts file.

That’s its primary function.

What a CSR App Can Do

In a CSR application (like a standard React or Vue app), the api.ts file is a module that you import into your components.

When a component needs to fetch data, it calls a function from api.ts, which then uses fetch or axios to make an HTTP request from the user’s browser to your backend.

  • Example: When a user clicks a “Load Posts” button, a getPosts() function in your api.ts file is executed in the browser. The browser then sends a request to your backend (/api/posts), gets the data, and the component updates the UI with the new posts.

What an SSR App Can Do That a CSR App Can’t

The key difference lies in when and where the data is fetched and the HTML is rendered.

An SSR (Server-Side Rendered) application fetches data and renders the initial HTML for a page on the server, before sending it to the browser.

A CSR app can’t do this; it sends an empty HTML file and relies on the browser to fetch the data and build the UI.

Here’s what an SSR app can do that a CSR app can’t:

  1. Improved SEO (Search Engine Optimization) πŸ“ˆ: Search engine crawlers can easily read the fully-formed HTML that an SSR app sends. This is a significant advantage over CSR, where crawlers often struggle to find and index dynamic content that loads after the initial page is rendered.

  2. Faster Initial Page Load πŸš€: The user sees the content of the page much faster. With SSR, the user’s browser receives a complete HTML page that’s ready to be displayed. With CSR, the user sees a blank page or a loading spinner while the JavaScript downloads, executes, and then fetches the data.

  3. Better Performance on Slower Devices πŸ“±: Since the heavy lifting of rendering is done on the server, the client’s device doesn’t have to use its own processing power to build the initial page. This makes the application feel much faster and more responsive on low-powered phones and computers.

  4. Security for Sensitive Data πŸ”’: With SSR, you can make API calls from the server without exposing sensitive information like API keys or credentials to the client’s browser. This is because the request happens entirely on the server.