use actix_cors::Cors; use actix_identity::{CookieIdentityPolicy, IdentityService}; use actix_web::middleware; use actix_web::{web, App, HttpServer}; use diesel::r2d2::{ConnectionManager, Pool}; use diesel::MysqlConnection; use furby::handlers::smoke::manual_hello; use furby::handlers::{cart_items, product, users}; use rand::Rng; #[actix_web::main] async fn main() -> std::io::Result<()> { pretty_env_logger::init(); let db_url = env!("DATABASE_URL"); let manager = ConnectionManager::::new(db_url); let pool = Pool::builder() .build(manager) .expect("Failed to create pool."); let private_key = rand::thread_rng().gen::<[u8; 32]>(); HttpServer::new(move || { App::new() .wrap(IdentityService::new( CookieIdentityPolicy::new(&private_key) .name("user-login") .secure(false), )) .wrap(Cors::new().supports_credentials().finish()) .wrap(middleware::Logger::default()) .data(pool.clone()) .service( web::scope("/user") .route("/existing", web::post().to(users::name_exists)) .route("/login", web::post().to(users::login)) .route("/{uname}", web::get().to(users::user_details)) .route("/new", web::post().to(users::new_user)) .route( "/change_password", web::post().to(users::change_password), ), ) .service( web::scope("/product") .route("/catalog", web::get().to(product::get_all_products)) .route("/new", web::post().to(product::new_product)) .route("/{id}", web::get().to(product::product_details)) .route( "/update_product/{id}", web::post().to(product::update_product), ), ) .service( web::scope("/cart") .route( "/items", web::get().to(cart_items::get_user_cart_items), ) .route("/add", web::post().to(cart_items::add_to_cart)) .route( "/remove", web::post().to(cart_items::remove_from_cart), ), ) .route("/hey", web::get().to(manual_hello)) }) .bind("127.0.0.1:7878")? .run() .await }