Flint Dart ๐Ÿ”ฅ

Flint Dart is a minimal, expressive, and extensible server-side framework built with Dart. Inspired by the simplicity of Express.js and Laravel, Flint provides an elegant developer experience for building RESTful APIs and backend services with Dart.

Developed and maintained by Eulogia Technologies.

๐Ÿ“š Table of Contents

Topic Description
๐Ÿš€ Getting Started Set up Flint in your project
๐Ÿ›ฃ๏ธ Routing Define routes for your Flint Dart app
๐Ÿ›ก Middleware Protect and modify requests with middleware
๐Ÿ—„ ORM & Models Work with databases using Flint Dart ORM
๐Ÿ’พ Database & Migrations Manage your database schema and migrations
๐Ÿ”‘ Authentication Built-in authentication and Google Auth support
โœ… Validation Validate input like Laravel
โ™ป๏ธ Hot Reload Instant feedback while developing
๐Ÿ’พ Storage Storage Flint Dart to production
๐Ÿšข Deployment Deploy Flint Dart to production
๐Ÿ“– API Docs Best-in-class API documentation with Swagger UI

โœจ Features

  • ๐Ÿงฑ Simple and intuitive routing
  • ๐Ÿ›ก๏ธ Middleware support
  • ๐Ÿ” Built-in JWT authentication
  • ๐Ÿ”’ Secure password hashing
  • โ™ป๏ธ Hot reload support for rapid development
  • ๐Ÿงช Modular structure for scalable projects
  • ๐Ÿ’ก Clean API design inspired by Flutter's widget philosophy
  • ORM for MySQL/Postgres
  • CLI for migrations, models, etc.

๐Ÿš€ Getting Started

1. Install as a Global Package

If you want to quickly create and run apps without adding Flint as a dependency, install it globally:

dart pub global activate flint_dart
flint create new_app   # Create a new Flint project
flint run              # Run the project

2. Add as a Project Dependency

If you prefer Flint to be part of your projectโ€™s dependencies:

dart pub add flint_dart
dart run 
import 'package:flint_dart/flint_dart.dart';

void main() {
  final app = Flint();

  app.get('/', (req, res) async {
  return  res.send('Welcome to Flint Dart!');
  });

  app.listen(3000);
}

3. Run with hot reload



app.get('/hello', (req, res) async {
  return res.json({'message': 'Hello, world!'});
});

Middleware


import 'package:flint_dart/flint_dart.dart';

class AuthMiddleware extends Middleware {
  @override
  Handler handle(Handler next) {
    return (Request req, Response res) async {
      final token = req.bearerToken;
      if (token == null || token != "expected_token") {
      return  res.status(401).send("Unauthorized");
      }
   return await next(req, res);
    };
  }

  app.put('/:id', AuthMiddleware().handle(controller.update));

JWT Authentication

final token = JwtUtil.generateToken({'userId': 123});
final payload = JwtUtil.verifyToken(token);

Password Hashing

final hash = Hashing.hashPassword('mySecret');
final isValid = Hashing.verifyPassword('mySecret', hash);

๐Ÿ“ Project Structure

lib/
โ”œโ”€โ”€ main.dart
โ”œโ”€โ”€ src/
โ”‚   โ”œโ”€โ”€ app.dart
โ”‚   โ”œโ”€โ”€ router.dart
โ”‚   โ”œโ”€โ”€ request.dart
โ”‚   โ”œโ”€โ”€ response.dart
โ”‚   โ”œโ”€โ”€ middleware.dart
โ”‚   โ””โ”€โ”€ security/
โ”‚       โ”œโ”€โ”€ jwt_util.dart
โ”‚       โ””โ”€โ”€ hashing.dart

๐Ÿ“ฎ Contact & Support ๐ŸŒ Website: flintdart.eulogia.net

๐Ÿ“ง Email: eulogiatechnologies@gmail.com

๐Ÿ™ GitHub: github.com/eulogiatechnologies/flint_dart

๐Ÿ›  Contributing We welcome contributions! To get started:

git clone https://github.com/eulogiatechnologies/flint_dart.git
cd flint_dart
dart pub get

Then feel free to submit issues or pull requests.

Libraries

auth
db
flint_dart
Support for doing something awesome.
model
schema
security
storage