Flapi (derived from "Fill API" term) is a free-to-use service tailored for frontend developers. It generates mock data effortlessly based on your custom schemas, speeding up your workflow and simplifying development.
Fully Customizable Data: Define your schema, and Flapi fills it in no time.
Dynamic Multi-Response: Flapi can generate different responses for the same schema in one call (amount parameter).
Frontend-Centric Design: Build and test interfaces without backend dependencies.
Completely Free: Designed with developers in mind to make their lives easier.
Let Flapi fill your API needs for mock data and take your development to the next level!
import requests
response = requests.get(
"https://flapi.sprucbot.tech/v1/gen?amount=2",
json={
"name" : "name()",
"email" : "email(domain=hg.co)",
"age" : "age(min=78$max=200)",
"address" : "address()",
"created_at" : "date()",
"phone" : "phone(code=87)",
"ids" : "list-int(amount=3$max=2)",
"employee" : {
"_$amount" : 1,
"name" : "name()",
"position" : "text(len=5)",
"clients" : {
"_$amount" : 2,
"deal" : "int(len=5)",
"name" : "name()",
"email" : "email(domain=hg.co)"
}
}
}
)
if response.status_code == 200:
data = response.json()
print(data)
else:
print(f"Error: {response.status_code}")
Example Response
{
"name": "Jennifer Huynh",
"email": "[email protected]",
"age": 125,
"address": "959 Holden Corner Apt. 103\nEast Matthew, IN 93214",
"created_at": "18-12-2003",
"phone": "+87-9487346280",
"ids": [1,2,1],
"employee": [
{
"_$amount": 1,
"name": "Jason Hartman",
"position": "PM.",
"clients": [
{
"_$amount": 2,
"deal": 55503,
"name": "Nicole Parker",
"email": "[email protected]"
},
{
"_$amount": 2,
"deal": 35965,
"name": "Mark Thomas",
"email": "[email protected]"
}
]
}
]
}
Base URL: https://flapi.sprucbot.tech/v1/gen
Generates mock data based on the provided schema. The schema is passed as a JSON object in the request body. The response will be a JSON object with the generated data. The amount parameter can be used to generate multiple responses with the same schema.
- amount - The number of responses to generate. Default: 1.
- schema - The schema for the data to generate. instead of schema query parameter, you can pass the schema in the request body.
Types and parameters are used to define the schema for the data you want to generate. Here are the available types and parameters:
-
int() - Generates a random integer within the specified range.
-
float() - Generates a random float within the specified range.
-
bool() - Generates a random boolean value.
-
name() - Generates a random name.
-
email() - Generates a random email address with the specified domain.
-
password() - Generates a random password with the specified length.
-
age() - Generates a random age within the specified range.
-
address() - Generates a random address.
-
date() - Generates a random date.
-
phone() - Generates a random phone number with the specified country code.
-
text() - Generates random text with the specified length.
-
subject() - Generates a random subject.
-
description() - Generates a random description.
-
list-int() - Generates a list of random integers with the specified amount and range.
-
list-str() - Generates a list of random strings with the specified amount and length.
-
object{} - Generates an object with the specified keys and types.
- min - The minimum value of the integer. Default: 0.
- max - The maximum value of the integer. Default: 100.
example :
{
"int" : "int(min=5$max=10)"
}
- min - The minimum value of the float. Default: 0.0
- max - The maximum value of the float. Default: 100.0
example :
{
"float" : "float(min=5$max=10)"
}
- No parameters.
example :
{
"bool" : "bool()"
}
- No parameters.
example :
{
"name" : "name()"
}
- domain - The domain of the email address. Default: gmail.com.
example :
{
"email" : "email(domain=hg.co)"
}
- len - The length of the password. Default: 8.
example :
{
"pass" : "password(len=8)"
}
- min - The minimum age. Default: 18.
- max - The maximum age. Default: 100.
example :
{
"age" : "age(min=78$max=200)"
}
- No parameters.
example :
{
"address" : "address()"
}
- between - The date range. Default:
2000-2024
- format - The date format. Default:
%d/%m/%Y
- era - can be
now
so it will generate the current date. example :
{
"dob" : "date(between=2000-2006)"
}
- code - The country code of the phone number. Default: 91.
example :
{
"phone" : "phone(code=87)"
}
- len - The length of the text. Default: 10.
example :
{
"text" : "text(len=5)"
}
- category - The category of the subject. Default:
any
-
- Categories :
-
computer_science
orcs
-
science
: Science related subjects
-
commerce
: Commerce related subjects
-
arts
: Arts related subjects
-
engineering
: Engineering related subjects
-
medical
: Medical related subjects
-
law
: Law related subjects
-
any
: any random subject
example :
{
"subject" : "subject(category=commerce)"
}
- words - The number of words in the description. Default: 3.
example :
{
"description" : "description(words=5)"
}
- width - The width of the image. Default: 200.
- height - The height of the image. Default: 200.
example :
{
"image" : "image(width=300$height=300)"
}
The list types are used to generate a list of values based on the specified schema.
- amount - The number of integers to generate. Default: 3.
- min - The minimum value of the integers. Default: 0.
- max - The maximum value of the integers. Default: 100.
example :
{
"list" : "list-int(amount=2$max=5)"
}
- amount - The number of strings to generate. Default: 3.
- len - The length of the strings. Default: 10.
example :
{
"list" : "list-str(amount=2$len=5)"
}
- amount - The number of names to generate. Default: 3.
example :
{
"list" : "list-name(amount=2)"
}
- amount - The number of email addresses to generate. Default: 3.
- domain - The domain of the email addresses. Default: gmail.com.
example :
{
"list" : "list-email(amount=2$domain=hg.co)"
}
- amount - The number of subjects to generate. Default: 3.
- category - The category of the subjects. Default: any.
example :
{
"list" : "list-subject(amount=2$category=cs)"
}
Object type defination is a bit different from others. It requires a key and a type. The key is the name of the object's property, and the type is the schema of the object property's value. The object type can also have the _$amount parameter to generate multiple objects with the same schema.
- _$amount - The number of objects to generate. Default: 1.
example :
{
"obj" : {
"_$amount" : 2,
"name" : "name()",
"email" : "email(domain=hg.co)",
"pass" : "password(len=8)"
}
}
Contributions are welcome! Please feel free to submit a pull request or open an issue if you have any suggestions or feedback.
This project is licensed under the MIT License - see the LICENSE for more details.