database/init/02-ddl/20-amenities.sql

53 lines
2.8 KiB
SQL

-- ****************************************************************************************************
-- * ______ _ _ *
-- * | ____| /\ (_) | | *
-- * | |__ _ _ _ __ ___ _ __ ___ __ _ _ __ / \ _ _ __ _ __ ___ _ __| |_ ___ *
-- * | __|| | | | '__/ _ \| '_ \ / _ \/ _` | '_ \ / /\ \ | | '__| '_ \ / _ \| '__| __/ __| *
-- * | |___| |_| | | | (_) | |_) | __/ (_| | | | | / ____ \| | | | |_) | (_) | | | |_\__ \ *
-- * |______\__,_|_| \___/| .__/ \___|\__,_|_| |_| /_/ \_\_|_| | .__/ \___/|_| \__|___/ *
-- * | | | | *
-- * |_| |_| *
-- * *
-- ****************************************************************************************************
-- This file is part of the European Airports Project, a free, collaborative platform of airport data
-- extending beyond the official AIPs.
-- Copyright (C) 2023
-- Florian Meissner <florianmeissner@gmx.de>
-- This program is free software: you can redistribute it and/or modify it under the
-- terms of the GNU General Public License as published by the Free Software Foundation, either
-- version 3 of the License, or (at your option) any later version. This program is distributed in the
-- hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
-- details. You should have received a copy of the GNU General Public License along with this program.
-- (license.md in the root folder of this project) If not, see <http://www.gnu.org/licenses/>.
USE eaMain;
START TRANSACTION;
CREATE TABLE IF NOT EXISTS `amenities` (
`id` INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
`airport` INT UNSIGNED NOT NULL,
`type` ENUM('CAMP', 'HANG', 'SQ', 'REST', 'SH', 'TIE', 'OTH', 'CUST', 'IM', 'WC')
NOT NULL DEFAULT 'OTH',
`price` DECIMAL(6, 2),
`reportedBy` INT UNSIGNED NOT NULL,
`reportedAt` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP(),
`available` BOOLEAN NOT NULL DEFAULT TRUE,
`contactName` VARCHAR(100),
`contactPhone` VARCHAR(30),
`contactMail` VARCHAR(100),
`contactUrl` VARCHAR(100),
`description` TEXT,
`priorNotice` VARCHAR(20),
CONSTRAINT `amenities.fk_reportedBy` FOREIGN KEY (`reportedBy`) REFERENCES users(id),
CONSTRAINT `amenities.fk_airport` FOREIGN KEY (`airport`) REFERENCES airports(id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
COMMIT;