Skip to content

api-flex: A powerful library that simplifies API calls with automatic retries and smart caching. Ideal for seamless integration and robust error handling in your applications.

License

Notifications You must be signed in to change notification settings

jasgigli/api-flex

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

13 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

πŸ› οΈ api-flex β€” A Flexible and Powerful API Handling Library

npm npm License

api-flex combines the simplicity of fetch and the power of axios, bringing modern solutions to API request handling. With built-in retries, token management, error handling, and caching, it removes the complexities of working with HTTP requests.


πŸš€ Key Features

  • 🌐 Unified API: Combines fetch's flexibility with axios's power.
  • πŸ” Automatic Retries: Set up configurable retries for failed requests.
  • πŸ” Token Management: Easily manage authorization tokens for secure API calls.
  • ⚠️ Centralized Error Handling: Streamlined error management and logging.
  • 🧠 Response Caching: Optional in-memory caching to optimize repeated requests.
  • ⚑ Lightweight: Efficiently built for modern applications with a small footprint.

πŸ“¦ Installation

Install api-flex via npm:

npm install api-flex

🎯 Why Use api-flex?

api-flex simplifies complex API integrations by providing an intuitive and feature-rich library. You don't have to set up retries, caching, or token handling manuallyβ€”everything is configured out-of-the-box.


πŸ’» Basic Usage Examples

πŸ’» GET Requests

🟒 Basic GET Request

import apiFlex from "api-flex";

const data = await apiFlex("https://jsonplaceholder.typicode.com/posts/1");
console.log(data);

πŸ” Using try-catch with a Function

import apiFlex from "api-flex";

const fetchUser = async () => {
  try {
    const data = await apiFlex("https://jsonplaceholder.typicode.com/posts/1");
    console.log(data);
  } catch (error) {
    console.error("Error fetching user:", error);
  }
};

fetchUser();

🟒 Using Promises

import apiFlex from "api-flex";

apiFlex("https://jsonplaceholder.typicode.com/posts/1")
  .then((data) => console.log(data))
  .catch((error) => console.error("Error fetching user:", error));

πŸ”’ GET Request with Custom Headers

import apiFlex from "api-flex";

const headers = { Authorization: "Bearer my-token" };
const data = await apiFlex("https://jsonplaceholder.typicode.com/posts/1", {
  headers,
});
console.log(data);

πŸ” GET Request with Optional Parameters

import apiFlex from "api-flex";

const fetchData = async (url) => {
  return await apiFlex(url);
};

const data = await fetchData("https://jsonplaceholder.typicode.com/posts/1");
console.log(data);

🟒 Fetching Data from a Dynamic URL

import apiFlex from "api-flex";

const userId = 1;
const url = `https://jsonplaceholder.typicode.com/posts/${userId}`;
const data = await apiFlex(url);
console.log(data);

🟒 Logging the Result Immediately

import apiFlex from "api-flex";

(async () =>
  console.log(await apiFlex("https://jsonplaceholder.typicode.com/posts/1")))();

πŸ“š More Modern Usage Examples

GET Request

import apiFlex from "api-flex";

const fetchPost = async () => {
  try {
    const data = await apiFlex("https://jsonplaceholder.typicode.com/posts/1");
    console.log(data);
  } catch (error) {
    console.error("Error fetching post:", error);
  }
};

fetchPost();

POST Request

import apiFlex from "api-flex";

const createPost = async () => {
  const postData = {
    title: "New Post",
    body: "This is a new post.",
    userId: 1,
  };

  try {
    const data = await apiFlex("https://jsonplaceholder.typicode.com/posts", {
      method: "POST",
      body: JSON.stringify(postData),
      headers: { "Content-Type": "application/json" },
    });
    console.log("Created Post:", data);
  } catch (error) {
    console.error("Error creating post:", error);
  }
};

createPost();

PUT Request

import apiFlex from "api-flex";

const updatePost = async () => {
  const updatedData = {
    id: 1,
    title: "Updated Title",
    body: "Updated body content",
    userId: 1,
  };

  try {
    const data = await apiFlex("https://jsonplaceholder.typicode.com/posts/1", {
      method: "PUT",
      body: JSON.stringify(updatedData),
      headers: { "Content-Type": "application/json" },
    });
    console.log("Updated Post:", data);
  } catch (error) {
    console.error("Error updating post:", error);
  }
};

updatePost();

DELETE Request

import apiFlex from "api-flex";

const deletePost = async () => {
  try {
    await apiFlex("https://jsonplaceholder.typicode.com/posts/1", {
      method: "DELETE",
    });
    console.log("Post deleted successfully.");
  } catch (error) {
    console.error("Error deleting post:", error);
  }
};

deletePost();

πŸ“¦ Integration with Different Frameworks and LibrariesπŸ“¦

Node.js Node.js( Express Express)

You can easily integrate api-flex in a Node.js/Express application for server-side API calls.

Example:

import express from "express";
import apiFlex from "api-flex";

const app = express();

app.get("/post", async (req, res) => {
  try {
    const post = await apiFlex("https://jsonplaceholder.typicode.com/posts/1");
    res.json(post);
  } catch (error) {
    console.error("Error fetching post:", error.message);
    res.status(500).send("Failed to fetch post.");
  }
});

app.listen(3000, () => {
  console.log("Server running on http://localhost:3000");
});

React / Next.js React

πŸ› οΈ Simple api-flex Usage in React

Loging the result in the Console

import React from "react";
import { useEffect } from "react";
import apiFlex from "api-flex";

const App = () => {
  useEffect(() => {
    apiFlex("https://jsonplaceholder.typicode.com/posts/1")
      .then((data) => {
        console.log(data);
      })
      .catch((err) => setError(err.message));
  }, []);

  return (
    <div>
      <h1>Welcome to ApiFlex Library</h1>
    </div>
  );
};

export default App;

Fetching Single Data

import React, { useEffect, useState } from "react";
import apiFlex from "api-flex";

const FetchSingleData = () => {
  const [post, setPost] = useState(null);

  useEffect(() => {
    apiFlex("https://jsonplaceholder.typicode.com/posts/1")
      .then((data) => setPost(data))
      .catch((err) => console.error("Error:", err.message));
  }, []);

  return (
    <div>
      <h1>Single Data</h1>
      {post && (
        <>
          <h2>{post.title}</h2>
          <p>{post.body}</p>
        </>
      )}
    </div>
  );
};

export default FetchSingleData;

Batching Multiple API Requests

import React, { useEffect, useState } from "react";
import apiFlex from "api-flex";

const FetchBatchData = () => {
  const [posts, setPosts] = useState([]);

  useEffect(() => {
    const urls = [
      "https://jsonplaceholder.typicode.com/posts/1",
      "https://jsonplaceholder.typicode.com/posts/2",
      "https://jsonplaceholder.typicode.com/posts/3",
    ];

    apiFlex
      .batch(urls)
      .then((responses) => setPosts(responses.map((res) => res.data)))
      .catch((err) => console.error("Error:", err.message));
  }, []);

  return (
    <div>
      <h1>Batch Data</h1>
      {posts.map((post, index) => (
        <div key={index}>
          <h2>{post.title}</h2>
          <p>{post.body}</p>
        </div>
      ))}
    </div>
  );
};

export default FetchBatchData;

πŸ”‘ Key Points:

  • Concise: These examples use minimal code to achieve the desired functionality.
  • Batch Requests: apiFlex.batch() simplifies fetching multiple URLs.
  • Error Handling: Easily handle and display errors in your React app.

⚑️Circuit Breaker Feature in api-flex πŸ”’

The Circuit Breaker feature in the api-flex library enhances API request resilience by preventing repeated attempts to call a failing service. It helps improve application stability and user experience by managing requests more intelligently.

Overview

A Circuit Breaker monitors the state of your requests and can prevent requests from being sent to a service that is already failing. When the failure threshold is reached, the Circuit Breaker trips, and subsequent requests are automatically failed without reaching the service, allowing it to recover before trying again.

Configuration Options

You can configure the Circuit Breaker with the following options:

  • failureThreshold: The number of failures before the circuit trips (default: 5).
  • resetTimeout: The duration in milliseconds for which the circuit remains open before trying again (default: 30000).

Example Usage

Here’s how to implement the Circuit Breaker feature in your React component using api-flex:

import React, { useEffect, useState } from "react";
import apiFlex from "api-flex";

const FetchSingleData = () => {
  const [postData, setPostData] = useState(null);
  const [error, setError] = useState(null);

  useEffect(() => {
    const fetchData = async () => {
      try {
        const data = await apiFlex(
          "https://jsonplaceholder.typicode.com/posts/1",
          {
            retries: 3, // Number of retries on failure
            retryDelay: 1000, // Delay between retries in milliseconds
            failureThreshold: 5, // Circuit trips after 5 failures
            resetTimeout: 30000, // Circuit remains open for 30 seconds before resetting
          }
        );

        setPostData(data);
        console.log(data);
      } catch (err) {
        setError(err.message);
        console.error("Request failed:", err.message);
      }
    };

    fetchData();
  }, []);

  if (error) return <div>Error: {error}</div>;

  return (
    <div>
      <h1>Single API Request with api-flex</h1>
      <pre>{JSON.stringify(postData, null, 2)}</pre>
    </div>
  );
};

export default FetchSingleData;

How It Works

  1. Failure Handling: The Circuit Breaker tracks the number of consecutive failures. Once the specified failureThreshold is reached, it trips the circuit.
  2. Automatic Retries: During the resetTimeout, any requests sent to the failing service will automatically fail, allowing time for recovery without overwhelming the service.
  3. Graceful Error Reporting: Users can see the error state without excessive logging or failed requests.

Benefits

  • Improved Stability: Reduces the risk of overwhelming a failing service.
  • Enhanced User Experience: Users experience fewer request failures and receive timely feedback.
  • Configurable: Adjust settings based on your application's needs.

πŸ“Š Comparison: fetch, axios, and api-flex

Feature fetch axios api-flex
Built-in retries ❌ ❌ βœ…
Token management ❌ (manual) ❌ (manual) βœ… (automatic)
Centralized errors ❌ ❌ βœ…
Response caching ❌ ❌ βœ…
Timeout handling ❌ βœ… βœ…
Batch requests ❌ ❌ βœ…
Request/Response Interceptors ❌ βœ… βœ…
Exponential backoff ❌ ❌ βœ…
Customizable defaults ❌ βœ… βœ…
Environment detection ❌ ❌ βœ…
Automatic rate-limiting handling ❌ ❌ βœ…
Lightweight βœ… ❌ βœ…
Wide browser support βœ… βœ… βœ…

Key Advantages of api-flex Over Other Libraries:

  • Batch Requests: Unlike fetch or axios, api-flex supports batching multiple API requests into a single operation, reducing network overhead.
  • Automatic Token Management: api-flex handles token refreshing and management automatically, streamlining the process of authenticated requests.
  • Built-in Retry Mechanism: With built-in retry logic and support for exponential backoff, api-flex offers more robust error handling compared to the manual approaches in fetch and axios.
  • Rate Limiting Handling: The rate-limiting feature in api-flex helps prevent API overuse, something fetch and axios don’t handle out-of-the-box.

πŸš€ Features of Api-Flex

Key Features

- ⚑️Circuit Breaker Feature in api-flex πŸ”’

The Circuit Breaker feature in the api-flex library enhances API request resilience by preventing repeated attempts to call a failing service. It helps improve application stability and user experience by managing requests more intelligently.

- Flexible API Requests

  • Easily make HTTP requests using a simple interface that supports both GET and POST methods.

Example:

import apiFlex from "api-flex";

const fetchPosts = async () => {
  const posts = await apiFlex("https://jsonplaceholder.typicode.com/posts");
  console.log("Posts:", posts);
};

fetchPosts();

- Automatic Retries

  • Configurable retry logic to automatically attempt to re-fetch data in case of network failures or errors. Supports customizable retry counts and delays.

- Timeout Handling

  • Customizable request timeout settings to prevent hanging requests and improve user experience.

Example:

import apiFlex from "api-flex";

const fetchPostWithTimeout = async () => {
  try {
    const data = await apiFlex("https://jsonplaceholder.typicode.com/posts/1", {
      timeout: 2000, // Timeout in 2 seconds
    });
    console.log("Fetched Post with Timeout:", data);
  } catch (error) {
    console.error("Error fetching post due to timeout:", error.message);
  }
};

fetchPostWithTimeout();

- Interceptor Support

  • Ability to add request and response interceptors, allowing developers to modify requests before sending or responses before returning.

Example:

import apiFlex from "api-flex";

const addRequestInterceptor = (config) => {
  // Modify request config
  console.log("Request Interceptor:", config);
  return config;
};

const addResponseInterceptor = (response) => {
  // Modify response data
  console.log("Response Interceptor:", response);
  return response;
};

apiFlex.addRequestInterceptor(addRequestInterceptor);
apiFlex.addResponseInterceptor(addResponseInterceptor);

- Environment Detection

  • Compatible with both Node.js and browser environments, making it versatile for various applications.

Example:

import apiFlex from "api-flex";

const fetchData = async () => {
  const data = await apiFlex("https://jsonplaceholder.typicode.com/posts/1");
  console.log("Fetched Data (Node/Browser Compatible):", data);
};

fetchData();

- Configurable Defaults

  • Easy-to-set default configurations (headers, timeouts, etc.) to streamline API calls.

Example:

import apiFlex from "api-flex";

const apiClient = new apiFlex({
  headers: {
    Authorization: "Bearer your-token",
  },
  timeout: 5000, // Default timeout
});

const fetchDefaultPost = async () => {
  const data = await apiClient("https://jsonplaceholder.typicode.com/posts/1");
  console.log("Fetched Post with Default Configs:", data);
};

fetchDefaultPost();

- Lightweight and Fast

  • Designed to be lightweight and efficient, ensuring minimal performance impact on applications.

πŸ“ˆ Conclusion

api-flex combines the best of modern API handling libraries, making it your go-to tool for powerful and streamlined API requests. Forget the headaches of retries, caching, token handling, and error managementβ€”api-flex does it all for you!


Here’s a more modern and visually appealing version of the License and Contributing section, enhancing clarity and engagement:


πŸ“œ License

This project is licensed under the MIT License. For detailed information, please refer to the LICENSE file.

🀝 Contributing

We welcome contributions from the community! Here’s how you can help:

  • Report Issues: If you encounter any bugs or have suggestions, please open an issue.
  • Submit Pull Requests: Contributions to the codebase are encouraged. Please follow the standard GitHub workflow for submitting your changes.

Contact Us: If you have questions or want to collaborate, feel free to reach out via email: overview.jjj@gmail.com.

🌐 Official Web App

Explore Api-Flex in action at our official web app: apiflex.vercel.app.

About

api-flex: A powerful library that simplifies API calls with automatic retries and smart caching. Ideal for seamless integration and robust error handling in your applications.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published