1
0
mirror of https://github.com/Jermolene/TiddlyWiki5 synced 2025-01-11 18:00:26 +00:00

Finish web server API docs

This commit is contained in:
Jermolene 2018-10-02 14:16:58 +01:00
parent 83a245ed21
commit c208c55a22
13 changed files with 284 additions and 4 deletions

View File

@ -0,0 +1,33 @@
created: 20181002130513206
modified: 20181002131123893
tags: [[WebServer Guides]]
title: TiddlyWeb JSON tiddler format
type: text/vnd.tiddlywiki
The web server API uses tiddlers in a special format originally designed for TiddlyWeb:
* Field values are represented as strings. Lists (like the ''tags'' and ''list'' fields) use double square brackets to quote values that contain spaces
* Tiddlers are represented as an object containing any of a fixed set of standard fields, with custom fields being relegated to a special property called ''fields''
* The standard fields are: ''bag'', ''created'', ''creator'', ''modified'', ''modifier'', ''permissions'', ''recipe'', ''revision'', ''tags'', ''text'', ''title'', ''type'', ''uri''
For example, consider the following tiddler:
```
{
"title": "HelloThere",
"tags": "FirstTag [[Second Tag]]",
"my-custom-field": "Field value"
}
```
In transit over the API, the tiddler would be converted to the following format:
```
{
"title": "HelloThere",
"tags": "FirstTag [[Second Tag]]",
"fields": {
"my-custom-field": "Field value"
}
}
```

View File

@ -1,6 +1,6 @@
created: 20180630194032981
modified: 20180630194042074
modified: 20181002103516011
tags: WebServer
title: WebServer Routing
title: WebServer API
type: text/vnd.tiddlywiki

View File

@ -0,0 +1,19 @@
created: 20181002112106875
modified: 20181002124355314
tags: [[WebServer API]]
title: WebServer API: Delete Tiddler
type: text/vnd.tiddlywiki
Delete a tiddler
```
DELETE /bags/default/tiddlers/{title}
```
Parameters:
* ''title'' - URI encoded title of the tiddler to delete
Response:
* 204 No Content

View File

@ -0,0 +1,25 @@
created: 20181002124825195
modified: 20181002125214104
tags: [[WebServer API]]
title: WebServer API: Force Basic Authentication Login
type: text/vnd.tiddlywiki
Forces the server to request basic authentication login, and then redirects to the root
```
GET /login-basic
```
Requests an basic authentication from the browser, and redirects to the root if successful.
Parameters:
* none
Response:
* 302 Found
*> `Location: /`
* 401 Unauthorized
*> `WWW-Authenticate: Basic realm="Please provide your username and password to login to <servername>"

View File

@ -0,0 +1,22 @@
created: 20181002131215403
modified: 20181002131322026
tags: [[WebServer API]]
title: WebServer API: Get All Tiddlers
type: text/vnd.tiddlywiki
Gets an array of all raw tiddlers, excluding the ''text'' field.
```
GET /recipes/default/tiddlers/tiddlers.json
```
Parameters:
* none
Response:
* 200 OK
*> `Content-Type: application/json`
*> Body: array of tiddlers in [[TiddlyWeb JSON tiddler format]]

View File

@ -0,0 +1,21 @@
created: 20181002123308575
modified: 20181002124103586
tags: [[WebServer API]]
title: WebServer API: Get Favicon
type: text/vnd.tiddlywiki
Get the favicon for the wiki from the tiddler $:/favicon.ico
```
GET /favicon.ico
```
Parameters:
* none
Response:
* 200 OK
*> `Content-Type: image/x-icon`
*> Body: image data from the tiddler $:/favicon.ico

View File

@ -0,0 +1,25 @@
created: 20181002123907518
modified: 20181002124345482
tags: [[WebServer API]]
title: WebServer API: Get File
type: text/vnd.tiddlywiki
Get the content of a static file. See
[[using the integrated static file server|Using the integrated static file server]]
```
GET /files/<pathname>
```
Parameters:
* ''pathname'' - URI encoded path to the file
Response:
* 200 OK
*> `Content-Type: <content-type>` (determined from file extension)
*> Body: data retrieved from file
* 403 Forbidden
* 404 Not Found

View File

@ -0,0 +1,43 @@
created: 20181002125229601
modified: 20181002125840235
tags: [[WebServer API]]
title: WebServer API: Get Server Status
type: text/vnd.tiddlywiki
Get server status information
```
GET /status
```
Parameters:
* none
Response:
* 200 OK
*> `Content-Type: application/json`
*> Body: see below
The JSON data returned comprises the following properties:
* ''username'' - the username of the currently authenticated user. If undefined, the [[WebServer Parameter: anon-username]] is returned instead
* ''anonymous'' - true if the current user is anonymous
* ''read_only'' - true if the current user is restricted to read only access to the server
* ''space'' - always contains the object `{recipe: "default"}`
* ''tiddlywiki_version'' - the current TiddlyWiki version
For example:
```
{
"username": "",
"anonymous": true,
"read_only": false,
"space": {
"recipe": "default"
},
"tiddlywiki_version": "5.1.18"
}
```

View File

@ -0,0 +1,23 @@
created: 20181002125954409
modified: 20181002130237725
tags: [[WebServer API]]
title: WebServer API: Get Tiddler Rendering
type: text/vnd.tiddlywiki
Gets a rendering of the specified tiddler. See [[using the read-only single tiddler view|Using the read-only single tiddler view]] for more details.
```
GET /{title}
```
Parameters:
* ''title'' - URI encoded title of the tiddler to render
Response:
* 200 OK
*> `Content-Type: <content-type>`
*> Body: tiddler rendering
* 404 Not Found

View File

@ -0,0 +1,23 @@
created: 20181002130310180
modified: 20181002130457330
tags: [[WebServer API]]
title: WebServer API: Get Tiddler
type: text/vnd.tiddlywiki
Gets the raw fields of a tiddler
```
GET /recipes/default/tiddlers/{title}
```
Parameters:
* ''title'' - URI encoded title of the tiddler to retrieve
Response:
* 200 OK
*> `Content-Type: application/json`
*> Body: tiddler in [[TiddlyWeb JSON tiddler format]]
* 404 Not Found

View File

@ -0,0 +1,23 @@
created: 20181002124430552
modified: 20181002124755134
tags: [[WebServer API]]
title: WebServer API: Get Wiki
type: text/vnd.tiddlywiki
Get the main wiki
```
GET /
```
The wiki is composed by rendering the tiddler identified in the [[root-tiddler|WebServer Parameter: root-tiddler]] parameter with the render type in the [[root-render-type|WebServer Parameter: root-render-type]] parameter. This is then served with the content type from the [[root-serve-type|WebServer Parameter: root-serve-type]] parameter.
Parameters:
* none
Response:
* 200 OK
*> `Content-Type: text/html`
*> Body: data retrieved from file

View File

@ -0,0 +1,23 @@
created: 20181002131341062
modified: 20181002131556452
tags: [[WebServer API]]
title: WebServer API: Put Tiddler
type: text/vnd.tiddlywiki
Saves the raw fields of a tiddler
```
PUT /recipes/default/tiddlers/{title}
```
The body should be in [[TiddlyWeb JSON tiddler format]].
Parameters:
* ''title'' - URI encoded title of the tiddler to save
Response:
* 204 No Content
*> `Content-Type: text/plain`
*> `Etag: "default/<title>/<changecount>:"`

View File

@ -1,5 +1,5 @@
created: 20180626150526207
modified: 20180703095555387
modified: 20181002103605866
tags: ListenCommand ServerCommand Features
title: WebServer
type: text/vnd.tiddlywiki
@ -14,7 +14,7 @@ The web server listens for requests coming over the network, and performs the fo
* [[Authentication|WebServer Authentication]] is the process of identifying the current user. TiddlyWiki supports three types of authentication: [[Anonymous|WebServer Anonymous Access]], [[Basic|WebServer Basic Authentication]] and [[Header|WebServer Header Authentication]]
* [[Authorization|WebServer Authorization]] is the process of determining which resources may be accessed by a particular user. TiddlyWiki implements a simple scheme whereby read and write access to the wiki can be independently controlled.
* [[Routing|WebServer Routing]] is the process of acting on the request, and returning any required data.
* Routing is the process of dispatching the request to the [[API handler|WebServer API]], and returning any required data.
! Usage