Projekt

Obecné

Profil

Stáhnout (13.2 KB) Statistiky
| Větev: | Tag: | Revize:
1
<!doctype html>
2
<html lang="en">
3
<head>
4
<meta charset="utf-8">
5
<meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1" />
6
<meta name="generator" content="pdoc 0.10.0" />
7
<title>sql_app.api.licenses_web API documentation</title>
8
<meta name="description" content="" />
9
<link rel="preload stylesheet" as="style" href="https://cdnjs.cloudflare.com/ajax/libs/10up-sanitize.css/11.0.1/sanitize.min.css" integrity="sha256-PK9q560IAAa6WVRRh76LtCaI8pjTJ2z11v0miyNNjrs=" crossorigin>
10
<link rel="preload stylesheet" as="style" href="https://cdnjs.cloudflare.com/ajax/libs/10up-sanitize.css/11.0.1/typography.min.css" integrity="sha256-7l/o7C8jubJiy74VsKTidCy1yBkRtiUGbVkYBylBqUg=" crossorigin>
11
<link rel="stylesheet preload" as="style" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.1.1/styles/github.min.css" crossorigin>
12
<style>:root{--highlight-color:#fe9}.flex{display:flex !important}body{line-height:1.5em}#content{padding:20px}#sidebar{padding:30px;overflow:hidden}#sidebar > *:last-child{margin-bottom:2cm}.http-server-breadcrumbs{font-size:130%;margin:0 0 15px 0}#footer{font-size:.75em;padding:5px 30px;border-top:1px solid #ddd;text-align:right}#footer p{margin:0 0 0 1em;display:inline-block}#footer p:last-child{margin-right:30px}h1,h2,h3,h4,h5{font-weight:300}h1{font-size:2.5em;line-height:1.1em}h2{font-size:1.75em;margin:1em 0 .50em 0}h3{font-size:1.4em;margin:25px 0 10px 0}h4{margin:0;font-size:105%}h1:target,h2:target,h3:target,h4:target,h5:target,h6:target{background:var(--highlight-color);padding:.2em 0}a{color:#058;text-decoration:none;transition:color .3s ease-in-out}a:hover{color:#e82}.title code{font-weight:bold}h2[id^="header-"]{margin-top:2em}.ident{color:#900}pre code{background:#f8f8f8;font-size:.8em;line-height:1.4em}code{background:#f2f2f1;padding:1px 4px;overflow-wrap:break-word}h1 code{background:transparent}pre{background:#f8f8f8;border:0;border-top:1px solid #ccc;border-bottom:1px solid #ccc;margin:1em 0;padding:1ex}#http-server-module-list{display:flex;flex-flow:column}#http-server-module-list div{display:flex}#http-server-module-list dt{min-width:10%}#http-server-module-list p{margin-top:0}.toc ul,#index{list-style-type:none;margin:0;padding:0}#index code{background:transparent}#index h3{border-bottom:1px solid #ddd}#index ul{padding:0}#index h4{margin-top:.6em;font-weight:bold}@media (min-width:200ex){#index .two-column{column-count:2}}@media (min-width:300ex){#index .two-column{column-count:3}}dl{margin-bottom:2em}dl dl:last-child{margin-bottom:4em}dd{margin:0 0 1em 3em}#header-classes + dl > dd{margin-bottom:3em}dd dd{margin-left:2em}dd p{margin:10px 0}.name{background:#eee;font-weight:bold;font-size:.85em;padding:5px 10px;display:inline-block;min-width:40%}.name:hover{background:#e0e0e0}dt:target .name{background:var(--highlight-color)}.name > span:first-child{white-space:nowrap}.name.class > span:nth-child(2){margin-left:.4em}.inherited{color:#999;border-left:5px solid #eee;padding-left:1em}.inheritance em{font-style:normal;font-weight:bold}.desc h2{font-weight:400;font-size:1.25em}.desc h3{font-size:1em}.desc dt code{background:inherit}.source summary,.git-link-div{color:#666;text-align:right;font-weight:400;font-size:.8em;text-transform:uppercase}.source summary > *{white-space:nowrap;cursor:pointer}.git-link{color:inherit;margin-left:1em}.source pre{max-height:500px;overflow:auto;margin:0}.source pre code{font-size:12px;overflow:visible}.hlist{list-style:none}.hlist li{display:inline}.hlist li:after{content:',\2002'}.hlist li:last-child:after{content:none}.hlist .hlist{display:inline;padding-left:1em}img{max-width:100%}td{padding:0 .5em}.admonition{padding:.1em .5em;margin-bottom:1em}.admonition-title{font-weight:bold}.admonition.note,.admonition.info,.admonition.important{background:#aef}.admonition.todo,.admonition.versionadded,.admonition.tip,.admonition.hint{background:#dfd}.admonition.warning,.admonition.versionchanged,.admonition.deprecated{background:#fd4}.admonition.error,.admonition.danger,.admonition.caution{background:lightpink}</style>
13
<style media="screen and (min-width: 700px)">@media screen and (min-width:700px){#sidebar{width:30%;height:100vh;overflow:auto;position:sticky;top:0}#content{width:70%;max-width:100ch;padding:3em 4em;border-left:1px solid #ddd}pre code{font-size:1em}.item .name{font-size:1em}main{display:flex;flex-direction:row-reverse;justify-content:flex-end}.toc ul ul,#index ul{padding-left:1.5em}.toc > ul > li{margin-top:.5em}}</style>
14
<style media="print">@media print{#sidebar h1{page-break-before:always}.source{display:none}}@media print{*{background:transparent !important;color:#000 !important;box-shadow:none !important;text-shadow:none !important}a[href]:after{content:" (" attr(href) ")";font-size:90%}a[href][title]:after{content:none}abbr[title]:after{content:" (" attr(title) ")"}.ir a:after,a[href^="javascript:"]:after,a[href^="#"]:after{content:""}pre,blockquote{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}img{max-width:100% !important}@page{margin:0.5cm}p,h2,h3{orphans:3;widows:3}h1,h2,h3,h4,h5,h6{page-break-after:avoid}}</style>
15
<script defer src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.1.1/highlight.min.js" integrity="sha256-Uv3H6lx7dJmRfRvH8TH6kJD1TSK1aFcwgx+mdg3epi8=" crossorigin></script>
16
<script>window.addEventListener('DOMContentLoaded', () => hljs.initHighlighting())</script>
17
</head>
18
<body>
19
<main>
20
<article id="content">
21
<header>
22
<h1 class="title">Module <code>sql_app.api.licenses_web</code></h1>
23
</header>
24
<section id="section-intro">
25
<details class="source">
26
<summary>
27
<span>Expand source code</span>
28
</summary>
29
<pre><code class="python">from typing import List
30

    
31
from fastapi import Depends, FastAPI, HTTPException, APIRouter, Form
32
from sqlalchemy.orm import Session
33
from datetime import date
34
from sql_app import crud, models, schemas
35
from ..database import SessionLocal, engine
36
from fastapi import FastAPI, Request
37
from fastapi.responses import HTMLResponse
38
from fastapi.staticfiles import StaticFiles
39
from fastapi.templating import Jinja2Templates
40

    
41
models.Base.metadata.create_all(bind=engine)
42

    
43
# Path to html templates used in this file
44
templates = Jinja2Templates(directory=&#34;../templates/licenses&#34;)
45
device_templates = Jinja2Templates(directory=&#34;../templates/devices&#34;)
46

    
47
# prefix used for all endpoints in this file
48
licenses_web = APIRouter(prefix=&#34;/api/v1&#34;)
49

    
50

    
51
# Dependency
52
def get_db():
53
    db = SessionLocal()
54
    try:
55
        yield db
56
    finally:
57
        db.close()
58

    
59

    
60
@licenses_web.get(&#34;/license-create&#34;, response_class=HTMLResponse)
61
async def licenses_create_web(request: Request):
62
    &#34;&#34;&#34;
63
    Returns template with Form for creating new license.
64
    &#34;&#34;&#34;
65
    return templates.TemplateResponse(&#34;license_create.html&#34;, {&#34;request&#34;: request})
66

    
67

    
68
@licenses_web.get(&#34;/licenses-web&#34;, response_class=HTMLResponse)
69
async def read_licenses_web(request: Request, skip: int = 0, limit: int = 100, db: Session = Depends(get_db)):
70
    &#34;&#34;&#34;
71
    Returns template with all licenses currently saved in database
72
    &#34;&#34;&#34;
73
    licenses = crud.get_licenses(db, skip=skip, limit=limit)
74
    return templates.TemplateResponse(&#34;licenses.html&#34;, {&#34;request&#34;: request, &#34;licenses&#34;: licenses})
75

    
76

    
77
@licenses_web.post(&#34;/licenses-web&#34;, response_class=HTMLResponse)
78
def create_license(request: Request, name: str = Form(...), expdate: date = Form(...), skip: int = 0, limit: int = 100,
79
                   db: Session = Depends(get_db)):
80
    &#34;&#34;&#34;
81
    Endpoint called from create license form. Creates new license and returns template with all licenses in database
82
    &#34;&#34;&#34;
83
    db_license = crud.create_license(db, name, expdate)
84
    if db_license is None:
85
        print(&#34;something went wrong&#34;)
86
    devices = crud.get_devices(db, skip=skip, limit=limit)
87
    statuses = []
88
    for i in range(0, len(devices)):
89
        statuses.append(devices[i].logs[len(devices[i].logs) - 1].status)
90
    licenses = crud.get_licenses(db, skip=skip, limit=limit)
91
    return device_templates.TemplateResponse(&#34;devices.html&#34;, {&#34;request&#34;: request, &#34;devs&#34;: len(devices), &#34;devices&#34;: devices,
92
                                                       &#34;statuses&#34;: statuses, &#34;licenses&#34;: licenses})</code></pre>
93
</details>
94
</section>
95
<section>
96
</section>
97
<section>
98
</section>
99
<section>
100
<h2 class="section-title" id="header-functions">Functions</h2>
101
<dl>
102
<dt id="sql_app.api.licenses_web.create_license"><code class="name flex">
103
<span>def <span class="ident">create_license</span></span>(<span>request: starlette.requests.Request, name: str = Form(Ellipsis), expdate: datetime.date = Form(Ellipsis), skip: int = 0, limit: int = 100, db: sqlalchemy.orm.session.Session = Depends(get_db))</span>
104
</code></dt>
105
<dd>
106
<div class="desc"><p>Endpoint called from create license form. Creates new license and returns template with all licenses in database</p></div>
107
<details class="source">
108
<summary>
109
<span>Expand source code</span>
110
</summary>
111
<pre><code class="python">@licenses_web.post(&#34;/licenses-web&#34;, response_class=HTMLResponse)
112
def create_license(request: Request, name: str = Form(...), expdate: date = Form(...), skip: int = 0, limit: int = 100,
113
                   db: Session = Depends(get_db)):
114
    &#34;&#34;&#34;
115
    Endpoint called from create license form. Creates new license and returns template with all licenses in database
116
    &#34;&#34;&#34;
117
    db_license = crud.create_license(db, name, expdate)
118
    if db_license is None:
119
        print(&#34;something went wrong&#34;)
120
    devices = crud.get_devices(db, skip=skip, limit=limit)
121
    statuses = []
122
    for i in range(0, len(devices)):
123
        statuses.append(devices[i].logs[len(devices[i].logs) - 1].status)
124
    licenses = crud.get_licenses(db, skip=skip, limit=limit)
125
    return device_templates.TemplateResponse(&#34;devices.html&#34;, {&#34;request&#34;: request, &#34;devs&#34;: len(devices), &#34;devices&#34;: devices,
126
                                                       &#34;statuses&#34;: statuses, &#34;licenses&#34;: licenses})</code></pre>
127
</details>
128
</dd>
129
<dt id="sql_app.api.licenses_web.get_db"><code class="name flex">
130
<span>def <span class="ident">get_db</span></span>(<span>)</span>
131
</code></dt>
132
<dd>
133
<div class="desc"></div>
134
<details class="source">
135
<summary>
136
<span>Expand source code</span>
137
</summary>
138
<pre><code class="python">def get_db():
139
    db = SessionLocal()
140
    try:
141
        yield db
142
    finally:
143
        db.close()</code></pre>
144
</details>
145
</dd>
146
<dt id="sql_app.api.licenses_web.licenses_create_web"><code class="name flex">
147
<span>async def <span class="ident">licenses_create_web</span></span>(<span>request: starlette.requests.Request)</span>
148
</code></dt>
149
<dd>
150
<div class="desc"><p>Returns template with Form for creating new license.</p></div>
151
<details class="source">
152
<summary>
153
<span>Expand source code</span>
154
</summary>
155
<pre><code class="python">@licenses_web.get(&#34;/license-create&#34;, response_class=HTMLResponse)
156
async def licenses_create_web(request: Request):
157
    &#34;&#34;&#34;
158
    Returns template with Form for creating new license.
159
    &#34;&#34;&#34;
160
    return templates.TemplateResponse(&#34;license_create.html&#34;, {&#34;request&#34;: request})</code></pre>
161
</details>
162
</dd>
163
<dt id="sql_app.api.licenses_web.read_licenses_web"><code class="name flex">
164
<span>async def <span class="ident">read_licenses_web</span></span>(<span>request: starlette.requests.Request, skip: int = 0, limit: int = 100, db: sqlalchemy.orm.session.Session = Depends(get_db))</span>
165
</code></dt>
166
<dd>
167
<div class="desc"><p>Returns template with all licenses currently saved in database</p></div>
168
<details class="source">
169
<summary>
170
<span>Expand source code</span>
171
</summary>
172
<pre><code class="python">@licenses_web.get(&#34;/licenses-web&#34;, response_class=HTMLResponse)
173
async def read_licenses_web(request: Request, skip: int = 0, limit: int = 100, db: Session = Depends(get_db)):
174
    &#34;&#34;&#34;
175
    Returns template with all licenses currently saved in database
176
    &#34;&#34;&#34;
177
    licenses = crud.get_licenses(db, skip=skip, limit=limit)
178
    return templates.TemplateResponse(&#34;licenses.html&#34;, {&#34;request&#34;: request, &#34;licenses&#34;: licenses})</code></pre>
179
</details>
180
</dd>
181
</dl>
182
</section>
183
<section>
184
</section>
185
</article>
186
<nav id="sidebar">
187
<h1>Index</h1>
188
<div class="toc">
189
<ul></ul>
190
</div>
191
<ul id="index">
192
<li><h3>Super-module</h3>
193
<ul>
194
<li><code><a title="sql_app.api" href="index.html">sql_app.api</a></code></li>
195
</ul>
196
</li>
197
<li><h3><a href="#header-functions">Functions</a></h3>
198
<ul class="">
199
<li><code><a title="sql_app.api.licenses_web.create_license" href="#sql_app.api.licenses_web.create_license">create_license</a></code></li>
200
<li><code><a title="sql_app.api.licenses_web.get_db" href="#sql_app.api.licenses_web.get_db">get_db</a></code></li>
201
<li><code><a title="sql_app.api.licenses_web.licenses_create_web" href="#sql_app.api.licenses_web.licenses_create_web">licenses_create_web</a></code></li>
202
<li><code><a title="sql_app.api.licenses_web.read_licenses_web" href="#sql_app.api.licenses_web.read_licenses_web">read_licenses_web</a></code></li>
203
</ul>
204
</li>
205
</ul>
206
</nav>
207
</main>
208
<footer id="footer">
209
<p>Generated by <a href="https://pdoc3.github.io/pdoc" title="pdoc: Python API documentation generator"><cite>pdoc</cite> 0.10.0</a>.</p>
210
</footer>
211
</body>
212
</html>
(5-5/11)