From 5ed1cb6b51548cdf2b4fc3838b8e58456369eea7 Mon Sep 17 00:00:00 2001 From: paku Date: Wed, 14 Feb 2024 01:09:42 +0900 Subject: [PATCH] Update README --- LICENSE | 2 +- README.md | 76 +++++++++++++++++++++++++++++++++++++++++++++++++++++-- 2 files changed, 75 insertions(+), 3 deletions(-) diff --git a/LICENSE b/LICENSE index ee82b0a..454f5aa 100644 --- a/LICENSE +++ b/LICENSE @@ -1,6 +1,6 @@ MIT License -Copyright (c) 2024 paku +Copyright (c) 2024 skyizwhite Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal diff --git a/README.md b/README.md index 4dfd607..2a5e11b 100644 --- a/README.md +++ b/README.md @@ -1,2 +1,74 @@ -# ningle-fbr -Plugin for ningle to enable file-based routing +# ningle-fbr (WIP) +Plugin for [ningle](https://github.com/fukamachi/ningle) and [jingle](https://github.com/dnaeon/cl-jingle) to enable file-based routing + +# Usage + +To use ningle-fbr, you must use [package-inferred-system](https://asdf.common-lisp.dev/asdf/The-package_002dinferred_002dsystem-extension.html). + +`/example.asd` +```lisp +(defsystem "example" + :class :package-inferred-system + :pathname "src" + :depends-on ("example/app") +``` + +`/src/app.lisp` +```lisp +(uiop:define-package #:example + (:nicknames #:example/app) + (:use #:cl) + (:import-from #:ningle) + (:import-from #:ningle-fbr)) +(in-package #:example/app) + +(defparameter *app* (make-instance 'ningle:)) + +(defun update-routes () + (ningle-fbr:enable-file-based-routing + *app* + :dir "src/routes" + :system "example" + :system-pathname "src")) + +(update-routes) +``` + +## Static routing + +`/src/routes/index.lisp` → `/` +```lisp +(uiop:define-package #:example/routes/index + (:use #:cl) + (:export #:on-get + #:on-post + #:on-put + #:on-delete)) +(in-package #:example/routes/index) + +(defun on-get (params) + ...) + +(defun on-post (params) + ...) + +(defun on-put (params) + ...) + +(defun on-delete (params) + ...) +``` + +## Dynamic routing + +A file or directory name prefixed with '=' indicates a dynamic path. + +In the example below, the name parameter can be obtained from handler's params. + +`/src/routes/user/=name.lisp` → `/user/:name` + +# License + +Licensed under MIT License.  + +Copyright (c) 2024, skyizwhite.