Devlien is a minimal and flexible Node.js backend framework designed to work seamlessly with:
- β Nuxt.js
- β Next.js
- β NestJS
- β Or run independently as a standalone server
It gives you a Laravel-like development experience while staying simple and unopinionated.
npm create devlien@latest devlienAppThis guide will walk you through installing and using Devlien in a Nuxt.js, Nextjs project.
In your Nuxtjs or Nextjs project root, install Devlien:
npm install devlienInitialize the server environment using:
npx devlien setupThis will automatically create the following structure inside your project:
server
βββ app
β βββ Http
| | βββControllers
| | βββMiddleware
| | βββResources
β βββ Models
β βββ Providers
βββ config
β βββ app
β βββ database
βββ database
β βββ migrations
β βββ seeds
βββ routes
β βββ web
β βββ api
βββ resources
β βββ views
βββ .env
Edit the generated .env file and set your database configuration:
APP_NAME="Devlien"
DB_CONNECTION="mysql"
DB_HOST="localhost"
DB_PORT="3306"
DB_USERNAME=root
DB_PASSWORD=secret
DB_NAME=devlienβ You must have a running MySQL/MariaDB database before proceeding.
Devlien includes several command-line tools to help you build faster:
npx devlien make:controller HomeControllerThis will generate:
server/app/Controllers/HomeController.js
npx devlien make:model UserThis will generate:
server/app/Models/User.js
npx devlien make:migration usersThis will generate:
server/database/migrations/2025_06_23_XXXXXX_users.js
Edit the file to define your table structure.
npx devlien migrate
npx devlien migrate:rollback --allThis will execute all pending migrations and create tables in your database.
npx devlien make:resourceYouβll be prompted to enter the resource name (e.g., Product) and Devlien will generate resource for you.
In your migraion: /database/migrations/...users.js
import Migration from "devlien/migration";
export default class extends Migration {
up(schema){
schema.create('users', (table)=>{
table.increments('id');
table.string('name');
table.string('email').unique();
table.string('password');
table.set('status', ['active', 'inactive']).default('active');
});
}
down(schema){
schema.drop('users');
}
}In your routes/api.js:
import route from "devlien/route";
import Auth from "../app/Http/Middleware/Auth.js";
export default route.serve(route => {
route.group({'prefix':'api', 'middleware':[Auth]}, (route)=>{
route.get('index', 'UserController@index');
route.put('create', 'UserController@create');
route.put('update/:id', 'UserController@update');
})
});In you controller
import view from "devlien/view";
export default class DevlienController extends Controller {
constructor() {
super();
// Any setup or initialization can go here.
}
async wellcome(request) {
return await view('wellcome', {title:'Wellcome to Devlien'});
}
}In you template (root/resources/views/wellcome.dl)
<template>
<h1>{{ title }}</h1>
<p>{{ version }}</p>
</template>
@script
const version = "1.0.3";
@endscriptIn your controller:
import User from "../../Models/User.js";
// Fetch users
let users = await User.get();
// or
let user = new User();
let users = await user.get();await User.limit(10).get();
await User.skip(5).limit(10).get();await User.where({id:1}).where([{id:1}, {id:1}]).where(['id', '=', 1]).get();
await User.where({id:1}).first();await User.create({
"name" : "Shamim Haque",
"username" : "shmimhaque",
"email" : "shamim.haque.dev@gmail.com"
});await User.where({id:1}).update({
"name" : "Shamim Haque",
"email" : "shamim.haque.dev@gmail.com"
});More query methods coming soon...
- Authentication scaffolding
- RESTful API boilerplate
- Collection map
- Queue process
Shamim Haque
GitHub: @shamimhaque-mpi
π§ Email: shamim.haque.dev@gmail.com
This project is open-source and available under the MIT License.