Create workspace asset upload ​
POST/api/v1/workspaces/{slug}/assets/
Generate presigned URL for generic asset upload
Path Parameters ​
slug:requiredstringWorkspace slug
Body Parameters ​
name:requiredstringOriginal filename of the asset
type:optionalstringMIME type of the file
size:requiredintegerFile size in bytes
project_id:optionalstringUUID of the project to associate with the asset
external_id:optionalstringExternal identifier for the asset (for integration tracking)
external_source:optionalstringExternal source system (for integration tracking)
Scopes ​
assets:write
Create workspace asset upload
bash
curl -X POST \
"https://api.plane.so/api/v1/workspaces/my-workspace/assets/" \
-H "X-API-Key: $PLANE_API_KEY" \
# Or use -H "Authorization: Bearer $PLANE_OAUTH_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"name": "Example Name",
"type": "image/jpeg",
"size": 1024000,
"project_id": "550e8400-e29b-41d4-a716-446655440000",
"external_id": "550e8400-e29b-41d4-a716-446655440000",
"external_source": "github"
}'python
import requests
response = requests.post(
"https://api.plane.so/api/v1/workspaces/my-workspace/assets/",
headers={"X-API-Key": "your-api-key"},
json={
"name": "Example Name",
"type": "image/jpeg",
"size": 1024000,
"project_id": "550e8400-e29b-41d4-a716-446655440000",
"external_id": "550e8400-e29b-41d4-a716-446655440000",
"external_source": "github"
}
)
print(response.json())javascript
const response = await fetch("https://api.plane.so/api/v1/workspaces/my-workspace/assets/", {
method: "POST",
headers: {
"X-API-Key": "your-api-key",
"Content-Type": "application/json",
},
body: JSON.stringify({
name: "Example Name",
type: "image/jpeg",
size: 1024000,
project_id: "550e8400-e29b-41d4-a716-446655440000",
external_id: "550e8400-e29b-41d4-a716-446655440000",
external_source: "github",
}),
});
const data = await response.json();Response200
json
{
"asset_id": "550e8400-e29b-41d4-a716-446655440000",
"asset_url": "/api/assets/v2/workspaces/my-workspace/projects/None/issues/None/attachments/550e8400-e29b-41d4-a716-446655440000/",
"upload_data": {
"url": "https://uploads.example.com/plane-bucket",
"fields": {
"Content-Type": "image/png",
"key": "workspace-assets/550e8400-e29b-41d4-a716-446655440000/workspace-image.png",
"x-amz-algorithm": "AWS4-HMAC-SHA256",
"x-amz-credential": "example/20240101/us-east-1/s3/aws4_request",
"x-amz-date": "20240101T000000Z",
"policy": "example-policy",
"x-amz-signature": "example-signature"
}
}
}
