openapi : 3.0 .0
info :
title : NodeBB Write API
description : >-
# Overview
The following document outlines every route exposed by the NodeBB Write API. As of NodeBB v1.15.0, NodeBB will use these routes to make changes to the database (e.g. creating new posts, editing user profiles, etc.)
We invite you to build external integrations with NodeBB using this document as a guide.
# History
Up until v1.15.0, NodeBB utilised the [WebSocket](https://en.wikipedia.org/wiki/WebSocket) protocol to communicate with the backend. However, it was decided in early 2020 that this usage of WebSocket – while functional – led to occasional wheel reinvention and disregarded an otherwise fully-featured technology (that is, REST).
Years prior to this determination, many users of NodeBB had asked for a RESTful API to call against NodeBB, which led to the creation of [`nodebb-plugin-write-api`](https://github.com/NodeBB/nodebb-plugin-write-api). In tandem with the above decision, the Write API was merged into NodeBB core in late 2020.
v3 of the Write API (this document) achieves rough feature parity with v2 of the Write API plugin.
version : 1.15 .0
contact :
email : support@nodebb.org
license :
name : GPL-3.0
servers :
- url : /api/v1
tags :
- name : users
description : 'Account related calls (create, modify, delete, etc.)'
- name : categories
description : Administrative calls to manage categories
paths :
'/users/{uid}' :
delete :
tags :
- users
summary : delete a single user account
parameters :
- in : path
name : uid
schema :
type : integer
required : true
description : uid of the user to delete
responses :
'200' :
description : user account deleted
content :
application/json :
schema :
type : object
properties :
status :
$ref : components/schemas/Status.yaml#/Status
response :
type : object
put :
tags :
- users
summary : update a user account
parameters :
- in : path
name : uid
schema :
type : integer
required : true
description : uid of the user to update
requestBody :
required : true
content :
application/json :
schema :
$ref : components/schemas/UserRequest.yaml#/UserRequest
responses :
'200' :
description : user profile updated
content :
application/json :
schema :
type : object
properties :
status :
$ref : components/schemas/Status.yaml#/Status
response :
$ref : components/schemas/UserObj.yaml#/UserObj
'401' :
$ref : components/responses/401.yaml#/401
'403' :
$ref : components/responses/403.yaml#/403
'426' :
$ref : components/responses/426.yaml#/426
'500' :
$ref : components/responses/500.yaml#/500
'/users/{uid}/password' :
put :
tags :
- users
summary : change a user's password
parameters :
- in : path
name : uid
schema :
type : integer
required : true
description : uid of the user to update
requestBody :
required : true
content :
application/json :
schema :
type : object
properties :
currentPassword :
type : string
description : test
example : oldp455word
newPassword :
type : string
example : s3cre7password
required :
- newPassword
responses :
'200' :
description : user profile updated
content :
application/json :
schema :
type : object
properties :
status :
$ref : components/schemas/Status.yaml#/Status
response :
type : object
'/users/{uid}/follow' :
post :
tags :
- users
summary : follow a user
parameters :
- in : path
name : uid
schema :
type : integer
required : true
description : uid of the user to follow
responses :
'200' :
description : successfully followed user
content :
application/json :
schema :
type : object
properties :
status :
$ref : components/schemas/Status.yaml#/Status
response :
type : object
delete :
tags :
- users
summary : unfollows a user
parameters :
- in : path
name : uid
schema :
type : integer
required : true
description : uid of the user to unfollow
responses :
'200' :
description : successfully unfollowed user
content :
application/json :
schema :
type : object
properties :
status :
$ref : components/schemas/Status.yaml#/Status
response :
type : object
'/users/{uid}/ban' :
put :
tags :
- users
summary : ban a user
parameters :
- in : path
name : uid
schema :
type : integer
required : true
description : uid of the user to ban
requestBody :
content :
application/json :
schema :
type : object
properties :
until :
type : number
description : UNIX timestamp of the ban expiry
example : 1585775608076
reason :
type : string
example : the reason for the ban
responses :
'200' :
description : successfully banned user
content :
application/json :
schema :
type : object
properties :
status :
$ref : components/schemas/Status.yaml#/Status
response :
type : object
delete :
tags :
- users
summary : unbans a user
parameters :
- in : path
name : uid
schema :
type : integer
required : true
description : uid of the user to unban
responses :
'200' :
description : successfully unbanned user
content :
application/json :
schema :
type : object
properties :
status :
$ref : components/schemas/Status.yaml#/Status
response :
type : object
'/users/{uid}/tokens' :
post :
tags :
- users
summary : generate a user token
description : This route can only be used to generate tokens for the same user. In other words, you cannot use this route to generate a token for a different user than the one you are authenticated as.
responses :
'200' :
description : successfully generated a user token
content :
application/json :
schema :
type : object
properties :
status :
$ref : components/schemas/Status.yaml#/Status
response :
type : object
delete :
tags :
- users
summary : delete user token
parameters :
- in : path
name : token
schema :
type : string
required : true
description : a valid API token
responses :
'200' :
description : successfully deleted user token
content :
application/json :
schema :
type : object
properties :
status :
$ref : components/schemas/Status.yaml#/Status
response :
type : object
/categories/ :
$ref : 'write/categories.yaml'
/groups/ :
$ref : 'write/groups.yaml'
/groups/{slug}/membership/{uid}:
$ref : 'write/groups/slug/membership/uid.yaml'
/topics :
$ref : 'write/topics.yaml'
/topics/{tid}:
$ref : 'write/topics/tid.yaml'
/topics/{tid}/state:
$ref : 'write/topics/tid/state.yaml'
/topics/{tid}/lock:
$ref : 'write/topics/tid/lock.yaml'
/topics/{tid}/pin:
$ref : 'write/topics/tid/pin.yaml'
/topics/{tid}/follow:
$ref : 'write/topics/tid/follow.yaml'
/topics/{tid}/ignore:
$ref : 'write/topics/tid/ignore.yaml'
/topics/{tid}/tags:
$ref : 'write/topics/tid/tags.yaml'
/posts/{pid}:
$ref : 'write/posts/pid.yaml'
/posts/{pid}/state:
$ref : 'write/posts/pid/state.yaml'
/posts/{pid}/vote:
$ref : 'write/posts/pid/vote.yaml'
/posts/{pid}/bookmark:
$ref : 'write/posts/pid/bookmark.yaml'
/admin/settings/{setting}:
$ref : 'write/admin/settings/setting.yaml'
/files :
$ref : 'write/files.yaml'