TopicObject:
  allOf:
    - $ref: '#/TopicObjectSlim'
    - type: object
      properties:
        lastposttime:
          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
    - 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
        pinExpiry:
          type: number
          description: A UNIX timestamp indicating when a pinned topic will no longer be pinned (i.e. the pin has expired)
        pinExpiryISO:
          type: string
          description: "`pinExpiry` rendered as an ISO 8601 format"
        index:
          type: number
      required:
        - tid
TopicObjectSlim:
  description: The output of a call to `Topics.getTopicField`, these properties are always present no matter the fields passed in
  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
        title:
          type: string
        slug:
          type: string
        mainPid:
          type: number
          description: The post id of the first post in this topic (also called the "original post")
        postcount:
          type: number
        viewcount:
          type: number
        postercount:
          type: number
        scheduled:
          type: number
        deleted:
          type: number
        deleterUid:
          type: number
        titleRaw:
          type: string
        locked:
          type: number
        pinned:
          type: number
          description: Whether or not this particular topic is pinned to the top of the
            category
        timestamp:
          type: number
        timestampISO:
          type: string
          description: An ISO 8601 formatted date string (complementing `timestamp`)
        lastposttime:
          type: number
        lastposttimeISO:
          type: string
          description: An ISO 8601 formatted date string (complementing `lastposttime`)
        pinExpiry:
          type: number
          description: A UNIX timestamp indicating when a pinned topic will no longer be pinned (i.e. the pin has expired)
        pinExpiryISO:
          type: string
          description: "`pinExpiry` rendered as an ISO 8601 format"
        upvotes:
          type: number
        downvotes:
          type: number
        votes:
          type: number
        teaserPid:
          oneOf:
            - type: number
            - type: string
          nullable: true
        thumbs:
          type: array
          items:
            type: object
            properties:
              id:
                type: number
                description: The topic id
              name:
                type: string
                description: The topic thumbnail filename
              url:
                type: string
                description: Relative path to the topic thumbnail
    - 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
        numThumbs:
          type: number
          description: The number of thumbnails associated with this topic
      required:
        - tid