Website Builder API
POST /services/websites/v1/structures/create Auth

Create Structure

Request Body Required

FieldTypeRequiredDescriptionExample
title string
max: 255
Yes Display name of the structure
status string
0, 1
Yes Whether the structure is active (1) or inactive (0)
identifier string
max: 255
Yes Unique slug identifier for the structure type (letters, numbers, underscores, hyphens)
items_per_page integer|null
min: 1
No Number of items to show per page in listings
sort_by string|null
max: 255
No Sort order strategy for items (e.g. created_at_latest, sort_number_lowest)
items_are_pages boolean|null No Whether items in this structure have their own dedicated pages
categories_enabled boolean|null No Whether category grouping is enabled for this structure
default_post_layout_id integer|null No Template layout ID to use by default for item pages
default_category_layout_id integer|null No Template layout ID to use by default for category pages
items_custom_fields_json string|null No JSON schema defining custom fields available on structure items
categories_custom_fields_json string|null No JSON schema defining custom fields available on structure categories

Responses

500
200
422
401
403
429
Internal server error
Headers
HeaderTypeDescriptionExample
X-RateLimit-Limit integer Maximum number of requests allowed per minute 60
X-RateLimit-Remaining integer Number of requests remaining in the current window 57
FieldTypeDescription
error boolean
message string
data mixed[]
Successful response
Headers
HeaderTypeDescriptionExample
X-RateLimit-Limit integer Maximum number of requests allowed per minute 60
X-RateLimit-Remaining integer Number of requests remaining in the current window 57
FieldTypeDescription
structures object
structures.id integer
Validation error
FieldTypeDescription
message string Errors overview.
errors object A detailed description of each field that failed validation.
Unauthenticated — missing or invalid Bearer token
Headers
HeaderTypeDescriptionExample
X-RateLimit-Limit integer Maximum number of requests allowed per minute 60
X-RateLimit-Remaining integer Number of requests remaining in the current window 57
FieldTypeDescription
error boolean
message string
Forbidden — insufficient permissions for this resource
Headers
HeaderTypeDescriptionExample
X-RateLimit-Limit integer Maximum number of requests allowed per minute 60
X-RateLimit-Remaining integer Number of requests remaining in the current window 57
FieldTypeDescription
error boolean
message string
Too Many Requests — rate limit exceeded
Headers
HeaderTypeDescriptionExample
X-RateLimit-Limit integer Maximum number of requests allowed per minute 60
X-RateLimit-Remaining integer Number of requests remaining in the current window 57
Retry-After integer Seconds until the rate limit resets 60
FieldTypeDescription
error boolean
message string
Base URL
https://api.wemasy.nl/api
Authentication

Request Sample
cURL
JS
PHP
Python
curl -X POST "https://api.wemasy.nl/api/services/websites/v1/structures/create" \
  -H "Authorization: Bearer YOUR_API_TOKEN" \
  -H "Accept: application/json" \
  -H "Content-Type: application/json" \
  -d '{
    "title": "string",
    "status": "string",
    "identifier": "string",
    "items_per_page": "string",
    "sort_by": "string",
    "items_are_pages": "string",
    "categories_enabled": "string",
    "default_post_layout_id": "string",
    "default_category_layout_id": "string",
    "items_custom_fields_json": "string",
    "categories_custom_fields_json": "string"
}'
fetch('https://api.wemasy.nl/api/services/websites/v1/structures/create', {
  method: 'POST',
  headers: {
    'Authorization': 'Bearer YOUR_API_TOKEN',
    'Accept': 'application/json',
    'Content-Type': 'application/json'
  },
  body: JSON.stringify({
    "title": "string",
    "status": "string",
    "identifier": "string",
    "items_per_page": "string",
    "sort_by": "string",
    "items_are_pages": "string",
    "categories_enabled": "string",
    "default_post_layout_id": "string",
    "default_category_layout_id": "string",
    "items_custom_fields_json": "string",
    "categories_custom_fields_json": "string"
})})
.then(r => r.json())
.then(data => console.log(data));
$response = Http::withToken('YOUR_API_TOKEN')
    ->accept('application/json')
    ->post('https://api.wemasy.nl/api/services/websites/v1/structures/create', {
    "title": "string",
    "status": "string",
    "identifier": "string",
    "items_per_page": "string",
    "sort_by": "string",
    "items_are_pages": "string",
    "categories_enabled": "string",
    "default_post_layout_id": "string",
    "default_category_layout_id": "string",
    "items_custom_fields_json": "string",
    "categories_custom_fields_json": "string"
});
$data = $response->json();
import requests

headers = {
    "Authorization": "Bearer YOUR_API_TOKEN",
    "Accept": "application/json"
}
data = {
    "title": "string",
    "status": "string",
    "identifier": "string",
    "items_per_page": "string",
    "sort_by": "string",
    "items_are_pages": "string",
    "categories_enabled": "string",
    "default_post_layout_id": "string",
    "default_category_layout_id": "string",
    "items_custom_fields_json": "string",
    "categories_custom_fields_json": "string"
}
r = requests.post("https://api.wemasy.nl/api/services/websites/v1/structures/create", headers=headers, json=data)
print(r.json())
Response Example
{
    "structures": {
        "id": 0
    }
}

Try It
Request Body Required

Export