Was this helpful?

Working with the Australian Tourism Data Warehouse (ATDW)

The Alpaca GraphQL API allows you to connect to ATDW in a single integration, accessing product information as well as performing search, and adding those products to your own collection. In addition to loading the information from ATDW, you can add your own tags, categories and other attributes to the data. You can also put ATDW data into Itineraries, to form itineraries that are kept up to date with information from organisations that update when data in ATDW updates.

Alpaca provide an integration directly into the Australian Tourism Data Warehouse (ATDW) to enable you to leverage their API and service for information about Australian tourism products.

This information becomes easily accessible to drive your place database or be integrated seemlessly into lists, itineraries and more. Leveraging the Alpaca API, information accessed from the ATDW will be sync'd refreshed automatically, saving you the need to write additional integrations.

The Australian Tourism Data Warehouse, commonly shortenned to ATDW, is a private company owned by the state tourism bodies, and offers servies for Australian Tourism Operators to offer information about their products to distributors. With an ATDW distributor agreement, you can access a wealth of information about different tourism operators in Australia. This information is encouraged to be kept up to date, as it is used by the state tourism providers, RTO's and other commercial distributors to list information about the business.

Prerequisites

  • Your ATDW API Key has been associated with your profile (connect application)

  • You have your Alpaca API Key for querying GraphQL

Place Identification

The Australian Tourism Data Warehouse (ATDW) uses a unique product ID to reference different products on their platform. These product IDs are a string of characters that look like "5cae80be57a096cd7084b6ab".

These product IDs can be used to retrieve information for different types of content on the ATDW such as:

  • Accommodation

  • Attractions

  • Events

  • Tours

To reference an ATDW place in the Alpaca platform, you will need to use the format place/atdw:product:<product_id>, where <product_id> is the product ID of the place you want to reference. For example, to reference the ATDW place with the product ID "5cae80be57a096cd7084b6ab", you would use the identifier "place/atdw:product:5cae80be57a096cd7084b6ab" in the Alpaca platform.

place/atdw:product:<product_id>

Please note that Alpaca also supports other place providers such as Facebook and OpenStreetMap, each one of them has their unique identifier format.

1# Load information about a winery from Australian Tourism Data Warehouse
2
3query GetWinery {
4  # use the place() query to load information about a specific winery
5  place(id: "place/atdw:product:5732b88b19f4a4ae38aa1974") {
6    # Identifiers/Type
7    id
8    __typename
9
10    # Basic information
11    name
12    description
13
14    # Various contact methods for the place
15    contact {
16      facebookUrl
17      twitterUrl
18      instagramUrl
19      bookingUrl
20    }
21
22    # Images
23    images: mediaContainers(first: 3) {
24      nodes {
25        resource {
26          ... on MediaImage {
27            url(bestFit: [200, 200])
28            copyright
29            attribution
30            caption
31          }
32        }
33      }
34    }
35
36    # Source and Attribution
37    contributor
38
39    # Required attribution/tracking for the place for ATDW
40    attribution {
41      pixel
42    }
43
44    # Address Information
45    address {
46      addressLineOne
47      locality
48      region
49      postalCode
50    }
51
52    # Geo Coordinates
53    position {
54      lon
55      lat
56    }
57
58    # Layers/Categories
59    layers {
60      name
61    }
62
63    # Wine specific attributes...
64    # There are many attributes that can be obtain about places which we have
65    # catalogued, this example draws from specific wine information
66    # Wine Varieties
67    wineVarieties: attr(id: "place/wine-varieties") {
68      value
69    }
70    # Wine Alternative Styles
71    wineAlternativeStyles: attr(id: "place/wine-alternative-styles") {
72      value
73    }
74    # Wine Viticultural Practices
75    wineViticulturalPractices: attr(
76      id: "place/winemaking-viticultural-practices"
77    ) {
78      value
79    }
80    # Wine Regions
81    wineRegions: attr(id: "place/wine-regions") {
82      value
83    }
84    # Some additional...
85    # Accreditations for Venue
86    accreditations: attr(id: "place/accreditations") {
87      value
88    }
89    # Cuisine Types
90    cuisineTypes: attr(id: "place/cuisine-types") {
91      value
92    }
93    # Accessibility
94    accessibility: attr(id: "place/accessible-comment") {
95      value
96    }
97  }
98}

Sandbox: Configure | Try Operation

Example Response

1{
2  "data": {
3    "place": {
4      "id": "place/atdw:product:5732b88b19f4a4ae38aa1974",
5      "__typename": "Place",
6      "name": "Heathcote Winery",
7      "description": "<p>Heathcote Winery is one of the pioneer wineries of the Heathcote Region and has established a reputation as one of the icon wineries of the Region.</p><p>Heathcote Winery specialises in the production of Shiraz and has a  premium range of wines sourced entirely from estate vineyards. The Mail Coach Shiraz, upon which Heathcote Winery has built its reputation, delivers a quintessential Heathcote Shiraz that is the envy of many other producers. Three single vineyard wines, the Slaughterhouse Paddock Shiraz, The Origin Shiraz, and Heathcote Winery's signature wine The Wilkins Shiraz complete the super premium range</p><p>Tastings at Heathcote Winery are free and also include the estate Vermentino, Viognier, Grenache Rose and an enticing Fortified Shiraz, the Slaughterfied, to complete the experience.</p><p>The unique Cellar Door  in Heathcote's Main Street is open seven days a week and light fare to compliment the wines is available on weekends and public holidays.</p>",
8      "contact": {
9        "facebookUrl": "http://www.facebook.com/heathcotewinery/",
10        "twitterUrl": "https://twitter.com/heathcotewinery",
11        "instagramUrl": "https://www.instagram.com/heathcotewinery",
12        "bookingUrl": null
13      },
14      "images": {
15        "nodes": ...
16      },
17      "attribution": [
18        {
19          "pixel": "https://atlas.atdw-online.com.au/pixel?productId=5732b88b19f4a4ae38aa1974&distributorId={distributorId}&language=ENGLISH&syndicationMethod=API"
20        }
21      ],
22      "address": {
23        "addressLineOne": "185 High Street",
24        "locality": "Heathcote",
25        "region": "Victoria",
26        "postalCode": "3523"
27      },
28      "position": {
29        "lon": 144.70510430000002,
30        "lat": -36.9188535
31      },
32      "layers": [
33        {
34          "name": "Food and Drink"
35        },
36        {
37          "name": "Wineries"
38        }
39      ],
40      "wineVarieties": {
41        "value": [
42          {
43            "type": "Red wines",
44            "varieties": ["Shiraz / Syrah"]
45          },
46          {
47            "type": "White wines",
48            "varieties": ["Vermentino", "Viognier"]
49          },
50          {
51            "type": "Fortified Wine",
52            "varieties": ["Vintage Fortified"]
53          }
54        ]
55      },
56      "wineAlternativeStyles": {
57        "value": ["Vegan or Vegetarian Wine"]
58      },
59      "wineViticulturalPractices": {
60        "value": [
61          "Hand-picked",
62          "Single Vineyard",
63          "Estate Grown",
64          "Family Run"
65        ]
66      },
67      "wineRegions": {
68        "value": ["Heathcote", "Central Victoria (zone)"]
69      },
70      "accreditations": {
71        "value": ["Quality Tourism Accreditation"]
72      },
73      "cuisineTypes": {
74        "value": ["Australian", "Light Meals", "Share Plates"]
75      },
76      "accessibility": {
77        "value": "Caters for people who use a wheelchair. Caters for people with sufficient mobility to climb a few steps but who would benefit from fixtures to aid balance. (This includes people using walking frames and mobility aids)"
78      }
79    }
80  }
81}

You can also find all the attributes that are available for a location with the following query:

1query {
2  place(id: "place/atdw:product:5732b88b19f4a4ae38aa1974") {
3    id
4
5    # Load the first 30 attributes for the product
6    attrs(first: 30) {
7      edges {
8        node {
9          id
10          value
11        }
12      }
13    }
14  }
15}

Sandbox: Configure | Try Operation

Position Attributes

Alpaca offers a additional attributes that can be used to enhance the data available about a location.

1query GetPlace {
2  place(id: "place/atdw:product:5732b88b19f4a4ae38aa1974") {
3    position {
4      lon
5      lat
6
7      # Access the timezone at the coordinate
8      timezone: attrValue(id: "place/time-zone")
9
10      # Further information, such as regions..
11      iso3166: attrValue(id: "place/iso-3166-2")
12
13      # Australian information, such as locality, gov, etc
14      locality: attrValue(id: "place/abs:locality")
15      lga: attrValue(id: "place/abs:local-government-area")
16      electoral: attrValue(id: "place/abs:commonwealth-electoral-division")
17      tourismRegion: attrValue(id: "place/abs:tourism-region")
18    }
19  }
20}

Sandbox: Configure | Try Operation

The response if successful will look like the following:

1{
2  "data": {
3    "place": {
4      "position": {
5        "lon": 144.70510430000002,
6        "lat": -36.9188535,
7        "timezone": "UTC+10:00",
8        "iso3166": "AU-VIC",
9        "locality": "Heathcote (Vic.)",
10        "lga": "Greater Bendigo (C)",
11        "electoral": "Euroa (Northern Victoria)",
12        "tourismRegion": "Bendigo Loddon"
13      }
14    }
15  }
16}

Opening Hours

Where opening hours are available, you can use the Alpaca platform to interpret and display opening hours of locations.

  • Search for a upcoming or future range

  • Localise the hours to a different timezone

  • Identify public holidays that could affect opening hours

  • Change the format and display for dates and times

Alpaca also offers the inclusion of Public Holidays in order to flag to users of your website or application that they may have affected operating hours due to local observed public holidays.

1# Obtain the open/closed hours for the place given a period, such as the
2# upcoming week or future date range. Includes information on local public
3# holidays that could affect opening hours.
4
5query QueryDateRangeOpenClosedTimes($placeId: ID!) {
6  # Use the place() operation
7  place(id: $placeId) {
8    # Access the opening hours (where specified)
9    hours {
10      # Use the forDays operation to obtain days across a range of dates. By
11      # default, without any arguments the next 7 days will be selected. You
12      # can change the range by specifying an alternative offset (which allows
13      # you to specify values like { days: 14 }) or provide a specific start and
14      # end dates (as ISO-8601 date strings)
15      forDays {
16        # Date/day, as ISO-8601, or as formatted for presentation using the
17        # Unicode Technical Standard #35 Date Field Symbols
18        date(format: "EEE, MMM d")
19        # Whether there is a public holiday for this date detected for this
20        # region on this date
21        publicHolidays
22        # Obtain the intervals for this date, requesting the opening status
23        # status is optional, otherwise use Open/Closed to specify your pref
24        intervals(status: Open) {
25          # Hours, from/to as ISO-8601 string, or formatted using the Unicode
26          # Technical Standard #35 Date Field Symbols
27          from(format: "h:mm a")
28          to(format: "h:mm a")
29          # Status (Open/Closed)
30          status
31          # Any corresponding comment for the opening hours
32          comment
33        }
34      }
35    }
36  }
37}

Sandbox: Configure | Try Operation

1{
2  "data": {
3    "place": {
4      "hours": {
5        "forDays": [
6          {
7            "date": "Mon, Jan 23",
8            "publicHolidays": [],
9            "intervals": [
10              {
11                "from": "7:00 AM",
12                "to": "3:30 PM",
13                "status": "Open",
14                "comment": null
15              }
16            ]
17          },
18          {
19            "date": "Tue, Jan 24",
20            "publicHolidays": [],
21            "intervals": [
22              {
23                "from": "7:00 AM",
24                "to": "3:30 PM",
25                "status": "Open",
26                "comment": null
27              }
28            ]
29          },
30          {
31            "date": "Wed, Jan 25",
32            "publicHolidays": [],
33            "intervals": [
34              {
35                "from": "7:00 AM",
36                "to": "3:30 PM",
37                "status": "Open",
38                "comment": null
39              }
40            ]
41          },
42          {
43            "date": "Thu, Jan 26",
44            "publicHolidays": ["Australia Day"],
45            "intervals": [
46              {
47                "from": "7:00 AM",
48                "to": "3:30 PM",
49                "status": "Open",
50                "comment": null
51              }
52            ]
53          },
54          {
55            "date": "Fri, Jan 27",
56            "publicHolidays": [],
57            "intervals": [
58              {
59                "from": "7:00 AM",
60                "to": "3:30 PM",
61                "status": "Open",
62                "comment": null
63              }
64            ]
65          },
66          {
67            "date": "Sat, Jan 28",
68            "publicHolidays": [],
69            "intervals": [
70              {
71                "from": "8:00 AM",
72                "to": "3:30 PM",
73                "status": "Open",
74                "comment": null
75              }
76            ]
77          },
78          {
79            "date": "Sun, Jan 29",
80            "publicHolidays": [],
81            "intervals": [
82              {
83                "from": "9:00 AM",
84                "to": "3:30 PM",
85                "status": "Open",
86                "comment": null
87              }
88            ]
89          }
90        ]
91      }
92    }
93  }
94}

Searching for Places

You can also leverage the place search capabilities of the API by specifying the sources as AustralianTourismDataWarehouse.

1# Search the Australian Tourism Data Warehouse (ATDW) for places using an
2# autocomplete style text query. Search includes highlighting for results
3# and summarising places into 2 main/secondary labels
4
5query SearchPlaceAutocompleteFromATDW {
6  # use the placeAutocompleteSearch operation to query ATDW
7  placeAutocompleteSearch(
8    text: "Heathcote Winery"
9    # Supply Australian Tourism Data Warehouse as source
10    sources: AustralianTourismDataWarehouse
11    # Provide the max number of records to return (differs by provider)
12    first: 5
13  ) {
14    edges {
15      node {
16        # Place Identifier/types
17        id
18        __typename
19        # obtain place information here...
20      }
21      # Autocomplete Matching
22      # Main label for place
23      main {
24        label
25        # Text matching for text highlighting on result
26        matches {
27          offset
28          length
29        }
30      }
31      # Secondary label for place (additional supporting text, 2nd line text)
32      secondary {
33        label
34        # Text maching for text highlighting on result
35        matches {
36          offset
37          length
38        }
39      }
40    }
41  }
42}

Sandbox: Configure | Try Operation

1{
2  "data": {
3    "placeAutocompleteSearch": {
4      "edges": [
5        {
6          "node": {
7            "id": "place/atdw:product:5732b88b19f4a4ae38aa1974",
8            "__typename": "PlaceSearchNode"
9          },
10          "main": {
11            "label": "Heathcote Winery",
12            "matches": [
13              {
14                "offset": 0,
15                "length": 9
16              },
17              {
18                "offset": 10,
19                "length": 6
20              }
21            ]
22          },
23          "secondary": {
24            "label": "185 High Street, Heathcote",
25            "matches": [
26              {
27                "offset": 17,
28                "length": 9
29              }
30            ]
31          }
32        },
33        {
34          "node": {
35            "id": "place/atdw:product:56b250842661405945694454",
36            "__typename": "PlaceSearchNode"
37          },
38          "main": {
39            "label": "Sanguine Estate",
40            "matches": []
41          },
42          "secondary": {
43            "label": "77 Shurans Lane, Heathcote",
44            "matches": [
45              {
46                "offset": 17,
47                "length": 9
48              }
49            ]
50          }
51        },
52        {
53          "node": {
54            "id": "place/atdw:product:56b250aeb042386245d58980",
55            "__typename": "PlaceSearchNode"
56          },
57          "main": {
58            "label": "Heathcote",
59            "matches": [
60              {
61                "offset": 0,
62                "length": 9
63              }
64            ]
65          },
66          "secondary": {
67            "label": "VIC, Australia",
68            "matches": []
69          }
70        },
71        {
72          "node": {
73            "id": "place/atdw:product:56b25647b042386245d5d30f",
74            "__typename": "PlaceSearchNode"
75          },
76          "main": {
77            "label": "Domaine Asmara",
78            "matches": []
79          },
80          "secondary": {
81            "label": "61 Gibb Road, Toolleen, VIC",
82            "matches": []
83          }
84        },
85        {
86          "node": {
87            "id": "place/atdw:product:56b24d2b2661405945690da5",
88            "__typename": "PlaceSearchNode"
89          },
90          "main": {
91            "label": "Munari Wines",
92            "matches": []
93          },
94          "secondary": {
95            "label": "1129 Northern Hwy, Heathcote",
96            "matches": [
97              {
98                "offset": 19,
99                "length": 9
100              }
101            ]
102          }
103        }
104      ]
105    }
106  }
107}

Creating an Itinerary Location with a reference to ATDW

If you are creating an itinerary (or list of saved places), you can supply the reference to the product when creating the itinerary location.

You can see further examples of how to work with itineraries by visiting our sections about Itineraries.

1# Add a location to our itinerary, associating the place to Mavis The Grocer
2# using the ATDW Product identifier. Once the location is added to the
3# itinerary, we query back the create items on the itinerary.
4
5mutation CreateItineraryLocationWithAtdwPlace {
6  # Use the createItineraryLocation mutation operation
7  createItineraryLocation(
8    # Supply our Itinerary to add the item to
9    itineraryId: "itinerary/ABC123"
10    # Describe the location
11    location: {
12      # Provide some optional content to personalise the itinerary
13      title: "Grab a coffee"
14      synopsis: "Nearby, we can find Mavis the Grocer open most days"
15      # Link the location to a known place
16      place: {
17        # Referencing the place from ATDW
18        id: "place/atdw:product:5cae80be57a096cd7084b6ab"
19        # Providing the position lon/lat
20        position: { lon: 144.9970825017, lat: -37.8030584810 }
21      }
22    }
23  ) {
24    # Select what we need from the itinerary or the result of the operation
25    cascaded {
26      created {
27        # Access the itinerary location ID as needed
28        __typename
29        id
30      }
31    }
32  }
33}

Sandbox: Configure | Try Operation

Creating a Collection Location with a reference to ATDW

If you are creating a collection containing ATDW products, you can supply the place id to collection locations.

1# Creates a Collection Location within a collection
2
3mutation CreateCollectionLocation {
4  # use createCollectionLocation for this operation
5  createCollectionLocation(
6    # Supply the collection to place the collection location within
7    collectionId: "collection/ABC123"
8    # Supply the data for the location model
9    location: {
10      # Provide content for the collection item
11      # Synopsis, tags, description, media, website etc.
12      title: "Mavis the Grocer"
13      # Supply tags (we can later query on this)
14      tags: ["cafe"]
15      # Note: See external refs/source if you want to store your own identifiers
16      # Provide a reference to the place/position for the place location
17      place: {
18        id: "place/atdw:product:5cae80be57a096cd7084b6ab"
19        position: { lon: 144.9970825017, lat: -37.803058481 }
20      }
21    }
22  ) {
23    location {
24      # Returns with the collection location just created
25      id
26      __typename
27    }
28  }
29}

Sandbox: Configure | Try Operation

alpaca.tech

Copyright © 2025 - Made with love ❤️ in Australia.