Skip to main content
Module

x/fastro/cli/tmpl.txt

Fast and simple web application framework for deno
Go to Latest
File
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775
# Fastro
Fast and simple web application framework for deno.
With[near-native perfomance](https://deno.land/x/fastro@v{{version}}/benchmarks),you can manage your routing, middlewares, and dependencies cleanly. You can alsotake advantage of existing Deno objects and methods:[Request](https://deno.com/deploy/docs/runtime-request),[Response](https://deno.com/deploy/docs/runtime-request),[Headers](https://deno.com/deploy/docs/runtime-headers), and[Cookie](https://deno.land/std@0.133.0/http).
### Examples
- [Getting Started](#getting-started)- [Custom Port](#custom-port)- [Set HTML](#set-html)- [Set HTML with RequestResponse](#set-html-with-requestresponse)- [Set JSON](#set-json)- [Set JSX](#set-jsx)- [Set Server Side Rendering](#set-ssr)- [Set Content Type](#set-content-type)- [Set HTTP Status](#set-http-status)- [Set Authorization](#set-authorization)- [Set, Get, and Delete a Cookie](#set-get-and-delete-a-cookie)- [Set, Get, and Delete a Cookie with RequestResponse](#set-get-and-delete-a-cookie-with-requestresponse)- [Render with Eta Template Engine](#render-with-eta-template-engine)- [Routing](#routing)- [Route Parameters](#route-parameters)- [Router Middleware](#router-middleware)- [Router Middleware with Array](#route-level-middleware-with-array)- [Application Level Middleware](#application-level-middleware)- [Application Level Middleware with Array](#application-level-middleware-with-array)- [Route Level Middleware](#route-level-middleware)- [Route Level Middleware with Array](#route-level-middleware-with-array)- [SQLite and Dependency Injection](#sqlite-and-dependency-injection)### Getting started
```tsimport application from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.get("/", () => "Hello world");
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/main.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/main.ts)
### Custom port
```tsimport application from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.get("/", () => "Hello world!");
await app.serve({ port: 3000 });```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/custom_port.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/custom_port.ts)
### Set HTML
```tsimport application from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.get("/", () => { return new Response("<html> Hello world </html>", { status: 200, headers: { "content-type": "text/html", }, });});
console.log("Listening on: http://localhost:8000");
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/html_response.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/html_response.ts)
### Set HTML with RequestResponse
```tsimport application, { response,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.get("/", () => { const res = response(); return res.html("<h2>Hello world</h2>");});
console.log("Listening on: http://localhost:8000");
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/response_html.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/response_html.ts)
### Set JSON
```tsimport application, { response,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.get("/", () => { const res = response(); return res.json({ text: "Hello world" });});
console.log("Listening on: http://localhost:8000");
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/response_json.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/response_json.ts)
### Set JSX
```tsximport application from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.get("/", () => <h1>Hello world</h1>);
console.log("Listening on: http://localhost:8000");
await app.serve();```
#### tsconfig: `deno.json`
```json{ "compilerOptions": { "strict": true, "jsx": "react-jsx", "jsxImportSource": "https://esm.sh/react" }}```
```deno run -A --unstable --config deno.json https://deno.land/x/fastro@v{{version}}/examples/jsx_response.tsx```
### Set SSR
#### React Component: `response_ssrApp.tsx`
```tsximport React from "https://esm.sh/react@17.0.2";
const App = () => { const [count, setCount] = React.useState(0); return ( <div> <h1>Hello Deno Land!</h1> <button onClick={() => setCount(count + 1)}>Click the 🦕</button> <p>You clicked the 🦕 {count} times</p> </div> );};
export default App;```
#### Endpoint: `response_ssr.tsx`
```tsimport application, { response,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";import App from "./response_ssrApp.tsx";
const app = application();const hydratePath = "./response_ssrClient.tsx";
app.get("/", () => { const res = response(); return res.ssr(<App />, hydratePath);});
console.log("Listening on: http://localhost:8000");
await app.serve();```
#### SSR Hydration `response_ssrClient.tsx`
```tsimport React from "https://esm.sh/react@17.0.2";import ReactDOM from "https://esm.sh/react-dom@17.0.2";import App from "./response_ssrApp.tsx";
ReactDOM.hydrate( <App />, //@ts-ignore: used by Deno.emit document.getElementById("root"),);```
#### tsconfig: `deno.json`
```json{ "compilerOptions": { "strict": true, "jsx": "react-jsx", "jsxImportSource": "https://esm.sh/react" }}```
#### How to run locally
```deno run -A --unstable response_ssr.tsx```
### Set Content Type
```tsimport application, { response,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.get("/", () => { const res = response(); return res.contentType("application/json") .send(JSON.stringify({ msg: "Hello world" }));});
console.log("Listening on: http://localhost:8000");
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/response_content_type.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/response_content_type.ts)
### Set HTTP Status
```tsimport application, { response,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.get("/", () => { const res = response(); return res.status(200).send("status");});
console.log("Listening on: http://localhost:8000");
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/response_status.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/response_status.ts)
### Set Authorization
```tsimport application, { response,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.get("/", () => { const res = response(); return res.authorization("Basic YWxhZGRpbjpvcGVuc2VzYW1l") .send("Basic auth");});
console.log("Listening on: http://localhost:8000");
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/response_auth.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/response_auth.ts)
### Set, Get, and Delete a Cookie
```tsimport { Cookie, deleteCookie, getCookies, setCookie,} from "https://deno.land/std@0.133.0/http/cookie.ts";
import application from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.post("/", () => { const headers = new Headers(); const cookie: Cookie = { name: "Space", value: "Cat" }; setCookie(headers, cookie); return new Response(JSON.stringify(cookie), { headers });});
app.get("/", (req: Request) => { const headers = req.headers; const cookies = getCookies(headers); return new Response(JSON.stringify(cookies));});
app.delete("/", () => { const headers = new Headers(); deleteCookie(headers, "Space"); const cookies = getCookies(headers); return new Response(JSON.stringify(cookies), { headers, });});
console.log("Listening on: http://localhost:8000");
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/cookies.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/cookies.ts)
### Set, Get, and Delete a Cookie with RequestResponse
```tsimport application, { Cookie, getCookies, response,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.get("/set", () => { const res = response(); const cookie: Cookie = { name: "Space", value: "Cat" }; return res.setCookie(cookie) .send(JSON.stringify(cookie));});
app.get("/del", () => { const res = response(); return res.deleteCookie("Space").send("Cookie deleted");});
app.get("/chk", (req: Request) => { const res = response(); const cookie = getCookies(req.headers); return res.send(JSON.stringify(cookie));});
console.log("Listening on: http://localhost:8000");
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/response_cookies.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/response_cookies.ts)
### Render with Eta Template Engine
```tsimport application from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";import { render } from "https://deno.land/x/eta@v1.12.3/mod.ts";
const app = application();
const headers = new Headers();headers.set("Content-Type", "text/html charset=UTF-8");
app.get("/", () => { const html = <string> render( "<h4>The answer to everything is <%= it.answer %></h4>", { answer: 42, }, ); return new Response(html, { headers });});
console.log("Listening on: http://localhost:8000");
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/render.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/render.ts)
### Routing
```tsimport application from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.get("/abcd", () => new Response("/abcd"));
app.get("/ef?gh", () => new Response("/ef?gh"));
app.get("/ij+kl", () => new Response("/ij+kl"));
app.get("/mn*op", () => new Response("mn*op"));
app.get("/qr(st)?u", () => new Response("qr(st)?u"));
app.get(/v/, () => new Response("/v/"));
app.get(/.*fast$/, () => new Response("/.*fast$/"));
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/routing.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/routing.ts)
### Route parameters
```tsimport application, { getParam, getParams,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.get("/:id/user/:name", (req: Request) => { const params = getParams(req); return new Response(JSON.stringify({ params }));});
app.get("/post/:id", (req: Request) => { const param = getParam("id", req); return new Response(param);});
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/route_params.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/route_params.ts)
### Router Middleware
```tsimport application, { ConnInfo, Next, router,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();const r = router();const middleware = (_req: Request, _connInfo: ConnInfo, next: Next) => { console.log("v2 - 1"); next();};
r.get("/", () => new Response("Get")) .post("/", () => new Response("Post")) .put("/", () => new Response("Put")) .delete("/", () => new Response("Delete"));app.use("/v1", r);app.use("/v2", middleware, r);
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/router_middleware.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/router_middleware.ts)
### Router Middleware with Array
```tsimport application, { ConnInfo, Next, router,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();const r = router();const middlewares = [(_req: Request, _connInfo: ConnInfo, next: Next) => { console.log("v2 - 1"); next();}, (_req: Request, _connInfo: ConnInfo, next: Next) => { console.log("v2 - 2"); next();}];
r.get("/", () => new Response("Get")) .post("/", () => new Response("Post")) .put("/", () => new Response("Put")) .delete("/", () => new Response("Delete"));app.use("/v1", r);app.use("/v2", middlewares, r);
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/router_middleware_with_array.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/router_middleware_with_array.ts)
### Application Level Middleware
```tsimport application, { ConnInfo, Next,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
app.use((_req: Request, _conn: ConnInfo, next: Next) => { console.log("app middleware #1"); next();});
app.use((_req: Request, _conn: ConnInfo, next: Next) => { console.log("app middleware #2"); next();});
app.use((_req: Request, _conn: ConnInfo, next: Next) => { console.log("app middleware #3"); next();}, (_req: Request, _conn: ConnInfo, next: Next) => { console.log("app middleware #4"); next();});
app.get("/", () => new Response("App level #1"));
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/application_level_middleware.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/application_level_middleware.ts)
### Application Level Middleware with Array
```tsimport application, { ConnInfo, Next,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
const middlewares = [(_req: Request, _conn: ConnInfo, next: Next) => { console.log("middleware #1"); next();}, (_req: Request, _conn: ConnInfo, next: Next) => { console.log("middleware #2"); next();}, (_req: Request, _conn: ConnInfo, next: Next) => { console.log("middleware #3"); next();}, (_req: Request, _conn: ConnInfo, next: Next) => { console.log("middleware #4"); next();}];
app.use(middlewares);
app.get("/", () => new Response("App level #1"));
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/application_level_middleware_with_array.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/application_level_middleware_with_array.ts)
### Route Level Middleware
```tsimport application, { ConnInfo, Next,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
const middlewares = (_req: Request, _conn: ConnInfo, next: Next) => { console.log("middleware #1"); next();};
app.get("/", middlewares, () => new Response("App level #1"));
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/route_level_middleware.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/route_level_middleware.ts)
### Route Level Middleware with Array
```tsimport application, { ConnInfo, Next,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";
const app = application();
const middlewares = [(_req: Request, _conn: ConnInfo, next: Next) => { console.log("middleware #1"); next();}, (_req: Request, _conn: ConnInfo, next: Next) => { console.log("middleware #2"); next();}, (_req: Request, _conn: ConnInfo, next: Next) => { console.log("middleware #3"); next();}, (_req: Request, _conn: ConnInfo, next: Next) => { console.log("middleware #4"); next();}];
app.get("/mnop", middlewares, () => new Response("Route level middleware #3"));
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/route_level_middleware_with_array.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/route_level_middleware_with_array.ts)
### SQLite and Dependency Injection
```tsimport application, { dependency,} from "https://deno.land/x/fastro@v{{version}}/server/mod.ts";import { DB } from "https://deno.land/x/sqlite@v3.3.0/mod.ts";
const app = application();const db = new DB("test.db");
const deps = dependency();deps.set("hello", () => "Hello world");deps.set("db", db);app.use(deps);
app.get("/", () => { type FunctionType = () => string; const fn = <FunctionType> app.getDeps("hello"); return new Response(fn());});
app.post("/name", () => { const db = <DB> app.getDeps("db"); db.query(`CREATE TABLE IF NOT EXISTS people ( id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT)`); const names = ["Peter Parker", "Clark Kent", "Bruce Wayne"]; for (const name of names) { db.query("INSERT INTO people (name) VALUES (?)", [name]); } return new Response(JSON.stringify(names));});
app.get("/name", () => { const db = <DB> app.getDeps("db"); const res = db.query("SELECT name FROM people"); return new Response(JSON.stringify(res));});
console.log("Listening on: http://localhost:8000");
await app.serve();```
```deno run -A --unstable https://deno.land/x/fastro@v{{version}}/examples/deps_injection.ts```
[![alt text](https://raw.githubusercontent.com/fastrodev/fastro/gh-pages/assets/img/deno-deploy-button.svg)](https://dash.deno.com/new?url=https://deno.land/x/fastro@v{{version}}/examples/deps_injection.ts)