initial commit. Cloned timetracker repository

This commit is contained in:
Daniel Goc
2026-03-10 09:02:57 +01:00
commit f2952bcef0
189 changed files with 21334 additions and 0 deletions

View File

@@ -0,0 +1,122 @@
-- +goose Up
CREATE TABLE IF NOT EXISTS "public"."language" (
"id" SERIAL,
"created_at" TIMESTAMP WITH TIME ZONE NOT NULL,
"updated_at" TIMESTAMP WITH TIME ZONE NULL,
"deleted_at" TIMESTAMP WITH TIME ZONE NULL,
"name" VARCHAR(128) NOT NULL,
"iso_code" VARCHAR(2) NOT NULL,
"lang_code" VARCHAR(5) NOT NULL,
"date_format" VARCHAR(32) NOT NULL,
"date_format_short" VARCHAR(32) NOT NULL,
"rtl" BOOLEAN NOT NULL DEFAULT false ,
"is_default" BOOLEAN NOT NULL DEFAULT false ,
"active" BOOLEAN NOT NULL DEFAULT true ,
"flag" VARCHAR(16) NOT NULL,
CONSTRAINT "language_pkey" PRIMARY KEY ("id")
);
CREATE INDEX IF NOT EXISTS "idx_language_deleted_at"
ON "public"."language" (
"deleted_at" ASC
);
INSERT INTO "public"."language" ("id", "created_at", "updated_at", "deleted_at", "name", "iso_code", "lang_code", "date_format", "date_format_short", "rtl", "is_default", "active", "flag") VALUES (1, '2022-09-16 17:10:02.837+00', '2026-03-02 21:24:36.77973+00', NULL, 'Polski', 'pl', 'pl', '__-__-____', '__-__', false, false, true, '🇵🇱') ON CONFLICT DO NOTHING;
INSERT INTO "public"."language" ("id", "created_at", "updated_at", "deleted_at", "name", "iso_code", "lang_code", "date_format", "date_format_short", "rtl", "is_default", "active", "flag") VALUES (2, '2022-09-16 17:10:02.852+00', '2026-03-02 21:24:36.77973+00', NULL, 'English', 'en', 'en', '__-__-____', '__-__', false, true, true, '🇬🇧') ON CONFLICT DO NOTHING;
INSERT INTO "public"."language" ("id", "created_at", "updated_at", "deleted_at", "name", "iso_code", "lang_code", "date_format", "date_format_short", "rtl", "is_default", "active", "flag") VALUES (3, '2022-09-16 17:10:02.865+00', '2026-03-02 21:24:36.77973+00', NULL, 'Čeština', 'cs', 'cs', '__-__-____', '__-__', false, false, true, '🇨🇿') ON CONFLICT DO NOTHING;
-- components
CREATE TABLE IF NOT EXISTS "public"."components" (
"id" SERIAL,
"name" VARCHAR(255) NOT NULL,
CONSTRAINT "components_pkey" PRIMARY KEY ("id")
);
CREATE UNIQUE INDEX IF NOT EXISTS "uk_components_name"
ON "public"."components" (
"name" ASC,
"id" ASC
);
-- scopes
CREATE TABLE IF NOT EXISTS "public"."scopes" (
"id" SERIAL,
"name" VARCHAR(255) NOT NULL,
CONSTRAINT "scopes_pkey" PRIMARY KEY ("id")
);
CREATE UNIQUE INDEX IF NOT EXISTS "uk_scopes_name"
ON "public"."scopes" (
"name" ASC
);
-- translations
CREATE TABLE IF NOT EXISTS "public"."translations" (
"lang_id" BIGINT NOT NULL,
"scope_id" BIGINT NOT NULL,
"component_id" BIGINT NOT NULL,
"key" VARCHAR(255) NOT NULL,
"data" TEXT NULL,
CONSTRAINT "translations_pkey" PRIMARY KEY ("lang_id", "scope_id", "component_id", "key"),
CONSTRAINT "fk_translations_language" FOREIGN KEY ("lang_id") REFERENCES "public"."language" ("id") ON DELETE RESTRICT ON UPDATE RESTRICT,
CONSTRAINT "fk_translations_scope" FOREIGN KEY ("scope_id") REFERENCES "public"."scopes" ("id") ON DELETE RESTRICT ON UPDATE RESTRICT,
CONSTRAINT "fk_translations_component" FOREIGN KEY ("component_id") REFERENCES "public"."components" ("id") ON DELETE RESTRICT ON UPDATE RESTRICT
);
-- customers
CREATE TABLE IF NOT EXISTS "public"."customers" (
"id" SERIAL,
"email" VARCHAR(255) NOT NULL,
"password" VARCHAR(255) NULL,
"first_name" VARCHAR(100) NULL,
"last_name" VARCHAR(100) NULL,
"role" VARCHAR(20) NULL DEFAULT 'user'::character varying ,
"provider" VARCHAR(20) NULL DEFAULT 'local'::character varying ,
"provider_id" VARCHAR(255) NULL,
"avatar_url" VARCHAR(500) NULL,
"is_active" BOOLEAN NULL DEFAULT true ,
"email_verified" BOOLEAN NULL DEFAULT false ,
"email_verification_token" VARCHAR(255) NULL,
"email_verification_expires" TIMESTAMP WITH TIME ZONE NULL,
"password_reset_token" VARCHAR(255) NULL,
"password_reset_expires" TIMESTAMP WITH TIME ZONE NULL,
"last_password_reset_request" TIMESTAMP WITH TIME ZONE NULL,
"last_login_at" TIMESTAMP WITH TIME ZONE NULL,
"lang" VARCHAR(10) NULL DEFAULT 'en'::character varying ,
"created_at" TIMESTAMP WITH TIME ZONE NULL,
"updated_at" TIMESTAMP WITH TIME ZONE NULL,
"deleted_at" TIMESTAMP WITH TIME ZONE NULL,
CONSTRAINT "customers_pkey" PRIMARY KEY ("id")
);
CREATE UNIQUE INDEX IF NOT EXISTS "idx_customers_email"
ON "public"."customers" (
"email" ASC
);
CREATE INDEX IF NOT EXISTS "idx_customers_deleted_at"
ON "public"."customers" (
"deleted_at" ASC
);
-- customer_repo_accesses
CREATE TABLE IF NOT EXISTS "public"."customer_repo_accesses" (
"user_id" BIGINT NOT NULL,
"repo_id" BIGINT NOT NULL,
PRIMARY KEY ("user_id", "repo_id"),
FOREIGN KEY ("user_id") REFERENCES "public"."customers" ("id") ON DELETE CASCADE,
FOREIGN KEY ("repo_id") REFERENCES "public"."repository" ("id") ON DELETE CASCADE
);
-- insert sample admin user admin@ma-al.com/Maal12345678
INSERT INTO "public"."customers" ("id", "email", "password", "first_name", "last_name", "role", "provider", "provider_id", "avatar_url", "is_active", "email_verified", "email_verification_token", "email_verification_expires", "password_reset_token", "password_reset_expires", "last_password_reset_request", "last_login_at", "lang", "created_at", "updated_at", "deleted_at") VALUES (1, 'admin@ma-al.com', '$2a$10$Owy9DjrS0l3Fz4XoOvh5pulgmOMqdwXmb7hYE9BovnSuWS2plGr82', 'Super', 'Admin', 'admin', 'local', '', '', true, true, NULL, NULL, '', NULL, NULL, NULL, 'pl', '2026-03-02 16:55:10.25274+00', '2026-03-02 16:55:10.25274+00', NULL) ON CONFLICT DO NOTHING;
-- +goose Down
DROP TABLE IF EXISTS "public"."language";
DROP TABLE IF EXISTS "public"."components";
DROP TABLE IF EXISTS "public"."scopes";
DROP TABLE IF EXISTS "public"."translations";
DROP TABLE IF EXISTS "public"."customers";