# community.gifthood.listing

> Published by [gifthood.community](https://lexicon.garden/identity/did:plc:7prvtl4j6wsfmkrfrnwknuxj)

✓ This is the authoritative definition for this NSID.

## Links

- [View on Lexicon Garden](https://lexicon.garden/lexicon/did:plc:7prvtl4j6wsfmkrfrnwknuxj/community.gifthood.listing)
- [Documentation](https://lexicon.garden/lexicon/did:plc:7prvtl4j6wsfmkrfrnwknuxj/community.gifthood.listing/docs)
- [Examples](https://lexicon.garden/lexicon/did:plc:7prvtl4j6wsfmkrfrnwknuxj/community.gifthood.listing/examples)

## Definitions

### `community.gifthood.listing`

**Type**: `record`

An offer or request for a free item, discoverable by approximate location.

**Key**: `tid`

| Property | Type | Required | Description |
|----------|------|----------|-------------|
| `langs` | `array` | No | Language(s) the content is written in, as BCP-47 language tags. Author-asserted; clients default from the composer's locale. |
| `title` | `string` | Yes | Required short title for the item being offered or requested. |
| `facets` | `array` | No | Annotations over `description` (mentions, links) keyed by UTF-8 byte range. Reuses app.bsky.richtext.facet for atmosphere-wide interop. Author-asserted at compose time; clients MUST treat them as display hints, re-validate ranges, and never trust a facet URI over the visible text. Addresses and phone numbers are deliberately NOT faceted here — those affordances are direct-message-only. |
| `images` | `array` | No | Up to 4 images of the item, stored as blobs in the poster's repo. |
| `intent` | `string` | Yes | Whether the poster is giving away an item or looking for one. |
| `labels` | `union` | No | Self-labels set by the author. Used to flag mature/adult content (e.g. the global 'sexual' value), which the AppView gates behind an opt-in. |
| `status` | `string` | No | Current availability. Clients should treat a missing value as 'available'. |
| `geohash` | `string` | Yes | Approximate location as a geohash, precision 6 (~1.2km cell). This is a privacy floor: indexers MUST truncate any finer-precision value to 6 characters before indexing or display. |
| `category` | `string` | No | Optional single-level category for opt-out feed filtering. Append-only enum; unknown or missing values index as 'other'. Never used for proximity or safety logic. |
| `createdAt` | `string` (datetime) | Yes |  |
| `imageAlts` | `array` | No | Alt text for images, parallel to the images array by index. |
| `description` | `string` | Yes | Required free text describing the item being offered or requested. |
| `locationName` | `string` | No | Optional human-readable area name. App-populated via reverse geocoding of the geohash cell. Display only; MUST NOT be used for proximity matching or filtering. |

## Raw Schema

```json
{
  "id": "community.gifthood.listing",
  "defs": {
    "main": {
      "key": "tid",
      "type": "record",
      "record": {
        "type": "object",
        "required": [
          "title",
          "intent",
          "description",
          "geohash",
          "createdAt"
        ],
        "properties": {
          "langs": {
            "type": "array",
            "items": {
              "type": "string",
              "format": "language"
            },
            "maxLength": 3,
            "description": "Language(s) the content is written in, as BCP-47 language tags. Author-asserted; clients default from the composer's locale."
          },
          "title": {
            "type": "string",
            "maxLength": 200,
            "minLength": 1,
            "description": "Required short title for the item being offered or requested.",
            "maxGraphemes": 100,
            "minGraphemes": 1
          },
          "facets": {
            "type": "array",
            "items": {
              "ref": "app.bsky.richtext.facet",
              "type": "ref"
            },
            "description": "Annotations over `description` (mentions, links) keyed by UTF-8 byte range. Reuses app.bsky.richtext.facet for atmosphere-wide interop. Author-asserted at compose time; clients MUST treat them as display hints, re-validate ranges, and never trust a facet URI over the visible text. Addresses and phone numbers are deliberately NOT faceted here — those affordances are direct-message-only."
          },
          "images": {
            "type": "array",
            "items": {
              "type": "blob",
              "accept": [
                "image/jpeg",
                "image/png",
                "image/webp"
              ],
              "maxSize": 1000000
            },
            "maxLength": 4,
            "description": "Up to 4 images of the item, stored as blobs in the poster's repo."
          },
          "intent": {
            "enum": [
              "offer",
              "request"
            ],
            "type": "string",
            "description": "Whether the poster is giving away an item or looking for one."
          },
          "labels": {
            "refs": [
              "com.atproto.label.defs#selfLabels"
            ],
            "type": "union",
            "description": "Self-labels set by the author. Used to flag mature/adult content (e.g. the global 'sexual' value), which the AppView gates behind an opt-in."
          },
          "status": {
            "enum": [
              "available",
              "pending",
              "gone"
            ],
            "type": "string",
            "description": "Current availability. Clients should treat a missing value as 'available'."
          },
          "geohash": {
            "type": "string",
            "maxLength": 6,
            "minLength": 1,
            "description": "Approximate location as a geohash, precision 6 (~1.2km cell). This is a privacy floor: indexers MUST truncate any finer-precision value to 6 characters before indexing or display."
          },
          "category": {
            "enum": [
              "furniture",
              "kitchen",
              "clothing",
              "baby",
              "books",
              "instruments",
              "electronics",
              "tools",
              "garden",
              "health",
              "pets",
              "hobbies",
              "food",
              "animals",
              "service",
              "other"
            ],
            "type": "string",
            "description": "Optional single-level category for opt-out feed filtering. Append-only enum; unknown or missing values index as 'other'. Never used for proximity or safety logic."
          },
          "createdAt": {
            "type": "string",
            "format": "datetime"
          },
          "imageAlts": {
            "type": "array",
            "items": {
              "type": "string",
              "maxGraphemes": 1000
            },
            "maxLength": 4,
            "description": "Alt text for images, parallel to the images array by index."
          },
          "description": {
            "type": "string",
            "maxLength": 3000,
            "minLength": 1,
            "description": "Required free text describing the item being offered or requested.",
            "maxGraphemes": 1500,
            "minGraphemes": 1
          },
          "locationName": {
            "type": "string",
            "maxLength": 300,
            "description": "Optional human-readable area name. App-populated via reverse geocoding of the geohash cell. Display only; MUST NOT be used for proximity matching or filtering.",
            "maxGraphemes": 100
          }
        }
      },
      "description": "An offer or request for a free item, discoverable by approximate location."
    }
  },
  "$type": "com.atproto.lexicon.schema",
  "lexicon": 1
}
```
