From 096231d00e766c5d45e8975f4cec21c41a50ec2e Mon Sep 17 00:00:00 2001 From: Chocobozzz Date: Thu, 22 Apr 2021 11:42:51 +0200 Subject: [PATCH] Add auth header in plugins guide --- .../plugins/register-server-option.model.ts | 4 +++ support/doc/plugins/guide.md | 27 ++++++++++++++++++- 2 files changed, 30 insertions(+), 1 deletion(-) diff --git a/server/types/plugins/register-server-option.model.ts b/server/types/plugins/register-server-option.model.ts index 1b9250ce4..4af476ed2 100644 --- a/server/types/plugins/register-server-option.model.ts +++ b/server/types/plugins/register-server-option.model.ts @@ -58,14 +58,18 @@ export type PeerTubeHelpers = { } plugin: { + // PeerTube >= 3.2 getBaseStaticRoute: () => string + // PeerTube >= 3.2 getBaseRouterRoute: () => string + // PeerTube >= 3.2 getDataDirectoryPath: () => string } user: { + // PeerTube >= 3.2 getAuthUser: (response: Response) => { id?: string username: string diff --git a/support/doc/plugins/guide.md b/support/doc/plugins/guide.md index 36ade117b..a90f8e72b 100644 --- a/support/doc/plugins/guide.md +++ b/support/doc/plugins/guide.md @@ -20,6 +20,7 @@ - [Plugin static route](#plugin-static-route) - [Notifier](#notifier) - [Markdown Renderer](#markdown-renderer) + - [Auth header](#auth-header) - [Custom Modal](#custom-modal) - [Translate](#translate) - [Get public settings](#get-public-settings) @@ -203,7 +204,7 @@ function register ({ } ``` -You can also store files in the plugin data directory (`/{plugins-directory}/data/{npm-plugin-name}`). +You can also store files in the plugin data directory (`/{plugins-directory}/data/{npm-plugin-name}`) **in PeerTube >= 3.2**. This directory and its content won't be deleted when your plugin is uninstalled/upgraded. ```js @@ -526,6 +527,30 @@ function register (...) { } ``` +#### Auth header + +**PeerTube >= 3.2** + +To make your own HTTP requests using the current authenticated user, use an helper to automatically set appropriate headers: + +```js +function register (...) { + registerHook({ + target: 'action:auth-user.information-loaded', + handler: ({ user }) => { + + // Useless because we have the same info in the ({ user }) parameter + // It's just an example + fetch('/api/v1/users/me', { + method: 'GET', + headers: peertubeHelpers.getAuthHeader() + }).then(res => res.json()) + .then(data => console.log('Hi %s.', data.username)) + } + }) +} +``` + #### Custom Modal To show a custom modal: