All Downloads are FREE. Search and download functionalities are using the official Maven repository.

bc_database_scripts.V3.0.0.2023.05.21__Create_database.sql Maven / Gradle / Ivy

Go to download

A Kotlin-first (and Java) framework that makes creating Discord bots a piece of cake, using the JDA library.

The newest version!
---------------------------------------------------- Baseline migration script for BotCommands ---------------------------------------------------
------------ This script is the first version of the database, you can apply this one manually as well as the ones after this version ------------
------------------------------------- The filename scheme should also be compatible with Flyway and Liquibase ------------------------------------

-------------------------------------------------- If you choose to create the database manually -------------------------------------------------
--------------------------------------------------- you will need to create a 'bc' schema first --------------------------------------------------

------------ Base framework

set schema 'bc';

drop table if exists bc_version cascade;

create table bc_version
(
    one_row bool default true,
    version text not null,

    primary key (one_row),
    check (one_row)
);

insert into bc_version
values (true, '3.0.0-alpha.1');

------------ Components

drop table if exists bc_component, bc_component_constraints,
    bc_ephemeral_handler, bc_persistent_handler,
    bc_ephemeral_timeout, bc_persistent_timeout,
    bc_component_component_group cascade;

create table bc_component
(
    component_id   serial   not null,
    component_type smallint not null, -- Can also be a group ! (0)
    lifetime_type  smallint not null,
    one_use        bool     not null,

    primary key (component_id),

    check (component_type between 0 and 2),
    check (lifetime_type between 0 and 1)
);

create table bc_component_constraints
(
    component_id int          not null,
    users        bigint array not null,
    roles        bigint array not null,
    permissions  bigint       not null,

    primary key (component_id),
    foreign key (component_id) references bc_component on delete cascade
);

-- Component types

create table bc_ephemeral_handler
(
    component_id int not null,
    handler_id   int not null,

    primary key (component_id),
    foreign key (component_id) references bc_component on delete cascade
);

create table bc_persistent_handler
(
    component_id int        not null,
    handler_name text       not null,
    user_data    text array not null,

    primary key (component_id),
    foreign key (component_id) references bc_component on delete cascade
);

-- Component timeouts

create table bc_ephemeral_timeout
(
    component_id         int                      not null,
    expiration_timestamp timestamp with time zone not null,
    handler_id           int                      null,

    primary key (component_id),
    foreign key (component_id) references bc_component on delete cascade
);

create table bc_persistent_timeout
(
    component_id         int                      not null,
    expiration_timestamp timestamp with time zone not null,
    handler_name         text                     null,
    user_data            text array               not null,

    primary key (component_id),
    foreign key (component_id) references bc_component on delete cascade
);

-- Group, bc_component can already be a group
-- Associative table
create table bc_component_component_group
(
    group_id     int not null,
    component_id int not null,

    foreign key (group_id) references bc_component on delete cascade,
    foreign key (component_id) references bc_component on delete cascade,
    primary key (group_id, component_id)
);




© 2015 - 2025 Weber Informatics LLC | Privacy Policy