Merge branch 'dev'
This commit is contained in:
commit
20c3780f8e
@ -1,20 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) SapphireCode - All Rights Reserved
|
|
||||||
* This file is part of Snippeteer which is released under BSD-3-Clause.
|
|
||||||
* See file 'LICENSE' for full license details.
|
|
||||||
* Created by Timo Hocker <timo@scode.ovh>, May 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { ColumnType } from './ColumnType';
|
|
||||||
import { Relation } from './Relation';
|
|
||||||
|
|
||||||
export class Column {
|
|
||||||
public name: string;
|
|
||||||
public type: ColumnType;
|
|
||||||
public relation?: Relation;
|
|
||||||
|
|
||||||
public constructor (name: string, type: ColumnType) {
|
|
||||||
this.name = name;
|
|
||||||
this.type = type;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,27 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) SapphireCode - All Rights Reserved
|
|
||||||
* This file is part of Snippeteer which is released under BSD-3-Clause.
|
|
||||||
* See file 'LICENSE' for full license details.
|
|
||||||
* Created by Timo Hocker <timo@scode.ovh>, May 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
export enum ColumnType {
|
|
||||||
string = 'string',
|
|
||||||
text = 'text',
|
|
||||||
integer = 'integer',
|
|
||||||
big_integer = 'bigInteger',
|
|
||||||
float = 'float',
|
|
||||||
decimal = 'decimal',
|
|
||||||
increments = 'increments',
|
|
||||||
big_increments = 'bigIncrements',
|
|
||||||
boolean = 'boolean',
|
|
||||||
date = 'date',
|
|
||||||
date_time ='datetime',
|
|
||||||
time = 'time',
|
|
||||||
timestamp = 'timestamp',
|
|
||||||
binary = 'binary',
|
|
||||||
enum = 'enu',
|
|
||||||
json='json',
|
|
||||||
jsonb='jsonb',
|
|
||||||
uuid='uuid'
|
|
||||||
}
|
|
@ -1,21 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) SapphireCode - All Rights Reserved
|
|
||||||
* This file is part of Snippeteer which is released under BSD-3-Clause.
|
|
||||||
* See file 'LICENSE' for full license details.
|
|
||||||
* Created by Timo Hocker <timo@scode.ovh>, May 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { Table } from './Table';
|
|
||||||
|
|
||||||
export class Database {
|
|
||||||
public tables: Array<Table> = [];
|
|
||||||
|
|
||||||
public get_table (name: string): Table|null {
|
|
||||||
for (const table of this.tables) {
|
|
||||||
if (table.name === name)
|
|
||||||
return table;
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,13 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) SapphireCode - All Rights Reserved
|
|
||||||
* This file is part of Snippeteer which is released under BSD-3-Clause.
|
|
||||||
* See file 'LICENSE' for full license details.
|
|
||||||
* Created by Timo Hocker <timo@scode.ovh>, May 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { Database } from './Database';
|
|
||||||
|
|
||||||
export interface PatchAction {
|
|
||||||
apply(db: Database): void;
|
|
||||||
assign_object(obj: Record<string, unknown>):void;
|
|
||||||
}
|
|
@ -1,16 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) SapphireCode - All Rights Reserved
|
|
||||||
* This file is part of Snippeteer which is released under BSD-3-Clause.
|
|
||||||
* See file 'LICENSE' for full license details.
|
|
||||||
* Created by Timo Hocker <timo@scode.ovh>, May 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
export class Relation {
|
|
||||||
public column: string;
|
|
||||||
public table: string;
|
|
||||||
|
|
||||||
public constructor (table: string, column: string) {
|
|
||||||
this.column = column;
|
|
||||||
this.table = table;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,26 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) SapphireCode - All Rights Reserved
|
|
||||||
* This file is part of Snippeteer which is released under BSD-3-Clause.
|
|
||||||
* See file 'LICENSE' for full license details.
|
|
||||||
* Created by Timo Hocker <timo@scode.ovh>, May 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { Column } from './Column';
|
|
||||||
|
|
||||||
export class Table {
|
|
||||||
public name: string;
|
|
||||||
public columns: Array<Column> = [];
|
|
||||||
|
|
||||||
public constructor (name: string) {
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public get_column (name: string): Column|null {
|
|
||||||
for (const col of this.columns) {
|
|
||||||
if (col.name === name)
|
|
||||||
return col;
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,21 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) SapphireCode - All Rights Reserved
|
|
||||||
* This file is part of Snippeteer which is released under BSD-3-Clause.
|
|
||||||
* See file 'LICENSE' for full license details.
|
|
||||||
* Created by Timo Hocker <timo@scode.ovh>, May 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { Snippet } from '../../Snippet';
|
|
||||||
import { MainMenu } from './menu/MainMenu';
|
|
||||||
import { Database as DatabaseClass } from './classes/Database';
|
|
||||||
|
|
||||||
export default class Database implements Snippet {
|
|
||||||
public is_active (): boolean {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public async start (): Promise<void> {
|
|
||||||
await (new MainMenu (new DatabaseClass))
|
|
||||||
.run ();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,21 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) SapphireCode - All Rights Reserved
|
|
||||||
* This file is part of Snippeteer which is released under BSD-3-Clause.
|
|
||||||
* See file 'LICENSE' for full license details.
|
|
||||||
* Created by Timo Hocker <timo@scode.ovh>, June 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { Database } from '../classes/Database';
|
|
||||||
import { Menu } from './Menu';
|
|
||||||
|
|
||||||
export class MainMenu extends Menu {
|
|
||||||
public constructor (db: Database) {
|
|
||||||
super ('Snippeteer Database');
|
|
||||||
this.register_option ('quit', () => {
|
|
||||||
// noop
|
|
||||||
});
|
|
||||||
this.register_option ('create table', () => {
|
|
||||||
console.log ('table');
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,35 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) SapphireCode - All Rights Reserved
|
|
||||||
* This file is part of Snippeteer which is released under BSD-3-Clause.
|
|
||||||
* See file 'LICENSE' for full license details.
|
|
||||||
* Created by Timo Hocker <timo@scode.ovh>, June 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { StringOption } from '@sapphirecode/console-app';
|
|
||||||
|
|
||||||
export class Menu {
|
|
||||||
private _options: Record<string, ()=>void|Promise<void>> = {};
|
|
||||||
private _title: string;
|
|
||||||
|
|
||||||
public constructor (title: string) {
|
|
||||||
this._title = title;
|
|
||||||
}
|
|
||||||
|
|
||||||
public async run (): Promise<void> {
|
|
||||||
const options = Object.keys (this._options);
|
|
||||||
const selected = await (new StringOption ({
|
|
||||||
name: 'menu_select',
|
|
||||||
message: this._title,
|
|
||||||
sources: { console: false },
|
|
||||||
exit_on_interrupt: true,
|
|
||||||
preset: options
|
|
||||||
}))
|
|
||||||
.parse ();
|
|
||||||
if (typeof this._options[selected] !== 'undefined')
|
|
||||||
await new Promise (this._options[selected]);
|
|
||||||
}
|
|
||||||
|
|
||||||
public register_option (name:string, callback:()=>void|Promise<void>): void {
|
|
||||||
this._options[name] = callback;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,16 +0,0 @@
|
|||||||
import { PatchAction } from '../classes/PatchAction';
|
|
||||||
|
|
||||||
export class ActionFactory {
|
|
||||||
private static _actions: Record<string, (json:string)=>PatchAction> = {};
|
|
||||||
|
|
||||||
public static get (name:string, json:string): PatchAction {
|
|
||||||
return this._actions[name] (json);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static register (
|
|
||||||
name:string,
|
|
||||||
constr: (json:string)=>PatchAction
|
|
||||||
):void {
|
|
||||||
this._actions[name] = constr;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,29 +0,0 @@
|
|||||||
import { Persistent } from '@sapphirecode/modelling';
|
|
||||||
import { PatchAction } from '../classes/PatchAction';
|
|
||||||
import { Database } from '../classes/Database';
|
|
||||||
import { Table } from '../classes/Table';
|
|
||||||
import { Column } from '../classes/Column';
|
|
||||||
import { ColumnType } from '../classes/ColumnType';
|
|
||||||
|
|
||||||
export class AddTable extends Persistent implements PatchAction {
|
|
||||||
public get name ():string {
|
|
||||||
return this.get ('name') as string;
|
|
||||||
}
|
|
||||||
|
|
||||||
public constructor (name:string) {
|
|
||||||
super ();
|
|
||||||
this.properties.name = 'string';
|
|
||||||
|
|
||||||
this.set ('name', name);
|
|
||||||
}
|
|
||||||
|
|
||||||
public apply (db: Database):void {
|
|
||||||
if (typeof db.get_table (this.name) !== 'undefined')
|
|
||||||
throw new Error ('table already exists');
|
|
||||||
|
|
||||||
const table = new Table (this.name);
|
|
||||||
table.columns.push (new Column ('id', ColumnType.increments));
|
|
||||||
|
|
||||||
db.tables.push (table);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,50 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) SapphireCode - All Rights Reserved
|
|
||||||
* This file is part of Snippeteer which is released under BSD-3-Clause.
|
|
||||||
* See file 'LICENSE' for full license details.
|
|
||||||
* Created by Timo Hocker <timo@scode.ovh>, June 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { PatchAction } from '../classes/PatchAction';
|
|
||||||
import { ActionFactory } from './ActionFactory';
|
|
||||||
import { RenameColumn } from './RenameColumn';
|
|
||||||
import { AddTable } from './AddTable';
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* export { AddColumn } from './AddColumn';
|
|
||||||
* export { DropColumn } from './DropColumn';
|
|
||||||
* export { AddRelation } from './AddRelation';
|
|
||||||
* export { DropRelation } from './DropRelation';
|
|
||||||
* export { SetColumnType } from './SetColumnType';
|
|
||||||
* export { DropTable } from './DropTable';
|
|
||||||
* export { RenameTable } from './RenameTable';
|
|
||||||
* export { InsertData } from './InsertData';
|
|
||||||
* export { UpdateData } from './UpdateData';
|
|
||||||
* export { MutateDate } from './MutateDate';
|
|
||||||
* export { DeleteData } from './DeleteData';
|
|
||||||
*/
|
|
||||||
|
|
||||||
function assign_json (patch:PatchAction, json:string):PatchAction {
|
|
||||||
const obj = JSON.parse (json);
|
|
||||||
patch.assign_object (obj);
|
|
||||||
return patch;
|
|
||||||
}
|
|
||||||
|
|
||||||
function init ():void {
|
|
||||||
ActionFactory.register (
|
|
||||||
'rename_column',
|
|
||||||
(json:string) => assign_json (new RenameColumn ('', '', ''), json)
|
|
||||||
);
|
|
||||||
|
|
||||||
ActionFactory.register (
|
|
||||||
'add_table',
|
|
||||||
(json:string) => assign_json (new AddTable (''), json)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
export {
|
|
||||||
init,
|
|
||||||
RenameColumn,
|
|
||||||
AddTable
|
|
||||||
};
|
|
@ -1,56 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) SapphireCode - All Rights Reserved
|
|
||||||
* This file is part of Snippeteer which is released under BSD-3-Clause.
|
|
||||||
* See file 'LICENSE' for full license details.
|
|
||||||
* Created by Timo Hocker <timo@scode.ovh>, May 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { Persistent } from '@sapphirecode/modelling';
|
|
||||||
import { PatchAction } from '../classes/PatchAction';
|
|
||||||
import { Database } from '../classes/Database';
|
|
||||||
|
|
||||||
export class RenameColumn extends Persistent implements PatchAction {
|
|
||||||
public get table (): string {
|
|
||||||
return this.get ('table') as string;
|
|
||||||
}
|
|
||||||
|
|
||||||
public get column (): string {
|
|
||||||
return this.get ('column') as string;
|
|
||||||
}
|
|
||||||
|
|
||||||
public get new_name (): string {
|
|
||||||
return this.get ('new_name') as string;
|
|
||||||
}
|
|
||||||
|
|
||||||
public constructor (
|
|
||||||
column: string,
|
|
||||||
new_name: string,
|
|
||||||
table: string
|
|
||||||
) {
|
|
||||||
super ();
|
|
||||||
this.properties.column = 'string';
|
|
||||||
this.properties.table = 'string';
|
|
||||||
this.properties.new_name = 'string';
|
|
||||||
|
|
||||||
this.set ('column', column);
|
|
||||||
this.set ('new_name', new_name);
|
|
||||||
this.set ('table', table);
|
|
||||||
}
|
|
||||||
|
|
||||||
public apply (db: Database): void {
|
|
||||||
const table = db.get_table (this.table);
|
|
||||||
if (typeof table === 'undefined' || table === null) {
|
|
||||||
throw new Error (
|
|
||||||
`table ${this.table} not found`
|
|
||||||
);
|
|
||||||
}
|
|
||||||
const column = table.get_column (this.column);
|
|
||||||
if (typeof column === 'undefined' || column === null) {
|
|
||||||
throw new Error (
|
|
||||||
`column ${this.column} not found in table ${this.table}`
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
column.name = this.new_name;
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user