mirror of
https://github.com/HeyPuter/puter.git
synced 2025-01-24 06:50:22 +08:00
3.8 KiB
3.8 KiB
Share Endpoints
Share endpoints allow sharing files with other users.
POST /share
(auth required)
Description
The /share
endpoint shares 1 or more filesystem items
with one or more recipients. The recipients will receive
some notification about the shared item, making this
different from calling /grant-user-user
with a permission.
Example
{
"recipients": [
"user_that_gets_shared_to",
"another@example.com"
],
"shares": [
{
"$": "app-share",
"name": "some-app-name"
},
{
"$": "app-share",
"uid": "app-SOME-APP-UID"
},
{
"$": "fs-share",
"path": "/some/file/or/directory"
},
{
"$": "fs-share",
"path": "SOME-FILE-UUID"
}
]
}
Parameters
- recipients - required
- accepts:
string | Array<string>
- description: recipients for the filesystem entries being shared.
- notes:
- validation on
string
: email or username - requirement of at least one value
- validation on
- accepts:
- shares: - required
- accepts:
object | Array<object>
- object is type-tagged
- type is either file-share or app-share
- notes:
- requirement that file/directory or app exists
- requirement of at least one entry
- accepts:
- dry_run: - optional
- accepts:
bool
- description: when true, only validation will occur
- accepts:
Response
- $:
api:share
- $version:
v0.0.0
- status: one of:
"success"
,"mixed"
,"aborted"
- recipients: array of:
api:status-report
orheyputer:api/APIError
- paths: array of:
api:status-report
orheyputer:api/APIError
- dry_run:
true
if present
Request Example
await fetch("http://puter.localhost:4100/share", {
headers: {
"Content-Type": "application/json",
"Authorization": `Bearer ${puter.authToken}`,
},
body: JSON.stringify({
recipients: [
"user_that_gets_shared_to",
"another@example.com"
],
shares: [
{
$: "app-share",
name: "some-app-name"
},
{
$: "app-share",
uid: "app-SOME-APP-UID"
},
{
$: "fs-share",
path: "/some/file/or/directory"
},
{
$: "fs-share",
path: "SOME-FILE-UUID"
}
]
}),
method: "POST",
});
Success Response
{
"$": "api:share",
"$version": "v0.0.0",
"status": "success",
"recipients": [
{
"$": "api:status-report",
"status": "success"
}
],
"paths": [
{
"$": "api:status-report",
"status": "success"
}
],
"dry_run": true
}
Error response (missing file)
{
"$": "api:share",
"$version": "v0.0.0",
"status": "mixed",
"recipients": [
{
"$": "api:status-report",
"status": "success"
}
],
"paths": [
{
"$": "heyputer:api/APIError",
"code": "subject_does_not_exist",
"message": "File or directory not found.",
"status": 404
}
],
"dry_run": true
}
Error response (missing user)
{
"$": "api:share",
"$version": "v0.0.0",
"status": "mixed",
"recipients": [
{
"$": "heyputer:api/APIError",
"code": "user_does_not_exist",
"message": "The user `non_existing_user` does not exist.",
"username": "non_existing_user",
"status": 422
}
],
"paths": [
{
"$": "api:status-report",
"status": "success"
}
],
"dry_run": true
}