Getting Started with Gazelle

This guide will walk you through the process of getting started with Gazelle and building your first HTTP server.

Installation

To install Gazelle in your Dart project, add it as a dependency in your pubspec.yaml file:

dependencies:
  gazelle_core: <latest-version>

Then, run pub get to fetch and install the package.

Creating Your First Server

Once Gazelle is installed, you can create a simple HTTP server with just a few lines of code. Here's an example:

import 'package:gazelle_core/gazelle_core.dart';

void main() async {
  final app = GazelleApp(
    routes: [
      GazelleRoute(
        name: "hello_gazelle",
        get: (context, request, response) => GazelleResponse(
          statusCode: GazelleHttpStatusCode.success.ok_200,
          body: "Hello, Gazelle!",
        ),
      ),
    ],
  );

  await app.start();
  print("Gazelle listening at ${app.serverAddress}");
}

In this example, we create a new instance of a GazelleApp, define a route for the path /hello_gazelle, and specify a request handler that returns a simple Hello, Gazelle! response. Finally, we start the server using the start() method.

Handling Requests

Gazelle provides a powerful routing system that allows you to handle different HTTP methods and paths with ease. You can define routes using methods like get, post, put, delete, etc., and specify request handlers to process incoming requests.

final myGetRoute = GazelleRoute(
  name: "hello",
  get: (context, request, response) => GazelleResponse(
    statusCode: GazelleHttpStatusCode.success.ok_200,
    body: "Hello, World!",
  ),
);

In this example, we define a route for the path /hello using the get method and specify a request handler that returns a Hello, World! response.

Adding Hooks and Plugins

Gazelle allows you to enhance your application's functionality using hooks and plugins. Hooks enable you to execute functions before and after request handlers, while plugins provide a way to extend Gazelle with custom features.

final app = GazelleApp(
  routes: [
    GazelleRoute(
      name: "login",
      post: (context, request, response) async {
        // Use the request to get data sent from the client.
        return GazelleResponse(
          statusCode: GazelleHttpStatusCode.success.ok_200,
          // Sign a token and send it back to the client.
          body: context.getPlugin<GazelleJwtPlugin>().sign({"test": "123"}),
        );
      },
    ),
    GazelleRoute(
      name: "hello_world",
      get: (context, request, response) async {
        return GazelleResponse(
          statusCode: GazelleHttpStatusCode.success.ok_200,
          body: "Hello, World!",
        );
      },
      // Add the authentication hook provided by the plugin to guard your routes.
      preRequestHooks: (context) => [
        context.getPlugin<GazelleJwtPlugin>().authenticationHook,
      ],
    ),
  ],
  plugins: [GazelleJwtPlugin(SecretKey("supersecret"))],
);

In this example, we register a JWT authentication plugin and apply an authentication hook to a protected route.

Next Steps

Congratulations! You've created your first Gazelle server. Now, explore the documentation further to learn about Gazelle's advanced features, including middleware, error handling, and more.