Skip to content

Latest commit

 

History

History
111 lines (81 loc) · 5.46 KB

readme.md

File metadata and controls

111 lines (81 loc) · 5.46 KB

Hello actix-web

⚠️🚧🛠️ Under Construction 🛠️🚧⚠️

If you find mistakes, typos, horrible practices being used, please consider opening up an issue and telling me all about it!

What is this?

A bunch of To-do web apps written with an increasing amount of features using the actix-web framework, and its friends in actix-extras.

This uses the actix-web: 4 release!

Things to keep in mind

The intention here is not to show how to implement a robust, production web service, these examples are exploratory projects. We'll be taking a tour in Actixland by implementing a very simple task management service, and increasing the amount of features as we get more familiar with what actix can offer. Starting with a basic actix app with a single route, and moving towards an app that supports protected routes.

I've tried to keep dependencies to a minimum, focusing on the basics of the framework and its ecosystem. Another focal point was in keeping things "simple", this means that in places were things could get complicated even a tiny little bit more (security), and take the focus away from the exploration of actix (SECURITY), I chose to not go there (SECURITY).

But there is a project literally named Authorization, how does it work then?

Well, have you heard the tales of websites that store your username and password in plaintext? This is the level of security you should expect here. Don't get me wrong, I'll show you how to use the authorization middleware to forbid and allow users from accessing certain routes, but we won't be going much further than that into security practices here.

Projects in ascending order of features

  1. minimal: A minimal "Hello, world" of sorts for actix-web;

  2. in-memory: Using web::Data to hold an in-memory database of sorts (if you call having a Mutex<Vec<T>> as "using a database");

  3. sqlite: Gets rid of Mutex<Vec<T>> "database" in favor of a proper sqlite database pool, courtesy of sqlx;

  4. cookies: We start playing with cookies (DO NOT EAT) and the actix_session crate;

  5. login: Identify who is eating all the cookies by tracking authentication with actix-identity;

  6. authorization: These are MY cookies! Allow and forbid access to routes with actix-web-httpauth;

  7. integration: We go a bit deeper in testing an actix-web app, bring a lantern and snacks;

  8. tls: It's HTTPS time;

How do I run this?

  • You must have Rust installed! These examples were compiled on version 1.57.0.

Each project is completely self-contained, so if you want to run cookies, for example, you can either run the project from its directory with a simple cargo run, or directly from the workspace folder with cargo run -p cookies.

If you want to compile all the projects in one go, just do a cargo build or cargo check in the workspace folder.

How do I test this?

The tests were designed to be run in single-threaded mode only!

You may run the following commands from the root (workspace) folder:

# Runs every test from each project
cargo test -- --test-threads=1

# Runs every test from [project]
cargo test -p sqlite -- --test-threads=1

List of dependencies used