---
title: "Food Establishment Schema"
description: "Use defineFoodEstablishment() to add Restaurant structured data. Display menu, reservations, and cuisine info in Google Maps and local search."
canonical_url: "https://unhead.unjs.io/docs/schema-org/api/schema/food-establishment"
last_updated: "2026-05-06T15:09:34.956Z"
---

## Schema.org FoodEstablishment

**Type**: `defineFoodEstablishment(input?: FoodEstablishment)`

Describes a food-related business.

## Useful Links

- [FoodEstablishment - Schema.org](https://schema.org/FoodEstablishment)

## Required properties

- **name** `string`<br />

The name of the business.
- **address** `AddressInput` - [PostalAddress](https://schema.org/PostalAddress)<br />

Physical postal address of the business.

## Recommended Properties

- **acceptsReservations** `string | boolean`<br />

Indicates whether a FoodEstablishment accepts reservations.
- **hasMenu** `string`<br />

URL of the menu.
- **openingHoursSpecification**  `OpeningHoursInput[]` - [OpeningHoursSpecification](https://schema.org/OpeningHoursSpecification)<br />

The specification for when the business is open.
- **servesCuisine** `string`<br />

The type of cuisine the restaurant serves.

### Minimal Example

```ts
defineFoodEstablishment({
  name: 'test',
  logo: '/logo.png',
  address: {
    addressCountry: 'Australia',
    postalCode: '2000',
    streetAddress: '123 st',
  },
  openingHoursSpecification: [
    {
      dayOfWeek: 'Saturday',
      opens: '09:30',
      closes: '13:30',
    },
    {
      dayOfWeek: ['Monday', 'Tuesday'],
      opens: '10:30',
      closes: '15:30',
    },
  ]
})
```

## Defaults

- **@type**: `FoodEstablishment`
- **@id**: `${canonicalHost}#identity`
- **url**: `${canonicalHost}`
- **currenciesAccepted**: `${options.defaultCurrency}` See [global options](/docs/schema-org/guides/core-concepts/params)

## Sub-Types

- `Bakery`
- `BarOrPub`
- `Brewery`
- `Dentist`
- `CafeOrCoffeeShop`
- `Distillery`
- `FastFoodRestaurant`
- `IceCreamShop`
- `Restaurant`
- `Winery`

## Resolves

See [Global Resolves](/docs/schema-org/guides/get-started/overview#site-page-level-config) for full context.

- `logo` will be resolved from a string into an ImageObject and added to `image`
- `@type` resolve: `Restaurant` -> `['Organization', 'LocalBusiness', 'FoodEstablishment', 'Restaurant']`
- `starRating` will be resolved as a [Rating](https://schema.org/Rating)

## Types

```ts
type ValidFoodEstablishmentSubTypes = 'Bakery'
  | 'BarOrPub'
  | 'Brewery'
  | 'Dentist'
  | 'CafeOrCoffeeShop'
  | 'Distillery'
  | 'FastFoodRestaurant'
  | 'IceCreamShop'
  | 'Restaurant'
  | 'Winery'

export interface FoodEstablishmentSimple extends Omit<LocalBusiness, '@type'> {
  '@type'?: ['Organization', 'LocalBusiness', 'FoodEstablishment'] | ['Organization', 'LocalBusiness', 'FoodEstablishment', ValidFoodEstablishmentSubTypes] | ValidFoodEstablishmentSubTypes
  /**
   * Indicates whether a FoodEstablishment accepts reservations.
   */
  'acceptsReservations'?: string | boolean
  /**
   * URL of the menu.
   */
  'hasMenu'?: string
  /**
   * Methods of payment accepted.
   */
  'paymentAccepted'?: string
  /**
   * The cuisine of the restaurant.
   */
  'servesCuisine'?: string
  /**
   * An official rating for a lodging business or food establishment
   */
  'starRating'?: NodeRelations<Rating>
}
```

## Related Schemas

- [LocalBusiness](/docs/schema-org/api/schema/local-business) - Parent type
- [Organization](/docs/schema-org/api/schema/organization) - Parent organization
- [Event](/docs/schema-org/api/schema/event) - Restaurant events
