TopicObject: allOf: - type: object properties: tid: type: number description: A topic identifier uid: type: number description: A user identifier cid: type: number description: A category identifier mainPid: type: number description: The post id of the first post in this topic (also called the "original post") title: type: string slug: type: string timestamp: type: number lastposttime: type: number postcount: type: number viewcount: type: number postercount: type: number teaserPid: oneOf: - type: number - type: string nullable: true upvotes: type: number downvotes: type: number deleted: type: number locked: type: number pinned: type: number description: Whether or not this particular topic is pinned to the top of the category deleterUid: type: number titleRaw: type: string timestampISO: type: string description: An ISO 8601 formatted date string (complementing `timestamp`) lastposttimeISO: type: string votes: type: number category: type: object properties: cid: type: number description: A category identifier name: type: string slug: type: string icon: type: string backgroundImage: nullable: true type: string imageClass: nullable: true type: string bgColor: type: string color: type: string disabled: type: number user: type: object properties: uid: type: number description: A user identifier username: type: string description: A friendly name for a given user account displayname: type: string description: This is either username or fullname depending on forum and user settings fullname: type: string userslug: type: string description: An URL-safe variant of the username (i.e. lower-cased, spaces removed, etc.) reputation: type: number postcount: type: number picture: type: string nullable: true signature: type: string nullable: true banned: type: number status: type: string icon:text: type: string description: A single-letter representation of a username. This is used in the auto-generated icon given to users without an avatar icon:bgColor: type: string description: A six-character hexadecimal colour code assigned to the user. This value is used in conjunction with `icon:text` for the user's auto-generated icon example: "#f44336" banned_until_readable: type: string required: - uid - username - userslug - reputation - postcount - picture - signature - banned - status - icon:text - icon:bgColor - banned_until_readable teaser: type: object properties: pid: type: number uid: type: number description: A user identifier timestamp: type: number tid: type: number description: A topic identifier content: type: string timestampISO: type: string description: An ISO 8601 formatted date string (complementing `timestamp`) user: type: object properties: uid: type: number description: A user identifier username: type: string description: A friendly name for a given user account userslug: type: string description: An URL-safe variant of the username (i.e. lower-cased, spaces removed, etc.) picture: nullable: true type: string icon:text: type: string description: A single-letter representation of a username. This is used in the auto-generated icon given to users without an avatar icon:bgColor: type: string description: A six-character hexadecimal colour code assigned to the user. This value is used in conjunction with `icon:text` for the user's auto-generated icon example: "#f44336" index: type: number nullable: true tags: type: array items: type: object properties: value: type: string valueEscaped: type: string color: type: string bgColor: type: string score: type: number isOwner: type: boolean ignored: type: boolean unread: type: boolean bookmark: nullable: true type: number unreplied: type: boolean icons: type: array items: type: string description: HTML injected into the theme index: type: number - type: object description: Optional properties that may or may not be present (except for `tid`, which is always present, and is only here as a hack to pass validation) properties: tid: type: number description: A topic identifier thumb: type: string required: - tid