Skip to main content

List Writers

Returns a paginated list of root writers for a project. Writers represent songwriters and composers extracted from contract documents.

Request

GET /v1/writers

Query Parameters

ParameterTypeRequiredDefaultDescription
projectIdUUIDYesThe project to list writers for
pageintegerNo1Page number (1-indexed)
perPageintegerNo20Items per page (1–100)
includeMergedstringNofalseSet to true to include merged writers for each root writer

Headers

HeaderRequiredDescription
AuthorizationYesBearer <token> — must be scoped to the requested project

Response

{
  "data": [
    {
      "id": "writer-1",
      "name": "Max Martin",
      "project_id": "a1b2c3d4-e5f6-7890-abcd-ef1234567890",
      "merged": [
        { "id": "writer-2", "name": "Martin Sandberg" }
      ]
    }
  ]
}
The merged array only appears when includeMerged=true.

Errors

StatusDescription
400Missing projectId or invalid query parameters
403Token is not scoped to the requested project

Example

curl "https://api.royaltyport.com/v1/writers?projectId=a1b2c3d4-...&page=1&perPage=50" \
  -H "Authorization: Bearer rp_your_token_here"

Get Writer

Returns a single writer by ID.

Request

GET /v1/writers/{writer_id}

Path Parameters

ParameterTypeRequiredDescription
writer_idstringYesThe writer ID

Query Parameters

ParameterTypeRequiredDefaultDescription
projectIdUUIDYesThe project the writer belongs to
includeMergedstringNofalseSet to true to include merged writers

Headers

HeaderRequiredDescription
AuthorizationYesBearer <token> — must be scoped to the requested project

Response

{
  "data": {
    "id": "writer-1",
    "name": "Max Martin",
    "project_id": "a1b2c3d4-e5f6-7890-abcd-ef1234567890",
    "merged": [
      { "id": "writer-2", "name": "Martin Sandberg" }
    ]
  }
}

Errors

StatusDescription
400Missing projectId
403Token is not scoped to the requested project
404Writer not found

Example

curl "https://api.royaltyport.com/v1/writers/writer-1?projectId=a1b2c3d4-..." \
  -H "Authorization: Bearer rp_your_token_here"