Add signup approval API REST doc
This commit is contained in:
parent
e364e31e25
commit
3e5716dd3a
1 changed files with 279 additions and 21 deletions
|
@ -1,7 +1,7 @@
|
||||||
openapi: 3.0.0
|
openapi: 3.0.0
|
||||||
info:
|
info:
|
||||||
title: PeerTube
|
title: PeerTube
|
||||||
version: 4.0.0
|
version: 5.1.0
|
||||||
contact:
|
contact:
|
||||||
name: PeerTube Community
|
name: PeerTube Community
|
||||||
url: https://joinpeertube.org
|
url: https://joinpeertube.org
|
||||||
|
@ -1401,22 +1401,44 @@ paths:
|
||||||
'200':
|
'200':
|
||||||
description: successful operation
|
description: successful operation
|
||||||
|
|
||||||
/api/v1/users/register:
|
/api/v1/users/ask-send-verify-email:
|
||||||
post:
|
post:
|
||||||
summary: Register a user
|
summary: Resend user verification link
|
||||||
operationId: registerUser
|
operationId: resendEmailToVerifyUser
|
||||||
tags:
|
tags:
|
||||||
- Users
|
- Users
|
||||||
- Register
|
- Register
|
||||||
responses:
|
|
||||||
'204':
|
|
||||||
description: successful operation
|
|
||||||
requestBody:
|
requestBody:
|
||||||
content:
|
content:
|
||||||
application/json:
|
application/json:
|
||||||
schema:
|
schema:
|
||||||
$ref: '#/components/schemas/RegisterUser'
|
type: object
|
||||||
required: true
|
properties:
|
||||||
|
email:
|
||||||
|
type: string
|
||||||
|
description: User email
|
||||||
|
responses:
|
||||||
|
'204':
|
||||||
|
description: successful operation
|
||||||
|
|
||||||
|
/api/v1/users/registrations/ask-send-verify-email:
|
||||||
|
post:
|
||||||
|
summary: Resend verification link to registration email
|
||||||
|
operationId: resendEmailToVerifyRegistration
|
||||||
|
tags:
|
||||||
|
- Register
|
||||||
|
requestBody:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
email:
|
||||||
|
type: string
|
||||||
|
description: Registration email
|
||||||
|
responses:
|
||||||
|
'204':
|
||||||
|
description: successful operation
|
||||||
|
|
||||||
/api/v1/users/{id}/verify-email:
|
/api/v1/users/{id}/verify-email:
|
||||||
post:
|
post:
|
||||||
|
@ -1425,6 +1447,7 @@ paths:
|
||||||
description: |
|
description: |
|
||||||
Following a user registration, the new user will receive an email asking to click a link
|
Following a user registration, the new user will receive an email asking to click a link
|
||||||
containing a secret.
|
containing a secret.
|
||||||
|
This endpoint can also be used to verify a new email set in the user account.
|
||||||
tags:
|
tags:
|
||||||
- Users
|
- Users
|
||||||
- Register
|
- Register
|
||||||
|
@ -1451,6 +1474,36 @@ paths:
|
||||||
'404':
|
'404':
|
||||||
description: user not found
|
description: user not found
|
||||||
|
|
||||||
|
/api/v1/users/registrations/{registrationId}/verify-email:
|
||||||
|
post:
|
||||||
|
summary: Verify a registration email
|
||||||
|
operationId: verifyRegistrationEmail
|
||||||
|
description: |
|
||||||
|
Following a user registration request, the user will receive an email asking to click a link
|
||||||
|
containing a secret.
|
||||||
|
tags:
|
||||||
|
- Register
|
||||||
|
parameters:
|
||||||
|
- $ref: '#/components/parameters/registrationId'
|
||||||
|
requestBody:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
verificationString:
|
||||||
|
type: string
|
||||||
|
format: url
|
||||||
|
required:
|
||||||
|
- verificationString
|
||||||
|
responses:
|
||||||
|
'204':
|
||||||
|
description: successful operation
|
||||||
|
'403':
|
||||||
|
description: invalid verification string
|
||||||
|
'404':
|
||||||
|
description: registration not found
|
||||||
|
|
||||||
/api/v1/users/{id}/two-factor/request:
|
/api/v1/users/{id}/two-factor/request:
|
||||||
post:
|
post:
|
||||||
summary: Request two factor auth
|
summary: Request two factor auth
|
||||||
|
@ -1541,18 +1594,6 @@ paths:
|
||||||
'404':
|
'404':
|
||||||
description: user not found
|
description: user not found
|
||||||
|
|
||||||
|
|
||||||
/api/v1/users/ask-send-verify-email:
|
|
||||||
post:
|
|
||||||
summary: Resend user verification link
|
|
||||||
operationId: resendEmailToVerifyUser
|
|
||||||
tags:
|
|
||||||
- Users
|
|
||||||
- Register
|
|
||||||
responses:
|
|
||||||
'204':
|
|
||||||
description: successful operation
|
|
||||||
|
|
||||||
/api/v1/users/me:
|
/api/v1/users/me:
|
||||||
get:
|
get:
|
||||||
summary: Get my user information
|
summary: Get my user information
|
||||||
|
@ -2037,6 +2078,146 @@ paths:
|
||||||
'204':
|
'204':
|
||||||
description: successful operation
|
description: successful operation
|
||||||
|
|
||||||
|
/api/v1/users/register:
|
||||||
|
post:
|
||||||
|
summary: Register a user
|
||||||
|
operationId: registerUser
|
||||||
|
description: Signup has to be enabled and signup approval is not required
|
||||||
|
tags:
|
||||||
|
- Register
|
||||||
|
responses:
|
||||||
|
'204':
|
||||||
|
description: successful operation
|
||||||
|
'400':
|
||||||
|
description: request error
|
||||||
|
'403':
|
||||||
|
description: user registration is not enabled, user limit is reached, registration is not allowed for the ip, requires approval or blocked by a plugin
|
||||||
|
'409':
|
||||||
|
description: 'a user with this username, channel name or email already exists'
|
||||||
|
requestBody:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/RegisterUser'
|
||||||
|
required: true
|
||||||
|
|
||||||
|
/api/v1/users/registrations/request:
|
||||||
|
post:
|
||||||
|
summary: Request registration
|
||||||
|
description: Signup has to be enabled and require approval on the instance
|
||||||
|
operationId: requestRegistration
|
||||||
|
tags:
|
||||||
|
- Register
|
||||||
|
responses:
|
||||||
|
'200':
|
||||||
|
description: successful operation
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/UserRegistration'
|
||||||
|
'400':
|
||||||
|
description: request error or signup approval is not enabled on the instance
|
||||||
|
'403':
|
||||||
|
description: user registration is not enabled, user limit is reached, registration is not allowed for the ip or blocked by a plugin
|
||||||
|
'409':
|
||||||
|
description: 'a user or registration with this username, channel name or email already exists'
|
||||||
|
requestBody:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/UserRegistrationRequest'
|
||||||
|
|
||||||
|
/api/v1/users/registrations/{registrationId}/accept:
|
||||||
|
post:
|
||||||
|
security:
|
||||||
|
- OAuth2:
|
||||||
|
- admin
|
||||||
|
- moderator
|
||||||
|
summary: Accept registration
|
||||||
|
operationId: acceptRegistration
|
||||||
|
tags:
|
||||||
|
- Register
|
||||||
|
parameters:
|
||||||
|
- $ref: '#/components/parameters/registrationId'
|
||||||
|
requestBody:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/UserRegistrationAcceptOrReject'
|
||||||
|
responses:
|
||||||
|
'204':
|
||||||
|
description: successful operation
|
||||||
|
|
||||||
|
/api/v1/users/registrations/{registrationId}/reject:
|
||||||
|
post:
|
||||||
|
security:
|
||||||
|
- OAuth2:
|
||||||
|
- admin
|
||||||
|
- moderator
|
||||||
|
summary: Reject registration
|
||||||
|
operationId: rejectRegistration
|
||||||
|
tags:
|
||||||
|
- Register
|
||||||
|
parameters:
|
||||||
|
- $ref: '#/components/parameters/registrationId'
|
||||||
|
requestBody:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/UserRegistrationAcceptOrReject'
|
||||||
|
responses:
|
||||||
|
'204':
|
||||||
|
description: successful operation
|
||||||
|
|
||||||
|
/api/v1/users/registrations/{registrationId}:
|
||||||
|
delete:
|
||||||
|
security:
|
||||||
|
- OAuth2:
|
||||||
|
- admin
|
||||||
|
- moderator
|
||||||
|
summary: Delete registration
|
||||||
|
description: 'Delete the registration entry. It will not remove the user associated with this registration (if any)'
|
||||||
|
operationId: deleteRegistration
|
||||||
|
tags:
|
||||||
|
- Register
|
||||||
|
parameters:
|
||||||
|
- $ref: '#/components/parameters/registrationId'
|
||||||
|
responses:
|
||||||
|
'204':
|
||||||
|
description: successful operation
|
||||||
|
|
||||||
|
/api/v1/users/registrations:
|
||||||
|
get:
|
||||||
|
security:
|
||||||
|
- OAuth2:
|
||||||
|
- admin
|
||||||
|
- moderator
|
||||||
|
summary: List registrations
|
||||||
|
operationId: listRegistrations
|
||||||
|
tags:
|
||||||
|
- Register
|
||||||
|
parameters:
|
||||||
|
- $ref: '#/components/parameters/start'
|
||||||
|
- $ref: '#/components/parameters/count'
|
||||||
|
- name: search
|
||||||
|
in: query
|
||||||
|
required: false
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
- name: sort
|
||||||
|
in: query
|
||||||
|
required: false
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
enum:
|
||||||
|
- -createdAt
|
||||||
|
- createdAt
|
||||||
|
- state
|
||||||
|
- -state
|
||||||
|
responses:
|
||||||
|
'204':
|
||||||
|
description: successful operation
|
||||||
|
|
||||||
/api/v1/videos/ownership:
|
/api/v1/videos/ownership:
|
||||||
get:
|
get:
|
||||||
summary: List video ownership changes
|
summary: List video ownership changes
|
||||||
|
@ -5389,6 +5570,7 @@ components:
|
||||||
type: string
|
type: string
|
||||||
enum:
|
enum:
|
||||||
- createdAt
|
- createdAt
|
||||||
|
|
||||||
name:
|
name:
|
||||||
name: name
|
name: name
|
||||||
in: path
|
in: path
|
||||||
|
@ -5404,6 +5586,13 @@ components:
|
||||||
description: Entity id
|
description: Entity id
|
||||||
schema:
|
schema:
|
||||||
$ref: '#/components/schemas/id'
|
$ref: '#/components/schemas/id'
|
||||||
|
registrationId:
|
||||||
|
name: registrationId
|
||||||
|
in: path
|
||||||
|
required: true
|
||||||
|
description: Registration ID
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/id'
|
||||||
idOrUUID:
|
idOrUUID:
|
||||||
name: id
|
name: id
|
||||||
in: path
|
in: path
|
||||||
|
@ -7724,6 +7913,7 @@ components:
|
||||||
required:
|
required:
|
||||||
- video
|
- video
|
||||||
- rating
|
- rating
|
||||||
|
|
||||||
RegisterUser:
|
RegisterUser:
|
||||||
properties:
|
properties:
|
||||||
username:
|
username:
|
||||||
|
@ -7754,6 +7944,74 @@ components:
|
||||||
- password
|
- password
|
||||||
- email
|
- email
|
||||||
|
|
||||||
|
UserRegistrationRequest:
|
||||||
|
allOf:
|
||||||
|
- $ref: '#/components/schemas/RegisterUser'
|
||||||
|
- type: object
|
||||||
|
properties:
|
||||||
|
registrationReason:
|
||||||
|
type: string
|
||||||
|
description: reason for the user to register on the instance
|
||||||
|
required:
|
||||||
|
- registrationReason
|
||||||
|
|
||||||
|
UserRegistrationAcceptOrReject:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
moderationResponse:
|
||||||
|
type: string
|
||||||
|
description: Moderation response to send to the user
|
||||||
|
required:
|
||||||
|
- moderationResponse
|
||||||
|
|
||||||
|
UserRegistration:
|
||||||
|
properties:
|
||||||
|
id:
|
||||||
|
$ref: '#/components/schemas/id'
|
||||||
|
state:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
id:
|
||||||
|
type: integer
|
||||||
|
enum:
|
||||||
|
- 1
|
||||||
|
- 2
|
||||||
|
- 3
|
||||||
|
description: 'The registration state (Pending = `1`, Rejected = `2`, Accepted = `3`)'
|
||||||
|
label:
|
||||||
|
type: string
|
||||||
|
registrationReason:
|
||||||
|
type: string
|
||||||
|
moderationResponse:
|
||||||
|
type: string
|
||||||
|
nullable: true
|
||||||
|
username:
|
||||||
|
type: string
|
||||||
|
email:
|
||||||
|
type: string
|
||||||
|
format: email
|
||||||
|
emailVerified:
|
||||||
|
type: boolean
|
||||||
|
accountDisplayName:
|
||||||
|
type: string
|
||||||
|
channelHandle:
|
||||||
|
type: string
|
||||||
|
channelDisplayName:
|
||||||
|
type: string
|
||||||
|
createdAt:
|
||||||
|
type: string
|
||||||
|
format: date-time
|
||||||
|
updatedAt:
|
||||||
|
type: string
|
||||||
|
format: date-time
|
||||||
|
user:
|
||||||
|
type: object
|
||||||
|
nullable: true
|
||||||
|
description: If the registration has been accepted, this is a partial user object created by the registration
|
||||||
|
properties:
|
||||||
|
id:
|
||||||
|
$ref: '#/components/schemas/id'
|
||||||
|
|
||||||
OAuthClient:
|
OAuthClient:
|
||||||
properties:
|
properties:
|
||||||
client_id:
|
client_id:
|
||||||
|
|
Loading…
Reference in a new issue