İçerik Oluştur
Yeni içerik oluşturur.
Endpoint
POST /api/v1/contents
Authentication
Bu endpoint authentication gerektirir.
Header: Authorization: Bearer \{token\}
Permission
content.create- Tüm içerikleri oluşturmacontent.create.own- Sadece kendi içeriğini oluşturma
Request
Headers
| Header | Değer | Zorunlu |
|---|---|---|
Authorization | Bearer \{token\} | Evet |
Content-Type | application/json | Evet |
Request Body
| Parametre | Tip | Zorunlu | Açıklama |
|---|---|---|---|
title | string | Evet | İçerik başlığı |
slug | string | Hayır | İçerik slug'ı (otomatik oluşturulur) |
content | string | Hayır | İçerik metni |
excerpt | string | Hayır | İçerik özeti |
status | string | Hayır | İçerik durumu (draft, published, archived, varsayılan: "draft") |
type | string | Hayır | İçerik tipi |
is_active | boolean | Hayır | Aktif durumu (varsayılan: true) |
published_at | datetime | Hayır | Yayınlanma tarihi |
Example Request
{
"title": "Örnek İçerik",
"content": "İçerik metni buraya gelir...",
"excerpt": "İçerik özeti",
"status": "draft",
"type": "article",
"is_active": true
}
Response
Success Response (201 Created)
{
"id": 1,
"uuid": "550e8400-e29b-41d4-a716-446655440000",
"title": "Örnek İçerik",
"slug": "ornek-icerik",
"content": "İçerik metni buraya gelir...",
"excerpt": "İçerik özeti",
"status": "draft",
"type": "article",
"is_active": true,
"user_id": 1,
"created_at": "2025-11-20T12:00:00.000000Z",
"updated_at": "2025-11-20T12:00:00.000000Z"
}
Error Responses
403 Forbidden
{
"message": "Forbidden"
}
422 Unprocessable Entity
{
"message": "Validation failed",
"errors": {
"title": ["The title field is required."]
}
}
Code Examples
cURL
curl -X POST https://api.example.com/api/v1/contents \
-H "Authorization: Bearer \{token\}" \
-H "Content-Type: application/json" \
-d '{
"title": "Örnek İçerik",
"content": "İçerik metni buraya gelir...",
"status": "draft"
}'
Notes
.ownpermission'ı olan kullanıcılar içinuser_idotomatik olarak atanırslugbelirtilmemişse başlıktan otomatik oluşturuluris_activedeğeri belirtilmemişse varsayılan olaraktruekullanılırstatusdeğeri belirtilmemişse varsayılan olarak "draft" kullanılır
Related Endpoints
- İçerik Listesi - Tüm içerikleri listele
- İçerik Detayı - İçerik detayını getir