Developer Page Specifications
Data Model
10 tables. FounderFileLead is the legal record — never hard-delete, 7-year retention.
مكتمل
10 جداول: FounderFile أساسي + FounderFileLang + 3 جداول فرعية (LearningPoints، BestFor، Artifacts) + 2 جداول join (Authors، Topics) + Sponsor + FounderFileLead + FounderFileReadSession. سجلّ الموافقة على FounderFileLead حامل-للحمل لـ GDPR/PDPL — لا تَحذف أبداً، لا تَتجاوز أبداً.
الجدول 1 · FounderFile (أساسي)
- Id، Slug، Number
- Id (uuid PK)، Slug (varchar(120) unique)، Number (varchar(8)، مثل "FF#04"، مضبوط تلقائياً).
- Category، ReadingTimeMinutes
- Category enum (strategy | operations | fundraising | product | sales | leadership | hiring). ReadingTimeMinutes (int، محتسبة من عدد كلمات الجسم، مُسوَّى للعرض السريع على الكرت).
- CoverImageUrl، SponsorId، IsFeatured، IsActive
- Cover: 3:4 portrait. Sponsor FK nullable (معظم الملفات غير-مدفوعة). IsFeatured يَقود banner B على القائمة.
- DownloadCount
- زيادة ذرّية عند كل POST ناجح لـ /api/founder-files/{id}/leads. يَقود فرز "most-downloaded".
- PublishedAt، CreatedAt، UpdatedAt
- طوابع زمنية قياسية.
الجداول 2-10 · الرفقاء
- FounderFileLang (PK مُرَكَّب FounderFileId + Lang): Title، BestForTagline، Subtitle?، MetaTitle?، MetaDescription?، ReaderBodyHtml (HTML مُعَقَّم).
- FounderFileBestForBullet (FK FounderFileId، DisplayOrder، رفيق lang: Text).
- FounderFileLearningPoint (FK FounderFileId، DisplayOrder، رفيق lang: Text).
- FounderFileArtifact (FK FounderFileId، ArtifactType: pdf | template | checklist | spreadsheet، FileUrl، FileSize، DisplayOrder، lang: Label).
- FounderFileAuthor (join: FounderFileId ↔ FounderId، DisplayOrder).
- FounderFileTopic (join: FounderFileId ↔ TopicCode).
- Sponsor (Id، Name، LogoUrl، Tier: gold/silver/bronze، ContractExpiry، ConsentPartnersWebhookUrl).
- FounderFileLead (Id، FounderFileId، Email، Name، Role، Country، Stage?، ConsentPlatform، ConsentPartners، Source: 'details' | 'reader'، CreatedAt، IpAddress، UserAgent).
- FounderFileReadSession (SessionId، FounderFileId، LeadId?، FirstViewAt، LastViewAt، ScrollDepthPct، CompletedAt?) — تحليلات-فقط، ليست حسّاسة لـ GDPR (مجهولة ما لم يَكن العميل مُرفَق).
