From d0f0d620776767412c1b137ca8182753c5669e1a Mon Sep 17 00:00:00 2001 From: Taran Nathan Date: Wed, 10 Jun 2026 23:53:31 -0400 Subject: [PATCH] rename and add password to args --- README.md | 18 +----------------- gleam.toml | 2 +- src/{preview.gleam => filestuffs.gleam} | 8 +++----- src/router.gleam | 12 +++++++----- ...review_test.gleam => filestuffs_test.gleam} | 4 ++-- 5 files changed, 14 insertions(+), 30 deletions(-) rename src/{preview.gleam => filestuffs.gleam} (76%) rename test/{preview_test.gleam => filestuffs_test.gleam} (82%) diff --git a/README.md b/README.md index 6be9ddc..7baa370 100644 --- a/README.md +++ b/README.md @@ -1,20 +1,4 @@ -# preview - -[![Package Version](https://img.shields.io/hexpm/v/preview)](https://hex.pm/packages/preview) -[![Hex Docs](https://img.shields.io/badge/hex-docs-ffaff3)](https://hexdocs.pm/preview/) - -```sh -gleam add preview@1 -``` -```gleam -import preview - -pub fn main() -> Nil { - // TODO: An example of the project in use -} -``` - -Further documentation can be found at . +# file server! ## Development diff --git a/gleam.toml b/gleam.toml index acf4aa9..fc50466 100644 --- a/gleam.toml +++ b/gleam.toml @@ -1,4 +1,4 @@ -name = "preview" +name = "filestuffs" version = "1.0.0" # Fill out these fields if you intend to generate HTML documentation or publish diff --git a/src/preview.gleam b/src/filestuffs.gleam similarity index 76% rename from src/preview.gleam rename to src/filestuffs.gleam index 947a17c..7121b60 100644 --- a/src/preview.gleam +++ b/src/filestuffs.gleam @@ -10,12 +10,10 @@ pub fn main() -> Nil { let args: List(String) = argv.load().arguments case args { ["greet", name] -> io.println("hello " <> name <> "!") - ["web", file_path] -> web(file_path) + ["web", file_path, "-p", password] -> web(file_path, password) _ -> io.println("bad args") } - // wisp.configure_logger() - Nil } @@ -23,13 +21,13 @@ pub fn wassup() -> Int { 42 } -fn web(file_path: String) -> Nil { +fn web(file_path: String, password: String) -> Nil { wisp.configure_logger() let secret_key_base = wisp.random_string(64) let assert Ok(_) = - router.handle_request(_, file_path) + router.handle_request(_, file_path, password) |> wisp_mist.handler(secret_key_base) |> mist.new |> mist.port(8000) diff --git a/src/router.gleam b/src/router.gleam index c32d12b..a30d11b 100644 --- a/src/router.gleam +++ b/src/router.gleam @@ -4,7 +4,11 @@ import gleam/result import simplifile import wisp -pub fn handle_request(req: wisp.Request, file_path: String) -> wisp.Response { +pub fn handle_request( + req: wisp.Request, + file_path: String, + password: String, +) -> wisp.Response { use req <- middleware(req) // use <- wisp.serve_static(req, "/files", file_path) @@ -15,7 +19,7 @@ pub fn handle_request(req: wisp.Request, file_path: String) -> wisp.Response { use <- wisp.serve_static(req, "/styles.css", "./static/styles.css") wisp.ok() } - "/new/" <> _path -> upload(req) + "/new/" <> _path -> upload(req, password) "/files/" <> path -> files(req, "/" <> path, file_path) _ -> wisp.not_found() } @@ -27,9 +31,7 @@ fn files(req: wisp.Request, path: String, file_path) -> wisp.Response { wisp.ok() } -const password = "greg" - -pub fn upload(req: wisp.Request) -> wisp.Response { +pub fn upload(req: wisp.Request, password: String) -> wisp.Response { use form <- wisp.require_form(req) //early return if incorrect password diff --git a/test/preview_test.gleam b/test/filestuffs_test.gleam similarity index 82% rename from test/preview_test.gleam rename to test/filestuffs_test.gleam index 456d957..8abeb09 100644 --- a/test/preview_test.gleam +++ b/test/filestuffs_test.gleam @@ -1,5 +1,5 @@ +import filestuffs import gleeunit -import preview pub fn main() -> Nil { gleeunit.main() @@ -14,5 +14,5 @@ pub fn hello_world_test() { } pub fn wassup_test() { - assert preview.wassup() == 42 + assert filestuffs.wassup() == 42 } -- 2.47.3