Create / Update Booking [RESTAURANT]

Booking NFT Creation Request

To make your first request, send an authenticated request to the endpoint. This will create a Booking NFT.

Take a look at how you might call this method using the technology of your choice:

const URI = "https://staging-api.takyon.io/v2";

const nftdata = {
  collectionId: "ce2bb8e9-ffde-4138-bc3a-bb00b879e9ec", // or your internal ID
  owner: "cody.martin@gmail.com",
  originalPrice: 599,
  images: [
    "https://www.yourhosting.com/image.png",
    "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAADHQA...",
  ],
  lockDate: "2023-02-14T22:59:00.000Z",
  guests: [
    {
      firstName: "Cody",
      secondName: "Martin",
      email: "cody.martin@gmail.com",
    },
    {
      firstName: "Zac",
      secondName: "Martin",
      email: "zac.martin@gmail.com",
    },
  ],
  lang: "en",
  payload: {
    type: "restaurant",
    restaurant: "Taste Bistro",
    cuisine: "French",
    email: "info@tastebistro.com",
    website: "https://tastebistro.com",
    note: "Include additional information about the restaurant here",
    location: {
      label: "123 Main Street, Anytown, USA",
      value: {
        description: "123 Main Street, Anytown, USA",
        matched_substrings: [{ length: 12, offset: 0 }],
        place_id: "ChIJRQNO6FIUhYgRqvgqaujHZgE",
        reference: "ChIJRQNO6FIUhYgRqvgqaujHZgE",
        structured_formatting: {
          main_text: "123 Main Street",
          main_text_matched_substrings: [{ length: 12, offset: 0 }],
          secondary_text: "Anytown, USA",
        },
        terms: [
          { offset: 0, value: "123 Main Street" },
          { offset: 17, value: "Anytown" },
          { offset: 26, value: "USA" },
        ],
        types: ["route", "geocode"],
      },
    },
    reference: "y789012",
    reservationTime: "2023-03-10T19:30:00.000Z",
    partySize: 4,
    specialRequests: "Vegetarian, gluten-free",
    occasion: "Anniversary",
    michelinStars: 2,
    dressCode: "Business Casual",
    reservationConfirmed: true,
    parking: "Valet Parking Available",
    chefsSpecialties: "Truffle Risotto, Grilled Sea Bass",
    wineList: "Extensive selection of local and international wines",
    tableType: "Window-side",
    extra: "Include additional information about the reservation here",
  },
};

const apikey = "1fed1306-3645-42d0-97d5-a39afa3195fa";

(async () => {
  const rawRes = await fetch(URI + "/nft", {
    method: "post",
    headers: {
      "Content-Type": "application/json",
      API_KEY: apikey,
    },
    body: JSON.stringify(nftdata),
  });

  const res = await rawRes.json();

  console.log(JSON.stringify(res));
})();

To avoid saving the Takyon collection ID in your systems you can set a custom ALIAS in /account/developer.

Keep note that the payload is customizable. We recommend using the structure provided in this example, but is possible to add information with custom keys or avoid some of the fields.

You might want to omit some of the fields of the payload (ex Restaurant Name, location, website ...), since this information will be customizable directly by the Restaurant in the Takyon dashboard and automatically placed inside the reservation.

Update an existent booking

You can update a Booking NFT simply by calling the Create Endpoint and adding "_id" as a parameter of the nftData. You'll get it in the response of the Create Endpoint, after the creation call, and you can store it in your systems. Alternatively, if you don't want to save the "_id" you can also use the same "payload.reference".

Last updated