prkserver

Crates.ioprkserver
lib.rsprkserver
version0.1.9
sourcesrc
created_at2024-06-07 04:34:59.277993
updated_at2024-06-18 09:34:04.241888
description`prkserver` is a CLI tool that helps create a backend server in Rust using Axum and SQLx. It configures everything based on a provided `config.toml` file.
homepage
repositoryhttps://github.com/prk-Jr/prkserver.git
max_upload_size
id1264387
size41,534
(prk-Jr)

documentation

README

prkserver

prkserver is a CLI tool that helps create a backend server in Rust using Axum and SQLx. It configures everything based on a provided config.toml file.

Features

  • Generates a Rust backend project using Axum for HTTP handling.
  • Configures SQLx for database interactions.
  • Supports PostgreSQL and MySQL databases.
  • Creates models, middlewares and endpoints as specified in the config.toml file.

Installation

To install prkserver, use cargo:

cargo install prkserver

Usage

To use prkserver, create a config.toml file that defines the project configuration. Here is an example config.toml file:

project_name = "backend_project"
database_url = "mysql://user:password@localhost/database_name"
database_type = "mysql"

[[models]]
name = "User"
table_name = "users"
fields = [
    { name = "id", type = "i32" },
    { name = "username", type = "String" },
    { name = "email", type = "String" },
    { name = "user_token", type = "String" },
]
endpoints = [
    { method = "GET", path = "/users" },
    { method = "POST", path = "/users", body_params = [
        { name = "username", type = "String" },
        { name = "email", type = "String" },
    ] },
]


[[models]]
name = "Todo"
table_name = "todos"
fields = [
    { name = "id", type = "i32" },
    { name = "task", type = "String" },
    { name = "description", type = "Option<String>" },
]
endpoints = [
    { method = "GET", path = "/todos", middlewares = [
        "UserLoginHistoryMiddleware",
    ],  },
    { method = "POST", path = "/todos", middlewares = [
        "UserLoginHistoryMiddleware",
    ], body_params = [
        { name = "task", type = "String" },
        { name = "description", type = "Option<String>" },
    ]  },
    { method = "GET", path = "/todos/:id", path_params = [
        { name = "id", type = "i32" },
    ] },
]

[[models]]
name = "UserLoginHistory"
table_name = "user_login_history"
fields = [
    { name = "id", type = "i32" },
    { name = "task", type = "String" },
    { name = "description", type = "Option<String>" },
]

[[middlewares]]
model = "UserLoginHistory"
select_from_model = "UserLoginHistory"
validate_header = [{ model_field = "token", header_key = "token" }]

Once you have your config.toml file, run prkserver at the path of this config file:

prkserver

This will generate a new project in a directory named after project_name specified in the config.toml.

Note: Still work in Progress.

Commit count: 26

cargo fmt