actix-web static files as resources support

Legal

Dual-licensed under MIT or the UNLICENSE.

Features

Usage

Create folder with static resources in your project (for example static): bash cd project_dir mkdir static echo "Hello, world" > static/hello

Add to Cargo.toml dependency to actix-web-static-files: ```toml [dependencies] actix-web-static-files = "0.1"

[build-dependencies] actix-web-static-files = "0.1" ```

Add build script to Cargo.toml: toml [package] build = "build.rs"

Add build.rs with call to bundle resources: ```rust use actixwebstaticfiles::resourcedir;

fn main() { resource_dir("./static").build().unwrap(); } ```

Include generated code in main.rs: ```rust use actixweb::{App, HttpServer}; use actixwebstaticfiles;

use std::collections::HashMap;

include!(concat!(env!("OUT_DIR"), "/generated.rs"));

fn main() { HttpServer::new(move || { let generated = generate(); App::new() .service(actixwebstatic_files::ResourceFiles::new( "/static", generated, )) }) .bind("127.0.0.1:8080").unwrap() .run().unwrap(); } ```

Run the server: bash cargo run

Request the resource: ```bash $ curl -v http://localhost:8080/static/hello * Trying 127.0.0.1:8080... * TCP_NODELAY set * Connected to localhost (127.0.0.1) port 8080 (#0)

GET /static/hello HTTP/1.1 Host: localhost:8080 User-Agent: curl/7.65.3 Accept: /