mirror of
https://github.com/metosin/reitit.git
synced 2025-12-20 09:31:11 +00:00
943 lines
29 KiB
HTML
943 lines
29 KiB
HTML
|
|
<!DOCTYPE HTML>
|
|
<html lang="" >
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta content="text/html; charset=utf-8" http-equiv="Content-Type">
|
|
<title>Dev Workflow · GitBook</title>
|
|
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
|
<meta name="description" content="">
|
|
<meta name="generator" content="GitBook 3.2.3">
|
|
|
|
|
|
|
|
|
|
<link rel="stylesheet" href="../gitbook/style.css">
|
|
|
|
|
|
|
|
|
|
<link rel="stylesheet" href="../gitbook/gitbook-plugin-highlight/website.css">
|
|
|
|
|
|
|
|
<link rel="stylesheet" href="../gitbook/gitbook-plugin-search/search.css">
|
|
|
|
|
|
|
|
<link rel="stylesheet" href="../gitbook/gitbook-plugin-fontsettings/website.css">
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<meta name="HandheldFriendly" content="true"/>
|
|
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
|
|
<meta name="apple-mobile-web-app-capable" content="yes">
|
|
<meta name="apple-mobile-web-app-status-bar-style" content="black">
|
|
<link rel="apple-touch-icon-precomposed" sizes="152x152" href="../gitbook/images/apple-touch-icon-precomposed-152.png">
|
|
<link rel="shortcut icon" href="../gitbook/images/favicon.ico" type="image/x-icon">
|
|
|
|
|
|
<link rel="next" href="../patterns/" />
|
|
|
|
|
|
<link rel="prev" href="route_validation.html" />
|
|
|
|
|
|
</head>
|
|
<body>
|
|
|
|
<div class="book">
|
|
<div class="book-summary">
|
|
|
|
|
|
<div id="book-search-input" role="search">
|
|
<input type="text" placeholder="Type to search" />
|
|
</div>
|
|
|
|
|
|
<nav role="navigation">
|
|
|
|
|
|
|
|
<ul class="summary">
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<li class="chapter " data-level="1.1" data-path="../">
|
|
|
|
<a href="../">
|
|
|
|
|
|
Introduction
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.2" data-path="../basics/">
|
|
|
|
<a href="../basics/">
|
|
|
|
|
|
Basics
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<ul class="articles">
|
|
|
|
|
|
<li class="chapter " data-level="1.2.1" data-path="../basics/route_syntax.html">
|
|
|
|
<a href="../basics/route_syntax.html">
|
|
|
|
|
|
Route Syntax
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.2.2" data-path="../basics/router.html">
|
|
|
|
<a href="../basics/router.html">
|
|
|
|
|
|
Router
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.2.3" data-path="../basics/path_based_routing.html">
|
|
|
|
<a href="../basics/path_based_routing.html">
|
|
|
|
|
|
Path-based Routing
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.2.4" data-path="../basics/name_based_routing.html">
|
|
|
|
<a href="../basics/name_based_routing.html">
|
|
|
|
|
|
Name-based Routing
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.2.5" data-path="../basics/route_data.html">
|
|
|
|
<a href="../basics/route_data.html">
|
|
|
|
|
|
Route Data
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.2.6" data-path="../basics/route_data_validation.html">
|
|
|
|
<a href="../basics/route_data_validation.html">
|
|
|
|
|
|
Route Data Validation
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.2.7" data-path="../basics/route_conflicts.html">
|
|
|
|
<a href="../basics/route_conflicts.html">
|
|
|
|
|
|
Route Conflicts
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
</ul>
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.3" data-path="../coercion/">
|
|
|
|
<a href="../coercion/">
|
|
|
|
|
|
Coercion
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<ul class="articles">
|
|
|
|
|
|
<li class="chapter " data-level="1.3.1" data-path="../coercion/coercion.html">
|
|
|
|
<a href="../coercion/coercion.html">
|
|
|
|
|
|
Coercion Explained
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.3.2" data-path="../coercion/schema_coercion.html">
|
|
|
|
<a href="../coercion/schema_coercion.html">
|
|
|
|
|
|
Plumatic Schema
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.3.3" data-path="../coercion/clojure_spec_coercion.html">
|
|
|
|
<a href="../coercion/clojure_spec_coercion.html">
|
|
|
|
|
|
Clojure.spec
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.3.4" data-path="../coercion/data_spec_coercion.html">
|
|
|
|
<a href="../coercion/data_spec_coercion.html">
|
|
|
|
|
|
Data-specs
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
</ul>
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4" data-path="../ring/">
|
|
|
|
<a href="../ring/">
|
|
|
|
|
|
Ring
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<ul class="articles">
|
|
|
|
|
|
<li class="chapter " data-level="1.4.1" data-path="../ring/ring.html">
|
|
|
|
<a href="../ring/ring.html">
|
|
|
|
|
|
Ring-router
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4.2" data-path="../ring/reverse_routing.html">
|
|
|
|
<a href="../ring/reverse_routing.html">
|
|
|
|
|
|
Reverse-routing
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4.3" data-path="../ring/default_handler.html">
|
|
|
|
<a href="../ring/default_handler.html">
|
|
|
|
|
|
Default handler
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4.4" data-path="../ring/static.html">
|
|
|
|
<a href="../ring/static.html">
|
|
|
|
|
|
Static Resources
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4.5" data-path="../ring/dynamic_extensions.html">
|
|
|
|
<a href="../ring/dynamic_extensions.html">
|
|
|
|
|
|
Dynamic Extensions
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4.6" data-path="../ring/data_driven_middleware.html">
|
|
|
|
<a href="../ring/data_driven_middleware.html">
|
|
|
|
|
|
Data-driven Middleware
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4.7" data-path="../ring/transforming_middleware_chain.html">
|
|
|
|
<a href="../ring/transforming_middleware_chain.html">
|
|
|
|
|
|
Transforming Middleware Chain
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4.8" data-path="../ring/middleware_registry.html">
|
|
|
|
<a href="../ring/middleware_registry.html">
|
|
|
|
|
|
Middleware Registry
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4.9" data-path="../ring/default_middleware.html">
|
|
|
|
<a href="../ring/default_middleware.html">
|
|
|
|
|
|
Default Middleware
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4.10" data-path="../ring/coercion.html">
|
|
|
|
<a href="../ring/coercion.html">
|
|
|
|
|
|
Pluggable Coercion
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4.11" data-path="../ring/route_data_validation.html">
|
|
|
|
<a href="../ring/route_data_validation.html">
|
|
|
|
|
|
Route Data Validation
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4.12" data-path="../ring/compiling_middleware.html">
|
|
|
|
<a href="../ring/compiling_middleware.html">
|
|
|
|
|
|
Compiling Middleware
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.4.13" data-path="../ring/swagger.html">
|
|
|
|
<a href="../ring/swagger.html">
|
|
|
|
|
|
Swagger Support
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
</ul>
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.5" data-path="./">
|
|
|
|
<a href="./">
|
|
|
|
|
|
Advanced
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<ul class="articles">
|
|
|
|
|
|
<li class="chapter " data-level="1.5.1" data-path="configuring_routers.html">
|
|
|
|
<a href="configuring_routers.html">
|
|
|
|
|
|
Configuring Routers
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.5.2" data-path="composing_routers.html">
|
|
|
|
<a href="composing_routers.html">
|
|
|
|
|
|
Composing Routers
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.5.3" data-path="different_routers.html">
|
|
|
|
<a href="different_routers.html">
|
|
|
|
|
|
Different Routers
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.5.4" data-path="route_validation.html">
|
|
|
|
<a href="route_validation.html">
|
|
|
|
|
|
Route Validation
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter active" data-level="1.5.5" data-path="dev_workflow.html">
|
|
|
|
<a href="dev_workflow.html">
|
|
|
|
|
|
Dev Workflow
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
</ul>
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.6" data-path="../patterns/">
|
|
|
|
<a href="../patterns/">
|
|
|
|
|
|
Patterns
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<ul class="articles">
|
|
|
|
|
|
<li class="chapter " data-level="1.6.1" data-path="../patterns/shared_routes.html">
|
|
|
|
<a href="../patterns/shared_routes.html">
|
|
|
|
|
|
Shared Routes
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
</ul>
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.7" data-path="../frontend/">
|
|
|
|
<a href="../frontend/">
|
|
|
|
|
|
Frontend
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<ul class="articles">
|
|
|
|
|
|
<li class="chapter " data-level="1.7.1" data-path="../frontend/basics.html">
|
|
|
|
<a href="../frontend/basics.html">
|
|
|
|
|
|
Basics
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.7.2" data-path="../frontend/browser.html">
|
|
|
|
<a href="../frontend/browser.html">
|
|
|
|
|
|
Browser integration
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.7.3" data-path="../frontend/controllers.html">
|
|
|
|
<a href="../frontend/controllers.html">
|
|
|
|
|
|
Controllers (WIP)
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
</ul>
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.8" data-path="../performance.html">
|
|
|
|
<a href="../performance.html">
|
|
|
|
|
|
Performance
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.9" data-path="../interceptors.html">
|
|
|
|
<a href="../interceptors.html">
|
|
|
|
|
|
Interceptors (WIP)
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.10" data-path="../development.html">
|
|
|
|
<a href="../development.html">
|
|
|
|
|
|
Development Instructions
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="1.11" data-path="../faq.html">
|
|
|
|
<a href="../faq.html">
|
|
|
|
|
|
FAQ
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
|
|
|
|
<li class="divider"></li>
|
|
|
|
<li>
|
|
<a href="https://www.gitbook.com" target="blank" class="gitbook-link">
|
|
Published with GitBook
|
|
</a>
|
|
</li>
|
|
</ul>
|
|
|
|
|
|
</nav>
|
|
|
|
|
|
</div>
|
|
|
|
<div class="book-body">
|
|
|
|
<div class="body-inner">
|
|
|
|
|
|
|
|
<div class="book-header" role="navigation">
|
|
|
|
|
|
<!-- Title -->
|
|
<h1>
|
|
<i class="fa fa-circle-o-notch fa-spin"></i>
|
|
<a href=".." >Dev Workflow</a>
|
|
</h1>
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<div class="page-wrapper" tabindex="-1" role="main">
|
|
<div class="page-inner">
|
|
|
|
<div id="book-search-results">
|
|
<div class="search-noresults">
|
|
|
|
<section class="normal markdown-section">
|
|
|
|
<h1 id="dev-worklfow">Dev Worklfow</h1>
|
|
<p>Many applications will require the routes to span multiple namespaces. It is quite easy to do so with reitit, but we might hit a problem during developement.</p>
|
|
<h2 id="an-example">An example</h2>
|
|
<p>Consider this sample routing :</p>
|
|
<pre><code class="lang-clj">(<span class="hljs-name"><span class="hljs-builtin-name">ns</span></span> ns1)
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">def</span></span> routes
|
|
[<span class="hljs-string">"/bar"</span> <span class="hljs-symbol">::bar</span>])
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">ns</span></span> ns2)
|
|
(<span class="hljs-name">require</span> '[ns1])
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">def</span></span> routes
|
|
[[<span class="hljs-string">"/ping"</span> <span class="hljs-symbol">::ping</span>]
|
|
[<span class="hljs-string">"/more"</span> ns1/routes]])
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">ns</span></span> ns3)
|
|
(<span class="hljs-name">require</span> '[ns1])
|
|
(<span class="hljs-name">require</span> '[ns2])
|
|
(<span class="hljs-name">require</span> '[reitit.core <span class="hljs-symbol">:as</span> r])
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">def</span></span> routes
|
|
[<span class="hljs-string">"/api"</span>
|
|
[<span class="hljs-string">"/ns2"</span> ns2/routes]
|
|
[<span class="hljs-string">"/ping"</span> <span class="hljs-symbol">::ping</span>]])
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">def</span></span> router (<span class="hljs-name">r/router</span> routes))
|
|
</code></pre>
|
|
<p>We may query the top router and get the expected result :</p>
|
|
<pre><code class="lang-clj">(<span class="hljs-name">r/match-by-path</span> router <span class="hljs-string">"/api/ns2/more/bar"</span>)
|
|
<span class="hljs-comment">;#reitit.core.Match{:template "/api/ns2/more/bar", :data {:name :ns1/bar}, :result nil, :path-params {}, :path "/api/ns2/more/bar"}</span>
|
|
</code></pre>
|
|
<p>Notice the route name : <code>:ns1/bar</code></p>
|
|
<p>When we change the routes in <code>ns1</code> like this :</p>
|
|
<pre><code class="lang-clj">(<span class="hljs-name"><span class="hljs-builtin-name">ns</span></span> ns1
|
|
(<span class="hljs-symbol">:require</span> [reitit.core <span class="hljs-symbol">:as</span> r]))
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">def</span></span> routes
|
|
[<span class="hljs-string">"/bar"</span> <span class="hljs-symbol">::bar-with-new-name</span>])
|
|
</code></pre>
|
|
<p>After we recompile the <code>ns1</code> namespace, and query again</p>
|
|
<pre><code class="lang-clj">ns1/routes
|
|
;["/bar" :ns1/bar-with-new-name]
|
|
;The routes var in ns1 was changed indeed
|
|
|
|
(r/match-by-path router "/api/ns2/more/bar")
|
|
;#reitit.core.Match{:template "/api/ns2/more/bar", :data {:name :ns1/bar}, :result nil, :path-params {}, :path "/api/ns2/more/bar"}
|
|
</code></pre>
|
|
<p>The route name is still <code>:ns1/bar</code> !</p>
|
|
<p>While we could use the <a href="http://thinkrelevance.com/blog/2013/06/04/clojure-workflow-reloaded" target="_blank">reloaded workflow</a> to reload the whole routing tree, it is not always possible, and quite frankly a bit slower than we might want for fast iterations.</p>
|
|
<h2 id="a-crude-solution">A crude solution</h2>
|
|
<p>In order to see the changes without reloading the whole route tree, we can use functions.</p>
|
|
<pre><code class="lang-clj">(<span class="hljs-name"><span class="hljs-builtin-name">ns</span></span> ns1)
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">defn</span></span> routes [] <span class="hljs-comment">;; Now a function !</span>
|
|
[<span class="hljs-string">"/bar"</span> <span class="hljs-symbol">::bar</span>])
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">ns</span></span> ns2)
|
|
(<span class="hljs-name">require</span> '[ns1])
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">defn</span></span> routes [] <span class="hljs-comment">;; Now a function !</span>
|
|
[[<span class="hljs-string">"/ping"</span> <span class="hljs-symbol">::ping</span>]
|
|
[<span class="hljs-string">"/more"</span> (<span class="hljs-name">ns1/routes</span>)]]) <span class="hljs-comment">;; Now a function call</span>
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">ns</span></span> ns3)
|
|
(<span class="hljs-name">require</span> '[ns1])
|
|
(<span class="hljs-name">require</span> '[ns2])
|
|
(<span class="hljs-name">require</span> '[reitit.core <span class="hljs-symbol">:as</span> r])
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">defn</span></span> routes [] <span class="hljs-comment">;; Now a function !</span>
|
|
[<span class="hljs-string">"/api"</span>
|
|
[<span class="hljs-string">"/ns2"</span> (<span class="hljs-name">ns2/routes</span>)] <span class="hljs-comment">;; Now a function call</span>
|
|
[<span class="hljs-string">"/ping"</span> <span class="hljs-symbol">::ping</span>]])
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">def</span></span> router #(<span class="hljs-name">r/router</span> (<span class="hljs-name">routes</span>))) <span class="hljs-comment">;; Now a function</span>
|
|
</code></pre>
|
|
<p>Let's query again</p>
|
|
<pre><code class="lang-clj">(<span class="hljs-name">r/match-by-path</span> (<span class="hljs-name">router</span>) <span class="hljs-string">"/api/ns2/more/bar"</span>)
|
|
<span class="hljs-comment">;#reitit.core.Match{:template "/api/ns2/more/bar", :data {:name :ns1/bar}, :result nil, :path-params {}, :path "/api/ns2/more/bar"}</span>
|
|
</code></pre>
|
|
<p>Notice that's we're now calling a function rather than just passing <code>router</code> to the matching function.</p>
|
|
<p>Now let's again change the route name in <code>ns1</code>, and recompile that namespace.</p>
|
|
<pre><code class="lang-clj">(<span class="hljs-name"><span class="hljs-builtin-name">ns</span></span> ns1)
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">defn</span></span> routes []
|
|
[<span class="hljs-string">"/bar"</span> <span class="hljs-symbol">::bar-with-new-name</span>])
|
|
</code></pre>
|
|
<p>let's see the query result :</p>
|
|
<pre><code class="lang-clj">(<span class="hljs-name">r/match-by-path</span> (<span class="hljs-name">router</span>) <span class="hljs-string">"/api/ns2/more/bar"</span>)
|
|
<span class="hljs-comment">;#reitit.core.Match{:template "/api/ns2/more/bar", :data {:name :ns1/bar-with-new-name}, :result nil, :path-params {}, :path "/api/ns2/more/bar"}</span>
|
|
</code></pre>
|
|
<p>Notice that the name is now correct, without reloading every namespace under the sun.</p>
|
|
<h2 id="why-is-this-a-crude-solution-">Why is this a crude solution ?</h2>
|
|
<p>The astute reader will have noticed that we're recompiling the full routing tree on every invocation. While this solution is practical during developement, it goes contrary to the performance goals of reitit. </p>
|
|
<p>We need a way to only do this once at production time.</p>
|
|
<h2 id="an-easy-fix">An easy fix</h2>
|
|
<p>Let's apply a small change to our <code>ns3</code>. We'll replace our router by two different routers, one for dev and one for production.</p>
|
|
<pre><code class="lang-clj">(<span class="hljs-name"><span class="hljs-builtin-name">ns</span></span> ns3)
|
|
(<span class="hljs-name">require</span> '[ns1])
|
|
(<span class="hljs-name">require</span> '[ns2])
|
|
(<span class="hljs-name">require</span> '[reitit.core <span class="hljs-symbol">:as</span> r])
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">defn</span></span> routes []
|
|
[<span class="hljs-string">"/api"</span>
|
|
[<span class="hljs-string">"/ns2"</span> (<span class="hljs-name">ns2/routes</span>)]
|
|
[<span class="hljs-string">"/ping"</span> <span class="hljs-symbol">::ping</span>]])
|
|
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">def</span></span> dev-router #(<span class="hljs-name">r/router</span> (<span class="hljs-name">routes</span>))) <span class="hljs-comment">;; A router for dev</span>
|
|
(<span class="hljs-name"><span class="hljs-builtin-name">def</span></span> prod-router (<span class="hljs-name"><span class="hljs-builtin-name">constantly</span></span> (<span class="hljs-name">r/router</span> (<span class="hljs-name">routes</span>)))) <span class="hljs-comment">;; A router for prod</span>
|
|
</code></pre>
|
|
<p>And there you have it, dynamic during dev, performance at production. We have it all !</p>
|
|
|
|
|
|
</section>
|
|
|
|
</div>
|
|
<div class="search-results">
|
|
<div class="has-results">
|
|
|
|
<h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
|
|
<ul class="search-results-list"></ul>
|
|
|
|
</div>
|
|
<div class="no-results">
|
|
|
|
<h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<a href="route_validation.html" class="navigation navigation-prev " aria-label="Previous page: Route Validation">
|
|
<i class="fa fa-angle-left"></i>
|
|
</a>
|
|
|
|
|
|
<a href="../patterns/" class="navigation navigation-next " aria-label="Next page: Patterns">
|
|
<i class="fa fa-angle-right"></i>
|
|
</a>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
<script>
|
|
var gitbook = gitbook || [];
|
|
gitbook.push(function() {
|
|
gitbook.page.hasChanged({"page":{"title":"Dev Workflow","level":"1.5.5","depth":2,"next":{"title":"Patterns","level":"1.6","depth":1,"path":"patterns/README.md","ref":"patterns/README.md","articles":[{"title":"Shared Routes","level":"1.6.1","depth":2,"path":"patterns/shared_routes.md","ref":"patterns/shared_routes.md","articles":[]}]},"previous":{"title":"Route Validation","level":"1.5.4","depth":2,"path":"advanced/route_validation.md","ref":"advanced/route_validation.md","articles":[]},"dir":"ltr"},"config":{"plugins":["editlink","github","highlight"],"root":"doc","styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"pluginsConfig":{"editlink":{"label":"Edit This Page","multilingual":false,"base":"https://github.com/metosin/reitit/tree/master/doc"},"github":{"url":"https://github.com/metosin/reitit"},"highlight":{},"search":{},"lunr":{"maxIndexSize":1000000,"ignoreSpecialCharacters":false},"sharing":{"facebook":true,"twitter":true,"google":false,"weibo":false,"instapaper":false,"vk":false,"all":["facebook","google","twitter","weibo","instapaper"]},"fontsettings":{"theme":"white","family":"sans","size":2},"theme-default":{"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false}},"theme":"default","pdf":{"pageNumbers":true,"fontSize":12,"fontFamily":"Arial","paperSize":"a4","chapterMark":"pagebreak","pageBreaksBefore":"/","margin":{"right":62,"left":62,"top":56,"bottom":56}},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"variables":{},"gitbook":"*"},"file":{"path":"advanced/dev_workflow.md","mtime":"2018-08-31T08:17:50.392Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2018-08-31T08:18:32.313Z"},"basePath":"..","book":{"language":""}});
|
|
});
|
|
</script>
|
|
</div>
|
|
|
|
|
|
<script src="../gitbook/gitbook.js"></script>
|
|
<script src="../gitbook/theme.js"></script>
|
|
|
|
|
|
<script src="../gitbook/gitbook-plugin-editlink/plugin.js"></script>
|
|
|
|
|
|
|
|
<script src="../gitbook/gitbook-plugin-github/plugin.js"></script>
|
|
|
|
|
|
|
|
<script src="../gitbook/gitbook-plugin-search/search-engine.js"></script>
|
|
|
|
|
|
|
|
<script src="../gitbook/gitbook-plugin-search/search.js"></script>
|
|
|
|
|
|
|
|
<script src="../gitbook/gitbook-plugin-lunr/lunr.min.js"></script>
|
|
|
|
|
|
|
|
<script src="../gitbook/gitbook-plugin-lunr/search-lunr.js"></script>
|
|
|
|
|
|
|
|
<script src="../gitbook/gitbook-plugin-sharing/buttons.js"></script>
|
|
|
|
|
|
|
|
<script src="../gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
|
|
|
|
|
|
|
|
</body>
|
|
</html>
|
|
|