Rusty Chat
Welcome to Rusty Chat, a full-stack web application built using the Leptos web framework, Axum backend, and Tokio for asynchronous operations. The app integrates a local AI language model using Ollama to offer intelligent chat responses. This project is designed for developers interested in building performant, real-time chat applications with a modern Rust stack.
Features
- Real-time Chat: π¬ Leverage Http Stream to enable seamless real-time chat functionality.
- AI-Powered Chat: π€ Integrate Ollama to run local AI models for enhanced chat responses.
- Full-Stack Development: π Leptos is used for both the frontend and backend, with Axum as the backend server.
- Async Framework: β‘ Tokio is used for handling asynchronous tasks efficiently.
- TailwindCSS: π¨ Beautiful, responsive UI powered by TailwindCSS.
- WebAssembly: πΉοΈ Support for WebAssembly (WASM) for better performance in the browser.
Demo
π₯ Demo Video
You can watch the demo of Rusty Chat here:
Project Setup
Prerequisites
To get started with Rusty Chat, you'll need the following tools installed:
- Rust (Nightly version): Install Rust through rustup.
- Node.js & npm: Required for managing frontend dependencies and building assets.
- cargo-leptos: Install this tool to manage Leptos-specific tasks.
Install cargo-leptos with the following command:
cargo install cargo-leptos --locked
Clone the Repository
Clone the project to your local machine:
git clone https://github.com/Abhishek2010DevSingh/RustyChat
cd RustyChat
Install Dependencies
Install the required dependencies using Cargo:
cargo build
For frontend assets, you can install the necessary npm packages by running:
npm install
Development Environment
Start the development server with the following command:
cargo leptos watch
This will compile the Rust backend and the frontend assets, then serve the application locally.
By default, the app will be hosted at 127.0.0.1:3000
.
Running the Application with TailwindCSS
Rusty Chat uses TailwindCSS for styling. Make sure the tailwind-input-file
is set to "style/main.css"
in your Cargo.toml
file. You can customize the styles according to your needs.
To start the build process for the frontend assets, run the following:
npm run build
Running the Application with AI Support
If you want to use the AI chat functionality with Ollama, make sure you have Ollama installed and set up locally.
cargo leptos watch --features "ssr"
This enables server-side rendering (SSR) along with Ollama's local AI model integration.
Testing the Application
Rusty Chat includes end-to-end testing with Playwright. You can run tests using the following command:
cargo leptos end-to-end
To run the tests in release mode:
cargo leptos end-to-end --release
Building for Production
For a production build, use the following command:
cargo leptos build --release
This will compile both the backend and the frontend assets and prepare them for deployment.
Deploying
After building for release, you can deploy the compiled server and the static site to your production server.
Copy the following files from the target
directory to your server:
-
Server binary: Located at
target/server/release
-
Site package: Located at
target/site
Set up the environment variables for your project:
LEPTOS_OUTPUT_NAME="rusty-chat"
LEPTOS_SITE_ROOT="site"
LEPTOS_SITE_PKG_DIR="pkg"
LEPTOS_SITE_ADDR="127.0.0.1:3000"
LEPTOS_RELOAD_PORT="3001"
Finally, run the server binary:
./target/server/release/rusty-chat
Development with WebAssembly (WASM)
If you plan to run the app with WebAssembly, make sure the wasm32-unknown-unknown
target is added:
rustup target add wasm32-unknown-unknown
You can then build the app for WebAssembly by running:
cargo leptos build --target wasm32-unknown-unknown
Iconography
The app's design uses modern icons and clean UI elements that align with current web design trends. Custom icons are integrated into the app for a unique look and feel. Here's a small preview:
- Chat bubble: π¬
- AI-powered: π€
- Real-time: β‘
- TailwindCSS: π¨
Support
If you encounter any issues or need help, feel free to open an issue on the GitHub repository.
Conclusion
Rusty Chat is a full-stack, real-time web chat app built with cutting-edge technologies in Rust. With features like local AI integration, real-time messaging, and full-stack development using Leptos and Axum, it provides a modern and efficient platform for building chat applications.
We hope this template helps you get started with your next full-stack web project!
Happy coding! π
Top comments (0)