mirror of
https://github.com/metosin/reitit.git
synced 2025-12-20 17:41:11 +00:00
954 lines
27 KiB
HTML
954 lines
27 KiB
HTML
|
|
<!DOCTYPE HTML>
|
|
<html lang="" >
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta content="text/html; charset=utf-8" http-equiv="Content-Type">
|
|
<title>Controllers · 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-hints/plugin-hints.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="../advanced/configuring_routers.html" />
|
|
|
|
|
|
<link rel="prev" href="browser.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="header">Introduction</li>
|
|
|
|
|
|
|
|
<li class="chapter " data-level="1.1" data-path="../">
|
|
|
|
<a href="../">
|
|
|
|
|
|
Introduction
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
|
|
|
|
<li class="header">Basics</li>
|
|
|
|
|
|
|
|
<li class="chapter " data-level="2.1" data-path="../basics/route_syntax.html">
|
|
|
|
<a href="../basics/route_syntax.html">
|
|
|
|
|
|
Route Syntax
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="2.2" data-path="../basics/router.html">
|
|
|
|
<a href="../basics/router.html">
|
|
|
|
|
|
Router
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="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="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="2.5" data-path="../basics/route_data.html">
|
|
|
|
<a href="../basics/route_data.html">
|
|
|
|
|
|
Route Data
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="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="2.7" data-path="../basics/route_conflicts.html">
|
|
|
|
<a href="../basics/route_conflicts.html">
|
|
|
|
|
|
Route Conflicts
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
|
|
|
|
<li class="header">Coercion</li>
|
|
|
|
|
|
|
|
<li class="chapter " data-level="3.1" data-path="../coercion/coercion.html">
|
|
|
|
<a href="../coercion/coercion.html">
|
|
|
|
|
|
Coercion Explained
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="3.2" data-path="../coercion/schema_coercion.html">
|
|
|
|
<a href="../coercion/schema_coercion.html">
|
|
|
|
|
|
Plumatic Schema
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="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="3.4" data-path="../coercion/data_spec_coercion.html">
|
|
|
|
<a href="../coercion/data_spec_coercion.html">
|
|
|
|
|
|
Data-specs
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
|
|
|
|
<li class="header">Ring</li>
|
|
|
|
|
|
|
|
<li class="chapter " data-level="4.1" data-path="../ring/ring.html">
|
|
|
|
<a href="../ring/ring.html">
|
|
|
|
|
|
Ring-router
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.2" data-path="../ring/reverse_routing.html">
|
|
|
|
<a href="../ring/reverse_routing.html">
|
|
|
|
|
|
Reverse-routing
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.3" data-path="../ring/default_handler.html">
|
|
|
|
<a href="../ring/default_handler.html">
|
|
|
|
|
|
Default handler
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.4" data-path="../ring/slash_handler.html">
|
|
|
|
<a href="../ring/slash_handler.html">
|
|
|
|
|
|
Slash handler
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.5" data-path="../ring/static.html">
|
|
|
|
<a href="../ring/static.html">
|
|
|
|
|
|
Static Resources
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.6" data-path="../ring/dynamic_extensions.html">
|
|
|
|
<a href="../ring/dynamic_extensions.html">
|
|
|
|
|
|
Dynamic Extensions
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.7" data-path="../ring/data_driven_middleware.html">
|
|
|
|
<a href="../ring/data_driven_middleware.html">
|
|
|
|
|
|
Data-driven Middleware
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.8" data-path="../ring/transforming_middleware_chain.html">
|
|
|
|
<a href="../ring/transforming_middleware_chain.html">
|
|
|
|
|
|
Transforming Middleware Chain
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.9" data-path="../ring/middleware_registry.html">
|
|
|
|
<a href="../ring/middleware_registry.html">
|
|
|
|
|
|
Middleware Registry
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.10" data-path="../ring/default_middleware.html">
|
|
|
|
<a href="../ring/default_middleware.html">
|
|
|
|
|
|
Default Middleware
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.11" data-path="../ring/coercion.html">
|
|
|
|
<a href="../ring/coercion.html">
|
|
|
|
|
|
Ring Coercion
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.12" data-path="../ring/route_data_validation.html">
|
|
|
|
<a href="../ring/route_data_validation.html">
|
|
|
|
|
|
Route Data Validation
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.13" data-path="../ring/compiling_middleware.html">
|
|
|
|
<a href="../ring/compiling_middleware.html">
|
|
|
|
|
|
Compiling Middleware
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.14" data-path="../ring/swagger.html">
|
|
|
|
<a href="../ring/swagger.html">
|
|
|
|
|
|
Swagger Support
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="4.15" data-path="../ring/RESTful_form_methods.html">
|
|
|
|
<a href="../ring/RESTful_form_methods.html">
|
|
|
|
|
|
RESTful form methods
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
|
|
|
|
<li class="header">HTTP</li>
|
|
|
|
|
|
|
|
<li class="chapter " data-level="5.1" data-path="../http/interceptors.html">
|
|
|
|
<a href="../http/interceptors.html">
|
|
|
|
|
|
Interceptors
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="5.2" data-path="../http/pedestal.html">
|
|
|
|
<a href="../http/pedestal.html">
|
|
|
|
|
|
Pedestal
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="5.3" data-path="../http/sieppari.html">
|
|
|
|
<a href="../http/sieppari.html">
|
|
|
|
|
|
Sieppari
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="5.4" data-path="../http/default_interceptors.html">
|
|
|
|
<a href="../http/default_interceptors.html">
|
|
|
|
|
|
Default Interceptors
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="5.5" data-path="../http/transforming_interceptor_chain.html">
|
|
|
|
<a href="../http/transforming_interceptor_chain.html">
|
|
|
|
|
|
Transforming Interceptor Chain
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
|
|
|
|
<li class="header">Frontend</li>
|
|
|
|
|
|
|
|
<li class="chapter " data-level="6.1" data-path="basics.html">
|
|
|
|
<a href="basics.html">
|
|
|
|
|
|
Basics
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="6.2" data-path="browser.html">
|
|
|
|
<a href="browser.html">
|
|
|
|
|
|
Browser integration
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter active" data-level="6.3" data-path="controllers.html">
|
|
|
|
<a href="controllers.html">
|
|
|
|
|
|
Controllers
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
|
|
|
|
<li class="header">Advanced</li>
|
|
|
|
|
|
|
|
<li class="chapter " data-level="7.1" data-path="../advanced/configuring_routers.html">
|
|
|
|
<a href="../advanced/configuring_routers.html">
|
|
|
|
|
|
Configuring Routers
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="7.2" data-path="../advanced/composing_routers.html">
|
|
|
|
<a href="../advanced/composing_routers.html">
|
|
|
|
|
|
Composing Routers
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="7.3" data-path="../advanced/different_routers.html">
|
|
|
|
<a href="../advanced/different_routers.html">
|
|
|
|
|
|
Different Routers
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="7.4" data-path="../advanced/route_validation.html">
|
|
|
|
<a href="../advanced/route_validation.html">
|
|
|
|
|
|
Route Validation
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="7.5" data-path="../advanced/dev_workflow.html">
|
|
|
|
<a href="../advanced/dev_workflow.html">
|
|
|
|
|
|
Dev Workflow
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="7.6" data-path="../advanced/shared_routes.html">
|
|
|
|
<a href="../advanced/shared_routes.html">
|
|
|
|
|
|
Shared Routes
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
|
|
|
|
|
|
<li class="header">Misc</li>
|
|
|
|
|
|
|
|
<li class="chapter " data-level="8.1" data-path="../performance.html">
|
|
|
|
<a href="../performance.html">
|
|
|
|
|
|
Performance
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="8.2" data-path="../development.html">
|
|
|
|
<a href="../development.html">
|
|
|
|
|
|
Development Instructions
|
|
|
|
</a>
|
|
|
|
|
|
|
|
</li>
|
|
|
|
<li class="chapter " data-level="8.3" 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=".." >Controllers</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="controllers">Controllers</h1>
|
|
<ul>
|
|
<li><a href="https://github.com/metosin/reitit/tree/master/examples/frontend-controllers" target="_blank">https://github.com/metosin/reitit/tree/master/examples/frontend-controllers</a></li>
|
|
</ul>
|
|
<p>Controllers run code when a route is entered and left. This can be useful to:</p>
|
|
<ul>
|
|
<li>Load resources</li>
|
|
<li>Update application state</li>
|
|
</ul>
|
|
<h2 id="how-controllers-work">How controllers work</h2>
|
|
<p>A controller map can contain these properties:</p>
|
|
<ul>
|
|
<li><code>identity</code> function which takes a Match and returns an arbitrary value,</li>
|
|
<li>or <code>parameters</code> value, which declares which parameters should affect
|
|
controller identity</li>
|
|
<li><code>start</code> & <code>stop</code> functions, which are called with controller identity</li>
|
|
</ul>
|
|
<p>When you navigate to a route that has a controller, controller identity
|
|
is first resolved by calling <code>identity</code> function, or by using <code>parameters</code>
|
|
declaration, or if neither is set, the identity is <code>nil</code>. Next controller
|
|
is initialized by calling <code>start</code> is called with the identity value.
|
|
When you exit that route, <code>stop</code> is called with the return value of <code>params.</code></p>
|
|
<p>If you navigate to the same route with different match, identity gets
|
|
resolved again. If the identity changes from the previous value, controller
|
|
is reinitialized: <code>stop</code> and <code>start</code> get called again.</p>
|
|
<p>You can add controllers to a route by adding them to the route data in the
|
|
<code>:controllers</code> vector. For example:</p>
|
|
<pre><code class="lang-cljs">["/item/:id"
|
|
{:controllers [{:parameters {:path [:id]}
|
|
:start (fn [parameters] (js/console.log :start (-> parameters :path :id)))
|
|
:stop (fn [parameters] (js/console.log :stop (-> parameters :path :id)))}]}]
|
|
</code></pre>
|
|
<p>You can leave out <code>start</code> or <code>stop</code> if you do not need both of them.</p>
|
|
<h2 id="enabling-controllers">Enabling controllers</h2>
|
|
<p>You need to
|
|
call
|
|
<a href="https://cljdoc.org/d/metosin/reitit-frontend/CURRENT/api/reitit.frontend.controllers#apply-controllers" target="_blank"><code>reitit.frontend.controllers/apply-controllers</code></a> whenever
|
|
the URL changes. You can call it from the <code>on-navigate</code> callback of
|
|
<code>reitit.frontend.easy</code>:</p>
|
|
<pre><code class="lang-cljs">(ns frontend.core
|
|
(:require [reitit.frontend.easy :as rfe]
|
|
[reitit.frontend.controllers :as rfc]))
|
|
|
|
(defonce match-a (atom nil))
|
|
|
|
(def routes
|
|
["/" ...])
|
|
|
|
(defn init! []
|
|
(rfe/start!
|
|
routes
|
|
(fn [new-match]
|
|
(swap! match-a
|
|
(fn [old-match]
|
|
(when new-match
|
|
(assoc new-match
|
|
:controllers (rfc/apply-controllers (:controllers old-match) new-match))))))))
|
|
</code></pre>
|
|
<p>See also <a href="https://github.com/metosin/reitit/tree/master/examples/frontend-controllers" target="_blank">the full example</a>.</p>
|
|
<h2 id="nested-controllers">Nested controllers</h2>
|
|
<p>When you nest routes in the route tree, the controllers get concatenated when
|
|
route data is merged. Consider this route tree:</p>
|
|
<pre><code class="lang-cljs">["/" {:controllers [{:start (fn [_] (js/console.log "root start"))}]}
|
|
["/item/:id"
|
|
{:controllers [{:params (fn [match] (get-in match [:path-params :id]))
|
|
:start (fn [item-id] (js/console.log "item start" item-id))
|
|
:stop (fn [item-id] (js/console.log "item stop" item-id))}]}]]
|
|
</code></pre>
|
|
<ul>
|
|
<li>When you navigate to any route at all, the root controller gets started.</li>
|
|
<li>If you navigate to <code>/item/something</code>, the root controller gets started first
|
|
and then the item controller gets started.</li>
|
|
<li>If you then navigate from <code>/item/something</code> to <code>/item/something-else</code>, first
|
|
the item controller gets stopped with parameter <code>something</code> and then it gets
|
|
started with the parameter <code>something-else</code>. The root controller stays on the
|
|
whole time since its parameters do not change.</li>
|
|
</ul>
|
|
<h2 id="tips">Tips</h2>
|
|
<h3 id="authentication">Authentication</h3>
|
|
<p>Controllers can be used to load resources from a server. If and when your
|
|
API requires authentication you will need to implement logic to prevent controllers
|
|
trying to do requests if user isn't authenticated yet.</p>
|
|
<h4 id="run-controllers-and-check-authentication">Run controllers and check authentication</h4>
|
|
<p>If you have both unauthenticated and authenticated resources, you can
|
|
run the controllers always and then check the authentication status
|
|
on controller code, or on the code called from controllers (e.g. re-frame event
|
|
handler).</p>
|
|
<h4 id="disable-controllers-until-user-is-authenticated">Disable controllers until user is authenticated</h4>
|
|
<p>If all your resources require authentication an easy way to prevent bad
|
|
requests is to enable controllers only after authentication is done.
|
|
To do this you can check authentication status and call <code>apply-controllers</code>
|
|
only after authentication is done (also remember to manually call <code>apply-controllers</code>
|
|
with current <code>match</code> when authentication is done). Or if no navigation is possible
|
|
before authentication is done, you can start the router only after
|
|
authentication is done.</p>
|
|
<h2 id="alternatives">Alternatives</h2>
|
|
<p>Similar solution could be used to describe required resources as data (maybe
|
|
even GraphQL query) per route, and then have code automatically load
|
|
missing resources.</p>
|
|
<h2 id="controllers-elsewhere">Controllers elsewhere</h2>
|
|
<ul>
|
|
<li><a href="https://keechma.com/guides/controllers/" target="_blank">Controllers in Keechma</a></li>
|
|
</ul>
|
|
|
|
|
|
</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="browser.html" class="navigation navigation-prev " aria-label="Previous page: Browser integration">
|
|
<i class="fa fa-angle-left"></i>
|
|
</a>
|
|
|
|
|
|
<a href="../advanced/configuring_routers.html" class="navigation navigation-next " aria-label="Next page: Configuring Routers">
|
|
<i class="fa fa-angle-right"></i>
|
|
</a>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
<script>
|
|
var gitbook = gitbook || [];
|
|
gitbook.push(function() {
|
|
gitbook.page.hasChanged({"page":{"title":"Controllers","level":"6.3","depth":1,"next":{"title":"Configuring Routers","level":"7.1","depth":1,"path":"advanced/configuring_routers.md","ref":"advanced/configuring_routers.md","articles":[]},"previous":{"title":"Browser integration","level":"6.2","depth":1,"path":"frontend/browser.md","ref":"frontend/browser.md","articles":[]},"dir":"ltr"},"config":{"plugins":["hints","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":{"github":{"url":"https://github.com/metosin/reitit"},"editlink":{"label":"Edit This Page","multilingual":false,"base":"https://github.com/metosin/reitit/tree/master/doc"},"search":{},"hints":{"danger":"fa fa-exclamation-circle","info":"fa fa-info-circle","tip":"fa fa-mortar-board","working":"fa fa-wrench"},"lunr":{"maxIndexSize":1000000,"ignoreSpecialCharacters":false},"fontsettings":{"theme":"white","family":"sans","size":2},"highlight":{},"sharing":{"facebook":true,"twitter":true,"google":false,"weibo":false,"instapaper":false,"vk":false,"all":["facebook","google","twitter","weibo","instapaper"]},"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":"frontend/controllers.md","mtime":"2019-05-10T12:25:19.364Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2019-05-10T12:25:44.275Z"},"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>
|
|
|