At Codrops, we’re all about open supply! In the present day, we’re excited to welcome Bruno Pérez, who’s right here to introduce us to Manifest—a easy, one-file answer for dealing with backend duties. Have an open supply challenge you’d prefer to share with our neighborhood? Tell us!
When delivering a static frontend to a shopper, nothing is extra irritating than listening to, “Good job! However can I edit this half…and that half too?” as they level to completely different sections of the positioning. Now, you’re caught explaining backend limitations, which frequently leaves the shopper feeling upset.
EEven although there’s an enormous technical distinction between frontend and backend growth, non-technical shoppers usually don’t notice it. This isn’t a one-off scenario both; a examine we carried out confirmed that almost all frontend builders often get requested to deal with backend duties.
The doughnut chart beneath reveals responses to the query, “What number of backend requests do you obtain per 12 months?”

With out stable backend experience, some builders will try backend duties even when it’s not their robust go well with, usually resulting in wasted time. Others might decline the work altogether, lacking out on potential enterprise and leaving shoppers unhappy.
Constructing and managing a backend is difficult, particularly if it’s not your space of focus. Even for easy wants, you’re confronted with choosing a runtime, a database, a framework, and constructing an API from scratch.
Just lately, Backend-as-a-Service (BaaS) options have emerged, providing ready-to-use options to hurry up growth. Nonetheless, these providers can nonetheless be robust to make use of successfully and not using a grasp of key backend ideas.
That’s why we created Manifest: a single-file backend designed with simplicity and inclusivity in thoughts. Our aim is to make it simple for any developer to shortly arrange and handle a backend.

The way it works
Manifest is an open-source challenge constructed round a single YAML file. By merely describing your information on this file, you immediately get a whole backend with:
- A non-technical admin panel which you could give to your shoppers
- A totally purposeful REST API with its dwell OpenAPI documentation
- An abstracted database to retailer all of your information
- Key backend options out-of-the-box: Auth, Validation, File storage, Picture resizing and extra
Manifest can be utilized in lots of purposes:
- Making an app or web site dynamic
- Create a minimal CMS or ERP
- Storing kind information
- Limit content material to logged-in customers
- and lots of extra
This code beneath is an instance of a todo app implementation:
identify: My TODO App ✅
entities:
  Todo:
    seedCount: 10
    properties:
      - title
      - { identify: accomplished, kind: boolean }To attain this simplicity, we needed to discover probably the most human-friendly language: YAML. It’s a minimal-syntax information serialization language (not a programming language) that regained quite a lot of consideration lately because it turned primarily used within the DevOps / CI-CD world. Let’s say that you don’t actually must study YAML, it simply seams logical for everybody who did a little bit of coding.
On high of that we created Manifest’s Area Particular Language (DSL) that surcharges YAML with the potential of creating entities and properties simply.
The admin panel view for the todo app:

Make your frontend dynamic with Manifest
Manifest is fairly simple to put in, you simply must have NodeJS v18+.
Run it straight out of your shopper app root of in a brand new folder:
npx add-manifestThis may set up the dependencies in addition to creating a brand new manifest folder with a backend.yml file. That is the center of your backend.
identify: My pet app 🐾
 entities:
  Proprietor 😃:
    properties:
      - identify
      - { identify: e mail, kind: e mail }
  Cat 😺:
    properties:
      - identify
      - { identify: age, kind: quantity }
      - { identify: birthdate, kind: date }
    belongsTo:
      - ProprietorNow you can go to:
From right here, you possibly can go to your manifest/backend.yml and tweak from right here. The next code generates a Twitter clone:
identify: Twitter clone
entities:
  Tweet 🐦:
    properties:
      - { identify: content material, kind: textual content }
      - { identify: createdAt, kind: timestamp }
    belongsTo:
      - Consumer
  Consumer 👤:
    properties:
      - identify
      - { identify: avatar, kind: picture }
Fairly neat, proper? The code above specifies the two entities (Tweet and Consumer), their properties and their relationship (many-to-one). After saving, let’s generate a bunch of dummy information with the seed command:
npm run manifest:seedIf we need to resize uploaded avatars into a number of sizes, change the Consumer entity code by this one:
Consumer 👤:
  properties:
    - identify
    - {
        identify: avatar,
        kind: picture,
        choices:
          {
            sizes: { small: { top: 90, width: 90 }, massive: { width: 200 } }
          }
      } There are numerous different backend options out-of-the-box like enable customers to login or limit entry.
Then out of your frontend, you should use the REST API to do HTTP requests like this:
// Fetch tweets
GET http://localhost:1111/api/dynamic/tweets
// Get them organized by final created first
GET http://localhost:1111/api/dynamic/tweets?orderBy=createdAt&order=DESC
  
// Be part of Customers
GET http://localhost:1111/api/dynamic/tweets?relations=consumer
  
// Filter Tweets by proprietor
GET http://localhost:1111/api/dynamic/tweets?relations=proprietor&proprietor.id_eq=1Or obtain the JavaScript SDK to your frontend to make use of as a extra pure language:
// Fetch tweets
const tweets = await manifest.from('tweets')
                             .discover()
// Get them organized by final created first
const orderedTweets = await manifest.from('tweets')
                                    .orderBy('createdAt', {desc: true})
                                    .discover()
// Be part of Customers
const tweetsWithUsers = await manifest.from('tweets')
                                      .with(['user'])
                                      .discover()
// Filter Tweets by proprietor
const filteredTweets = await manifest.from('tweets')
                                     .with(['user'])
                                     .the place('consumer.id = 1')
                                     .discover()
How the Manifest Challenge Began
Manifest was born from an inner challenge at Buddyweb, our digital company based mostly in Paris. We began utilizing a skeleton so as to acquire time making backends and admin panels.
Nonetheless after we first open-sourced this software (named CASE at the moment), we obtained combined suggestions from builders because the technical stack was too particular and solely suited our inner processes.
That is after we understood that inside the overwhelming variety of stacks and libraries accessible, folks have to actually select properly which of them they need to make investments time to study. And Manifest was born, a method to get began with backend growth with nothing to study.
After a small Proof-of-Idea that caught some consideration in Hacker Information, we’re at present incubated at HEC incubator at Station F, the world largest startup campus. We need to proceed our journey constructing the best backend on the earth, guided by our love for Open Supply software program.
Manifest is now in BETA and accessible on Github. We’re beginning to get many constructive power from completely different communities, if you wish to be a part of it or simply to observe the challenge, give us a ⭐ on Github. We anticipate folks to construct good issues with Manifest within the close to future.
Cheers ! 🦚💗



