mirror of https://github.com/nocodb/nocodb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
2091 lines
43 KiB
2091 lines
43 KiB
const dbTypes = [ |
|
"int", |
|
"integer", |
|
"bigint", |
|
"bigserial", |
|
"char", |
|
"int2", |
|
"int4", |
|
"int8", |
|
"int4range", |
|
"int8range", |
|
"serial", |
|
"serial2", |
|
"serial8", |
|
"character", |
|
"bit", |
|
"bool", |
|
"boolean", |
|
"date", |
|
"double precision", |
|
"event_trigger", |
|
"fdw_handler", |
|
"float4", |
|
"float8", |
|
"uuid", |
|
"smallint", |
|
"smallserial", |
|
"character varying", |
|
"text", |
|
"real", |
|
"time", |
|
"time without time zone", |
|
"timestamp", |
|
"timestamp without time zone", |
|
"timestamptz", |
|
"timestamp with time zone", |
|
"timetz", |
|
"time with time zone", |
|
"daterange", |
|
"json", |
|
"jsonb", |
|
"gtsvector", |
|
"index_am_handler", |
|
"anyenum", |
|
"anynonarray", |
|
"anyrange", |
|
"box", |
|
"bpchar", |
|
"bytea", |
|
"cid", |
|
"cidr", |
|
"circle", |
|
"cstring", |
|
"inet", |
|
"internal", |
|
"interval", |
|
"language_handler", |
|
"line", |
|
"lsec", |
|
"macaddr", |
|
"money", |
|
"name", |
|
"numeric", |
|
"numrange", |
|
"oid", |
|
"opaque", |
|
"path", |
|
"pg_ddl_command", |
|
"pg_lsn", |
|
"pg_node_tree", |
|
"point", |
|
"polygon", |
|
"record", |
|
"refcursor", |
|
"regclass", |
|
"regconfig", |
|
"regdictionary", |
|
"regnamespace", |
|
"regoper", |
|
"regoperator", |
|
"regproc", |
|
"regpreocedure", |
|
"regrole", |
|
"regtype", |
|
"reltime", |
|
"smgr", |
|
"tid", |
|
"tinterval", |
|
"trigger", |
|
"tsm_handler", |
|
"tsquery", |
|
"tsrange", |
|
"tstzrange", |
|
"tsvector", |
|
"txid_snapshot", |
|
"unknown", |
|
"void", |
|
"xid", |
|
"xml"] |
|
|
|
export class PgUi { |
|
|
|
static getNewTableColumns() { |
|
return [ |
|
{ |
|
cn: "id", |
|
dt: "int4", |
|
dtx: "integer", |
|
ct: "int(11)", |
|
nrqd: false, |
|
rqd: true, |
|
ck: false, |
|
pk: true, |
|
un: false, |
|
ai: true, |
|
cdf: null, |
|
clen: null, |
|
np: 11, |
|
ns: 0, |
|
dtxp: '11', |
|
dtxs: '', |
|
altered: 1, |
|
uidt: "ID", |
|
uip: "", |
|
uicn: "", |
|
}, |
|
{ |
|
cn: "title", |
|
dt: "character varying", |
|
dtx: "specificType", |
|
ct: "varchar(45)", |
|
nrqd: true, |
|
rqd: false, |
|
ck: false, |
|
pk: false, |
|
un: false, |
|
ai: false, |
|
cdf: null, |
|
clen: 45, |
|
np: null, |
|
ns: null, |
|
dtxp: '45', |
|
dtxs: '', |
|
altered: 1, |
|
uidt: 'SingleLineText', |
|
uip: "", |
|
uicn: "", |
|
}, |
|
{ |
|
cn: "created_at", |
|
dt: "timestamp", |
|
dtx: "specificType", |
|
ct: "varchar(45)", |
|
nrqd: true, |
|
rqd: false, |
|
ck: false, |
|
pk: false, |
|
un: false, |
|
ai: false, |
|
cdf: 'now()', |
|
clen: 45, |
|
np: null, |
|
ns: null, |
|
dtxp: '', |
|
dtxs: '', |
|
altered: 1, |
|
uidt: 'CreateTime', |
|
uip: "", |
|
uicn: "", |
|
}, |
|
{ |
|
cn: "updated_at", |
|
dt: "timestamp", |
|
dtx: "specificType", |
|
ct: "varchar(45)", |
|
nrqd: true, |
|
rqd: false, |
|
ck: false, |
|
pk: false, |
|
un: false, |
|
ai: false, |
|
au: true, |
|
cdf: 'now()', |
|
clen: 45, |
|
np: null, |
|
ns: null, |
|
dtxp: '', |
|
dtxs: '', |
|
altered: 1, |
|
uidt: 'LastModifiedTime', |
|
uip: "", |
|
uicn: "", |
|
} |
|
]; |
|
} |
|
|
|
static getNewColumn(suffix) { |
|
return { |
|
cn: "title" + suffix, |
|
dt: "int4", |
|
dtx: "specificType", |
|
ct: "integer(11)", |
|
nrqd: true, |
|
rqd: false, |
|
ck: false, |
|
pk: false, |
|
un: false, |
|
ai: false, |
|
cdf: null, |
|
clen: 45, |
|
np: null, |
|
ns: null, |
|
//data_type_x_specific: ' ', |
|
dtxp: '11', |
|
dtxs: ' ', |
|
altered: 1, |
|
uidt: 'Number', |
|
uip: "", |
|
uicn: "", |
|
}; |
|
} |
|
|
|
|
|
// static getDefaultLengthForDatatype(type) { |
|
// switch (type) { |
|
// case "int": |
|
// return 11; |
|
// break; |
|
// case "tinyint": |
|
// return 1; |
|
// break; |
|
// case "smallint": |
|
// return 5; |
|
// break; |
|
// |
|
// case "mediumint": |
|
// return 9; |
|
// break; |
|
// case "bigint": |
|
// return 20; |
|
// break; |
|
// case "bit": |
|
// return 64; |
|
// break; |
|
// case "boolean": |
|
// return ''; |
|
// break; |
|
// case "float": |
|
// return 12; |
|
// break; |
|
// case "decimal": |
|
// return 10; |
|
// break; |
|
// case "double": |
|
// return 22; |
|
// break; |
|
// case "serial": |
|
// return 20; |
|
// break; |
|
// case "date": |
|
// return ''; |
|
// break; |
|
// case "datetime": |
|
// case "timestamp": |
|
// return 6; |
|
// break; |
|
// case "time": |
|
// return ''; |
|
// break; |
|
// case "year": |
|
// return ''; |
|
// break; |
|
// case "char": |
|
// return 255; |
|
// break; |
|
// case "varchar": |
|
// return 45; |
|
// break; |
|
// case "nchar": |
|
// return 255; |
|
// break; |
|
// case "text": |
|
// return ''; |
|
// break; |
|
// case "tinytext": |
|
// return ''; |
|
// break; |
|
// case "mediumtext": |
|
// return ''; |
|
// break; |
|
// case "longtext": |
|
// return '' |
|
// break; |
|
// case "binary": |
|
// return 255; |
|
// break; |
|
// case "varbinary": |
|
// return 65500; |
|
// break; |
|
// case "blob": |
|
// return ''; |
|
// break; |
|
// case "tinyblob": |
|
// return ''; |
|
// break; |
|
// case "mediumblob": |
|
// return ''; |
|
// break; |
|
// case "longblob": |
|
// return ''; |
|
// break; |
|
// case "enum": |
|
// return '\'a\',\'b\''; |
|
// break; |
|
// case "set": |
|
// return '\'a\',\'b\''; |
|
// break; |
|
// case "geometry": |
|
// return ''; |
|
// case "point": |
|
// return ''; |
|
// case "linestring": |
|
// return ''; |
|
// case "polygon": |
|
// return ''; |
|
// case "multipoint": |
|
// return ''; |
|
// case "multilinestring": |
|
// return ''; |
|
// case "multipolygon": |
|
// return ''; |
|
// case "json": |
|
// return '' |
|
// break; |
|
// |
|
// } |
|
// |
|
// } |
|
|
|
static getDefaultLengthForDatatype(type) { |
|
switch (type) { |
|
case "int": |
|
return ''; |
|
break; |
|
case "tinyint": |
|
return ''; |
|
break; |
|
case "smallint": |
|
return ''; |
|
break; |
|
|
|
case "mediumint": |
|
return ''; |
|
break; |
|
case "bigint": |
|
return ''; |
|
break; |
|
case "bit": |
|
return ''; |
|
break; |
|
case "boolean": |
|
return ''; |
|
break; |
|
case "float": |
|
return ''; |
|
break; |
|
case "decimal": |
|
return ''; |
|
break; |
|
case "double": |
|
return ''; |
|
break; |
|
case "serial": |
|
return ''; |
|
break; |
|
case "date": |
|
return ''; |
|
break; |
|
case "datetime": |
|
case "timestamp": |
|
return ''; |
|
break; |
|
case "time": |
|
return ''; |
|
break; |
|
case "year": |
|
return ''; |
|
break; |
|
case "char": |
|
return ''; |
|
break; |
|
case "varchar": |
|
return ''; |
|
break; |
|
case "nchar": |
|
return ''; |
|
break; |
|
case "text": |
|
return ''; |
|
break; |
|
case "tinytext": |
|
return ''; |
|
break; |
|
case "mediumtext": |
|
return ''; |
|
break; |
|
case "longtext": |
|
return ''; |
|
break; |
|
case "binary": |
|
return ''; |
|
break; |
|
case "varbinary": |
|
return ''; |
|
break; |
|
case "blob": |
|
return ''; |
|
break; |
|
case "tinyblob": |
|
return ''; |
|
break; |
|
case "mediumblob": |
|
return ''; |
|
break; |
|
case "longblob": |
|
return ''; |
|
break; |
|
case "enum": |
|
return ''; |
|
break; |
|
case "set": |
|
return ''; |
|
break; |
|
case "geometry": |
|
return ''; |
|
case "point": |
|
return ''; |
|
case "linestring": |
|
return ''; |
|
case "polygon": |
|
return ''; |
|
case "multipoint": |
|
return ''; |
|
case "multilinestring": |
|
return ''; |
|
case "multipolygon": |
|
return ''; |
|
case "json": |
|
return ''; |
|
break; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
static getDefaultLengthIsDisabled(type) { |
|
switch (type) { |
|
case "anyenum": |
|
case "anynonarray": |
|
case "anyrange": |
|
case "bigint": |
|
case "bigserial": |
|
case "bit": |
|
case "bool": |
|
case "box": |
|
case "bpchar": |
|
case "bytea": |
|
case "char": |
|
case "character": |
|
case "cid": |
|
case "cidr": |
|
case "circle": |
|
case "cstring": |
|
case "date": |
|
case "daterange": |
|
case "double precision": |
|
case "event_trigger": |
|
case "fdw_handler": |
|
case "float4": |
|
case "float8": |
|
case "gtsvector": |
|
case "index_am_handler": |
|
case "inet": |
|
case "int": |
|
case "int2": |
|
case "int4": |
|
case "int8": |
|
case "int4range": |
|
case "int8range": |
|
case "integer": |
|
case "internal": |
|
case "interval": |
|
case "json": |
|
case "jsonb": |
|
case "language_handler": |
|
case "line": |
|
case "lsec": |
|
case "macaddr": |
|
case "money": |
|
case "name": |
|
case "numeric": |
|
case "numrange": |
|
case "oid": |
|
case "opaque": |
|
case "path": |
|
case "pg_ddl_command": |
|
case "pg_lsn": |
|
case "pg_node_tree": |
|
case "point": |
|
case "polygon": |
|
case "real": |
|
case "record": |
|
case "refcursor": |
|
case "regclass": |
|
case "regconfig": |
|
case "regdictionary": |
|
case "regnamespace": |
|
case "regoper": |
|
case "regoperator": |
|
case "regproc": |
|
case "regpreocedure": |
|
case "regrole": |
|
case "regtype": |
|
case "reltime": |
|
case "serial": |
|
case "serial2": |
|
case "serial8": |
|
case "smallint": |
|
case "smallserial": |
|
case "smgr": |
|
case "text": |
|
case "tid": |
|
case "time": |
|
case "time without time zone": |
|
case "timestamp": |
|
case "timestamp without time zone": |
|
case "timestamptz": |
|
case "timestamp with time zone": |
|
case "timetz": |
|
case "time with time zone": |
|
case "tinterval": |
|
case "trigger": |
|
case "tsm_handler": |
|
case "tsquery": |
|
case "tsrange": |
|
case "tstzrange": |
|
case "tsvector": |
|
case "txid_snapshot": |
|
case "unknown": |
|
case "void": |
|
case "xid": |
|
case "xml": |
|
case "integer": |
|
case "character varying": |
|
case "int2": |
|
case "int4": |
|
case "int8": |
|
case "float4": |
|
case "float8": |
|
case "interval": |
|
case "json": |
|
case "jsonb": |
|
case "jsonb": |
|
case "int": |
|
case "tinyint": |
|
case "smallint": |
|
case "mediumint": |
|
case "bigint": |
|
case "float": |
|
case "decimal": |
|
case "double": |
|
case "real": |
|
case "bit": |
|
case "boolean": |
|
case "serial": |
|
case "date": |
|
case "datetime": |
|
case "timestamp": |
|
case "timestamptz": |
|
case "timetz": |
|
case "time": |
|
case "uuid": |
|
case "year": |
|
case "char": |
|
case "varchar": |
|
case "nchar": |
|
case "text": |
|
case "tinytext": |
|
case "mediumtext": |
|
case "longtext": |
|
case "binary": |
|
case "varbinary": |
|
case "blob": |
|
case "tinyblob": |
|
case "mediumblob": |
|
case "longblob": |
|
case "enum": |
|
case "set": |
|
case "time": |
|
case "geometry": |
|
case "point": |
|
case "linestring": |
|
case "polygon": |
|
case "multipoint": |
|
case "multilinestring": |
|
case "multipolygon": |
|
case "json": |
|
return true; |
|
break; |
|
} |
|
|
|
} |
|
|
|
|
|
static getDefaultValueForDatatype(type) { |
|
switch (type) { |
|
case "anyenum": |
|
return "eg: "; |
|
break; |
|
case "anynonarray": |
|
return "eg: "; |
|
break; |
|
case "anyrange": |
|
return "eg: "; |
|
break; |
|
case "bigint": |
|
return "eg: "; |
|
break; |
|
case "bigserial": |
|
return "eg: "; |
|
break; |
|
case "bit": |
|
return "eg: "; |
|
break; |
|
case "bool": |
|
return "eg: "; |
|
break; |
|
case "box": |
|
return "eg: "; |
|
break; |
|
case "bpchar": |
|
return "eg: "; |
|
break; |
|
case "bytea": |
|
return "eg: "; |
|
break; |
|
case "char": |
|
return "eg: "; |
|
break; |
|
case "character": |
|
return "eg: 'sample'"; |
|
break; |
|
case "cid": |
|
return "eg: "; |
|
break; |
|
case "cidr": |
|
return "eg: "; |
|
break; |
|
case "circle": |
|
return "eg: "; |
|
break; |
|
case "cstring": |
|
return "eg: "; |
|
break; |
|
case "date": |
|
return "eg: '2020-09-09'"; |
|
break; |
|
case "daterange": |
|
return "eg: "; |
|
break; |
|
case "double precision": |
|
return "eg: 1.2"; |
|
break; |
|
case "event_trigger": |
|
return "eg: "; |
|
break; |
|
case "fdw_handler": |
|
return "eg: "; |
|
break; |
|
case "float4": |
|
return "eg: 1.2"; |
|
break; |
|
case "float8": |
|
return "eg: 1.2"; |
|
break; |
|
case "gtsvector": |
|
return "eg: "; |
|
break; |
|
case "index_am_handler": |
|
return "eg: "; |
|
break; |
|
case "inet": |
|
return "eg: "; |
|
break; |
|
case "int": |
|
return "eg: "; |
|
break; |
|
case "int2": |
|
return "eg: "; |
|
break; |
|
case "int4": |
|
return "eg: "; |
|
break; |
|
case "int8": |
|
return "eg: "; |
|
break; |
|
case "int4range": |
|
return "eg: "; |
|
break; |
|
case "int8range": |
|
return "eg: "; |
|
break; |
|
case "integer": |
|
return "eg: "; |
|
break; |
|
case "internal": |
|
return "eg: "; |
|
break; |
|
case "interval": |
|
return "eg: "; |
|
break; |
|
case "json": |
|
return "eg: "; |
|
break; |
|
case "jsonb": |
|
return "eg: "; |
|
break; |
|
case "language_handler": |
|
return "eg: "; |
|
break; |
|
case "line": |
|
return "eg: "; |
|
break; |
|
case "lsec": |
|
return "eg: "; |
|
break; |
|
case "macaddr": |
|
return "eg: "; |
|
break; |
|
case "money": |
|
return "eg: "; |
|
break; |
|
case "name": |
|
return "eg: "; |
|
break; |
|
case "numeric": |
|
return "eg: "; |
|
break; |
|
case "numrange": |
|
return "eg: "; |
|
break; |
|
case "oid": |
|
return "eg: "; |
|
break; |
|
case "opaque": |
|
return "eg: "; |
|
break; |
|
case "path": |
|
return "eg: "; |
|
break; |
|
case "pg_ddl_command": |
|
return "eg: "; |
|
break; |
|
case "pg_lsn": |
|
return "eg: "; |
|
break; |
|
case "pg_node_tree": |
|
return "eg: "; |
|
break; |
|
case "point": |
|
return "eg: "; |
|
break; |
|
case "polygon": |
|
return "eg: "; |
|
break; |
|
case "real": |
|
return "eg: 1.2"; |
|
break; |
|
case "record": |
|
return "eg: "; |
|
break; |
|
case "refcursor": |
|
return "eg: "; |
|
break; |
|
case "regclass": |
|
return "eg: "; |
|
break; |
|
case "regconfig": |
|
return "eg: "; |
|
break; |
|
case "regdictionary": |
|
return "eg: "; |
|
break; |
|
case "regnamespace": |
|
return "eg: "; |
|
break; |
|
case "regoper": |
|
return "eg: "; |
|
break; |
|
case "regoperator": |
|
return "eg: "; |
|
break; |
|
case "regproc": |
|
return "eg: "; |
|
break; |
|
case "regpreocedure": |
|
return "eg: "; |
|
break; |
|
case "regrole": |
|
return "eg: "; |
|
break; |
|
case "regtype": |
|
return "eg: "; |
|
break; |
|
case "reltime": |
|
return "eg: "; |
|
break; |
|
case "serial": |
|
return "eg: "; |
|
break; |
|
case "serial2": |
|
return "eg: "; |
|
break; |
|
case "serial8": |
|
return "eg: "; |
|
break; |
|
case "smallint": |
|
return "eg: "; |
|
break; |
|
case "smallserial": |
|
return "eg: "; |
|
break; |
|
case "smgr": |
|
return "eg: "; |
|
break; |
|
case "text": |
|
return "eg: 'sample text'"; |
|
break; |
|
case "tid": |
|
return "eg: "; |
|
break; |
|
case "time": |
|
return "eg: now()\n\n'04:05:06.789'"; |
|
break; |
|
case "time without time zone": |
|
return "eg: now()\n\n'04:05:06.789'"; |
|
break; |
|
case "timestamp": |
|
return "eg: now()\n\n'2016-06-22 19:10:25-07'"; |
|
break; |
|
case "timestamp without time zone": |
|
return "eg: now()\n\n'2016-06-22 19:10:25-07'"; |
|
break; |
|
case "timestamptz": |
|
return "eg: timezone('America/New_York','2016-06-01 00:00')\n\nnow()\n\n'2016-06-22 19:10:25-07'"; |
|
break; |
|
case "timestamp with time zone": |
|
return "eg: now()\n\n'2016-06-22 19:10:25-07'"; |
|
break; |
|
case "timetz": |
|
return "eg: now()"; |
|
break; |
|
case "time with time zone": |
|
return "eg: now()"; |
|
break; |
|
case "tinterval": |
|
return "eg: "; |
|
break; |
|
case "trigger": |
|
return "eg: "; |
|
break; |
|
case "tsm_handler": |
|
return "eg: "; |
|
break; |
|
case "tsquery": |
|
return "eg: "; |
|
break; |
|
case "tsrange": |
|
return "eg: "; |
|
break; |
|
case "tstzrange": |
|
return "eg: "; |
|
break; |
|
case "tsvector": |
|
return "eg: "; |
|
break; |
|
case "txid_snapshot": |
|
return "eg: "; |
|
break; |
|
case "unknown": |
|
return "eg: "; |
|
break; |
|
case "void": |
|
return "eg: "; |
|
break; |
|
case "xid": |
|
return "eg: "; |
|
break; |
|
case "xml": |
|
return "eg: "; |
|
break; |
|
case "integer": |
|
return "eg: "; |
|
break; |
|
case "character varying": |
|
return "eg: "; |
|
break; |
|
case "int2": |
|
return "eg: "; |
|
break; |
|
case "int4": |
|
return "eg: "; |
|
break; |
|
case "int8": |
|
return "eg: "; |
|
break; |
|
case "float4": |
|
return "eg: "; |
|
break; |
|
case "float8": |
|
return "eg: "; |
|
break; |
|
case "interval": |
|
return "eg: "; |
|
break; |
|
case "json": |
|
return "eg: "; |
|
break; |
|
case "jsonb": |
|
return "eg: "; |
|
break; |
|
case "jsonb": |
|
return "eg: "; |
|
break; |
|
case "int": |
|
return "eg: "; |
|
break; |
|
case "tinyint": |
|
return "eg: "; |
|
break; |
|
case "smallint": |
|
return "eg: "; |
|
break; |
|
case "mediumint": |
|
return "eg: "; |
|
break; |
|
case "bigint": |
|
return "eg: "; |
|
break; |
|
case "float": |
|
return "eg: "; |
|
break; |
|
case "decimal": |
|
return "eg: "; |
|
break; |
|
case "double": |
|
return "eg: 1.2"; |
|
break; |
|
case "real": |
|
return "eg: "; |
|
break; |
|
case "bit": |
|
return "eg: "; |
|
break; |
|
case "boolean": |
|
return "eg: true\n\nfalse"; |
|
break; |
|
case "serial": |
|
return "eg: "; |
|
break; |
|
case "date": |
|
return "eg: "; |
|
break; |
|
case "datetime": |
|
return "eg: "; |
|
break; |
|
case "timestamp": |
|
return "eg: "; |
|
break; |
|
case "timestamptz": |
|
return "eg: "; |
|
break; |
|
case "timetz": |
|
return "eg: "; |
|
break; |
|
case "time": |
|
return "eg: "; |
|
break; |
|
case "uuid": |
|
return "eg: "; |
|
break; |
|
case "year": |
|
return "eg: "; |
|
break; |
|
case "char": |
|
return "eg: 'sample'"; |
|
break; |
|
case "varchar": |
|
return "eg: "; |
|
break; |
|
case "nchar": |
|
return "eg: "; |
|
break; |
|
case "text": |
|
return "eg: "; |
|
break; |
|
case "tinytext": |
|
return "eg: "; |
|
break; |
|
case "mediumtext": |
|
return "eg: "; |
|
break; |
|
case "longtext": |
|
return "eg: "; |
|
break; |
|
case "binary": |
|
return "eg: "; |
|
break; |
|
case "varbinary": |
|
return "eg: "; |
|
break; |
|
case "blob": |
|
return "eg: "; |
|
break; |
|
case "tinyblob": |
|
return "eg: "; |
|
break; |
|
case "mediumblob": |
|
return "eg: "; |
|
break; |
|
case "longblob": |
|
return "eg: "; |
|
break; |
|
case "enum": |
|
return "eg: "; |
|
break; |
|
case "set": |
|
return "eg: "; |
|
break; |
|
case "time": |
|
return "eg: "; |
|
break; |
|
case "geometry": |
|
return "eg: "; |
|
break; |
|
case "point": |
|
return "eg: "; |
|
break; |
|
case "linestring": |
|
return "eg: "; |
|
break; |
|
case "polygon": |
|
return "eg: "; |
|
break; |
|
case "multipoint": |
|
return "eg: "; |
|
break; |
|
case "multilinestring": |
|
return "eg: "; |
|
break; |
|
case "multipolygon": |
|
return "eg: "; |
|
break; |
|
case "json": |
|
return "eg: "; |
|
break; |
|
|
|
} |
|
} |
|
|
|
|
|
static getDefaultScaleForDatatype(type) { |
|
switch (type) { |
|
case "int": |
|
return ' ' |
|
break; |
|
case "tinyint": |
|
return ' ' |
|
break; |
|
case "smallint": |
|
return ' ' |
|
break; |
|
|
|
case "mediumint": |
|
return ' ' |
|
break; |
|
case "bigint": |
|
return ' ' |
|
break; |
|
case "bit": |
|
return ' ' |
|
break; |
|
case "boolean": |
|
return ' ' |
|
break; |
|
case "float": |
|
return '2' |
|
break; |
|
case "decimal": |
|
return '2' |
|
break; |
|
case "double": |
|
return '2' |
|
break; |
|
case "serial": |
|
return ' ' |
|
break; |
|
case "date": |
|
case "datetime": |
|
case "timestamp": |
|
return ' ' |
|
break; |
|
case "time": |
|
return ' ' |
|
break; |
|
case "year": |
|
return ' ' |
|
break; |
|
case "char": |
|
return ' ' |
|
break; |
|
case "varchar": |
|
return ' ' |
|
break; |
|
case "nchar": |
|
return ' ' |
|
break; |
|
case "text": |
|
return ' ' |
|
break; |
|
case "tinytext": |
|
return ' ' |
|
break; |
|
case "mediumtext": |
|
return ' ' |
|
break; |
|
case "longtext": |
|
return ' ' |
|
break; |
|
case "binary": |
|
return ' ' |
|
break; |
|
case "varbinary": |
|
return ' ' |
|
break; |
|
case "blob": |
|
return ' ' |
|
break; |
|
case "tinyblob": |
|
return ' ' |
|
break; |
|
case "mediumblob": |
|
return ' ' |
|
break; |
|
case "longblob": |
|
return ' ' |
|
break; |
|
case "enum": |
|
return ' ' |
|
break; |
|
case "set": |
|
return ' ' |
|
break; |
|
case "geometry": |
|
return ' ' |
|
case "point": |
|
return ' ' |
|
case "linestring": |
|
return ' ' |
|
case "polygon": |
|
return ' ' |
|
case "multipoint": |
|
return ' ' |
|
case "multilinestring": |
|
return ' ' |
|
case "multipolygon": |
|
return ' ' |
|
case "json": |
|
return ' ' |
|
break; |
|
|
|
} |
|
|
|
} |
|
|
|
static colPropAIDisabled(col, columns) { |
|
//console.log(col); |
|
if (col.dt === 'int4' || |
|
col.dt === 'integer' || |
|
col.dt === 'bigint' || |
|
col.dt === 'smallint') { |
|
for (var i = 0; i < columns.length; ++i) { |
|
if (columns[i].cn !== col.cn && columns[i].ai) { |
|
return true; |
|
} |
|
} |
|
return false; |
|
} else { |
|
return true; |
|
} |
|
} |
|
|
|
static colPropUNDisabled(col) { |
|
//console.log(col); |
|
return true; |
|
// if (col.dt === 'int' || |
|
// col.dt === 'tinyint' || |
|
// col.dt === 'smallint' || |
|
// col.dt === 'mediumint' || |
|
// col.dt === 'bigint') { |
|
// return false; |
|
// } else { |
|
// return true; |
|
// } |
|
} |
|
|
|
static onCheckboxChangeAI(col) { |
|
console.log(col); |
|
if (col.dt === 'int' || col.dt === 'bigint' || col.dt === 'smallint' || col.dt === 'tinyint') { |
|
col.altered = col.altered || 2; |
|
} |
|
|
|
// if (!col.ai) { |
|
// col.dtx = 'specificType' |
|
// } else { |
|
// col.dtx = '' |
|
// } |
|
} |
|
|
|
static onCheckboxChangeAU(col) { |
|
console.log(col); |
|
if (1) { |
|
col.altered = col.altered || 2; |
|
} |
|
if (col.au) { |
|
col.cdf = 'now()'; |
|
} |
|
|
|
// if (!col.ai) { |
|
// col.dtx = 'specificType' |
|
// } else { |
|
// col.dtx = '' |
|
// } |
|
} |
|
|
|
static showScale(columnObj) { |
|
return false; |
|
} |
|
|
|
|
|
static removeUnsigned(columns) { |
|
|
|
for (var i = 0; i < columns.length; ++i) { |
|
if (columns[i].altered === 1 && (!(columns[i].dt === 'int' |
|
|| columns[i].dt === 'bigint' |
|
|| columns[i].dt === 'tinyint' |
|
|| columns[i].dt === 'smallint' |
|
|| columns[i].dt === 'mediumint'))) { |
|
columns[i].un = false; |
|
console.log('>> resetting unsigned value', columns[i].cn); |
|
} |
|
console.log(columns[i].cn); |
|
} |
|
|
|
} |
|
|
|
static columnEditable(colObj) { |
|
return colObj.tn !== '_evolutions' || colObj.tn !== 'nc_evolutions'; |
|
} |
|
|
|
|
|
static extractFunctionName(query) { |
|
const reg = /^\s*CREATE\s+(?:OR\s+REPLACE\s*)?\s*FUNCTION\s+(?:[\w\d_]+\.)?([\w_\d]+)/i; |
|
const match = query.match(reg); |
|
return match && match[1]; |
|
} |
|
|
|
|
|
static extractProcedureName(query) { |
|
const reg = /^\s*CREATE\s+(?:OR\s+REPLACE\s*)?\s*PROCEDURE\s+(?:[\w\d_]+\.)?([\w_\d]+)/i; |
|
const match = query.match(reg); |
|
return match && match[1]; |
|
} |
|
|
|
static handleRawOutput(result, headers) { |
|
if (['DELETE', 'INSERT', 'UPDATE'].includes(result.command.toUpperCase())) { |
|
headers.push({text: 'Row count', value: 'rowCount', sortable: false}) |
|
result = [{ |
|
rowCount: result.rowCount |
|
}]; |
|
} else { |
|
result = result.rows; |
|
if (Array.isArray(result) && result[0]) { |
|
const keys = Object.keys(result[0]); |
|
//set headers before settings result |
|
for (let i = 0; i < keys.length; i++) { |
|
const text = keys[i]; |
|
headers.push({text, value: text, sortable: false}); |
|
} |
|
} |
|
} |
|
return result; |
|
} |
|
|
|
static splitQueries(query) { |
|
/*** |
|
* we are splitting based on semicolon |
|
* there are mechanism to escape semicolon within single/double quotes(string) |
|
*/ |
|
return query.match(/\b("[^"]*;[^"]*"|'[^']*;[^']*'|[^;])*;/g); |
|
} |
|
|
|
/** |
|
* if sql statement is SELECT - it limits to a number |
|
* @param args |
|
* @returns {string|*} |
|
*/ |
|
sanitiseQuery(args) { |
|
|
|
let q = args.query.trim().split(';'); |
|
|
|
if (q[0].startsWith('Select')) { |
|
q = q[0] + ` LIMIT 0,${args.limit ? args.limit : 100};` |
|
} else if (q[0].startsWith('select')) { |
|
q = q[0] + ` LIMIT 0,${args.limit ? args.limit : 100};` |
|
} else if (q[0].startsWith('SELECT')) { |
|
q = q[0] + ` LIMIT 0,${args.limit ? args.limit : 100};` |
|
} else { |
|
return args.query; |
|
} |
|
|
|
return q; |
|
|
|
} |
|
|
|
static getColumnsFromJson(json, tn) { |
|
|
|
const columns = []; |
|
|
|
try { |
|
if (typeof json === 'object' && !Array.isArray(json)) { |
|
|
|
let keys = Object.keys(json); |
|
for (let i = 0; i < keys.length; ++i) { |
|
const column = { |
|
"dp": null, |
|
"tn": tn, |
|
"cn": keys[i], |
|
"cno": keys[i], |
|
"np": 10, |
|
"ns": 0, |
|
"clen": null, |
|
"cop": 1, |
|
"pk": false, |
|
"nrqd": false, |
|
"rqd": false, |
|
"un": false, |
|
"ct": "int(11) unsigned", |
|
"ai": false, |
|
"unique": false, |
|
"cdf": null, |
|
"cc": "", |
|
"csn": null, |
|
"dtx": "specificType", |
|
"dtxp": null, |
|
"dtxs": 0, |
|
altered: 1 |
|
}; |
|
|
|
switch (typeof json[keys[i]]) { |
|
|
|
case 'number': |
|
if (Number.isInteger(json[keys[i]])) { |
|
if (PgUi.isValidTimestamp(keys[i], json[keys[i]])) { |
|
Object.assign(column, { |
|
"dt": "timestamp" |
|
}); |
|
} else { |
|
Object.assign(column, { |
|
"dt": "int", |
|
"np": 10, |
|
"ns": 0, |
|
}); |
|
} |
|
} else { |
|
Object.assign(column, { |
|
"dt": "float4", |
|
"np": null, |
|
"ns": null, |
|
"dtxp": null, |
|
"dtxs": null, |
|
}); |
|
} |
|
break; |
|
case 'string': |
|
if (PgUi.isValidDate(json[keys[i]])) { |
|
Object.assign(column, { |
|
"dt": "date" |
|
}); |
|
} else if (json[keys[i]].length <= 255) { |
|
Object.assign(column, { |
|
"dt": "character varying", |
|
"np": null, |
|
"ns": 0, |
|
"dtxp": null, |
|
}); |
|
} else { |
|
Object.assign(column, { |
|
"dt": "text" |
|
}); |
|
} |
|
break; |
|
case 'boolean': |
|
Object.assign(column, { |
|
"dt": "boolean", |
|
"np": 3, |
|
"ns": 0, |
|
}); |
|
break; |
|
case 'object': |
|
Object.assign(column, { |
|
"dt": "json", |
|
"np": 3, |
|
"ns": 0, |
|
}); |
|
break; |
|
default: |
|
break; |
|
} |
|
columns.push(column) |
|
} |
|
|
|
} |
|
} catch (e) { |
|
console.log('Error in getColumnsFromJson', e); |
|
} finally { |
|
} |
|
|
|
return columns; |
|
} |
|
|
|
static isValidTimestamp(key, value) { |
|
if (typeof value !== 'number') return false; |
|
return new Date(value).getTime() > 0 && /(?:_|(?=A))[aA]t$/.test(key); |
|
} |
|
|
|
static isValidDate(value) { |
|
return new Date(value).getTime() > 0; |
|
} |
|
|
|
|
|
static colPropAuDisabled(col) { |
|
|
|
if (col.altered !== 1) return true; |
|
|
|
|
|
switch (col.dt) { |
|
case "time": |
|
case "time without time zone": |
|
case "timestamp": |
|
case "timestamp without time zone": |
|
case "timestamptz": |
|
case "timestamp with time zone": |
|
case "timetz": |
|
case "time with time zone": |
|
return false; |
|
break; |
|
default: |
|
return true; |
|
} |
|
} |
|
|
|
|
|
static getAbstractType(col) { |
|
switch ((col.dt || col.dt).toLowerCase()) { |
|
case "anyenum": |
|
return 'enum'; |
|
case "anynonarray": |
|
case "anyrange": |
|
return 'string'; |
|
|
|
case "bit": |
|
return 'integer'; |
|
case "bigint": |
|
case "bigserial": |
|
return 'string'; |
|
|
|
case "bool": |
|
return 'boolean'; |
|
|
|
case "box": |
|
case "bpchar": |
|
case "bytea": |
|
case "char": |
|
case "character": |
|
return 'string'; |
|
|
|
case "cid": |
|
case "cidr": |
|
case "circle": |
|
case "cstring": |
|
return 'string' |
|
|
|
case "date": |
|
return 'date' |
|
case "daterange": |
|
return 'string' |
|
case "double precision": |
|
return 'string'; |
|
|
|
case "event_trigger": |
|
case "fdw_handler": |
|
return 'string'; |
|
|
|
case "float4": |
|
case "float8": |
|
return 'float'; |
|
|
|
case "gtsvector": |
|
case "index_am_handler": |
|
case "inet": |
|
return 'string'; |
|
|
|
case "int": |
|
case "int2": |
|
case "int4": |
|
case "int8": |
|
case "integer": |
|
return 'integer' |
|
case "int4range": |
|
case "int8range": |
|
case "internal": |
|
case "interval": |
|
return 'string' |
|
case "json": |
|
return 'json' |
|
case "jsonb": |
|
return 'string'; |
|
|
|
case "language_handler": |
|
case "line": |
|
case "lsec": |
|
case "macaddr": |
|
case "money": |
|
case "name": |
|
case "numeric": |
|
case "numrange": |
|
case "oid": |
|
case "opaque": |
|
case "path": |
|
case "pg_ddl_command": |
|
case "pg_lsn": |
|
case "pg_node_tree": |
|
case "point": |
|
case "polygon": |
|
return 'string'; |
|
case "real": |
|
return 'float'; |
|
case "record": |
|
case "refcursor": |
|
case "regclass": |
|
case "regconfig": |
|
case "regdictionary": |
|
case "regnamespace": |
|
case "regoper": |
|
case "regoperator": |
|
case "regproc": |
|
case "regpreocedure": |
|
case "regrole": |
|
case "regtype": |
|
case "reltime": |
|
return 'string' |
|
case "serial": |
|
case "serial2": |
|
case "serial8": |
|
case "smallint": |
|
case "smallserial": |
|
return 'integer' |
|
case "smgr": |
|
return 'string' |
|
case "text": |
|
return 'text' |
|
case "tid": |
|
return 'string' |
|
case "time": |
|
case "time without time zone": |
|
return 'time' |
|
case "timestamp": |
|
case "timestamp without time zone": |
|
case "timestamptz": |
|
case "timestamp with time zone": |
|
return 'datetime' |
|
case "timetz": |
|
case "time with time zone": |
|
return 'time' |
|
|
|
case "tinterval": |
|
case "trigger": |
|
case "tsm_handler": |
|
case "tsquery": |
|
case "tsrange": |
|
case "tstzrange": |
|
case "tsvector": |
|
case "txid_snapshot": |
|
case "unknown": |
|
case "void": |
|
case "xid": |
|
case "character varying": |
|
case "xml": |
|
return 'string' |
|
|
|
case "tinyint": |
|
case "mediumint": |
|
return 'integer' |
|
|
|
case "float": |
|
case "decimal": |
|
case "double": |
|
return 'float' |
|
case "boolean": |
|
return 'boolean' |
|
case "datetime": |
|
return 'datetime' |
|
|
|
case "uuid": |
|
case "year": |
|
case "varchar": |
|
case "nchar": |
|
return 'string' |
|
case "tinytext": |
|
case "mediumtext": |
|
case "longtext": |
|
return 'text' |
|
case "binary": |
|
case "varbinary": |
|
return 'string' |
|
case "blob": |
|
case "tinyblob": |
|
case "mediumblob": |
|
case "longblob": |
|
return 'blob' |
|
case "enum": |
|
return 'enum' |
|
case "set": |
|
return 'set' |
|
case "geometry": |
|
case "linestring": |
|
case "multipoint": |
|
case "multilinestring": |
|
case "multipolygon": |
|
return 'string' |
|
case "json": |
|
return 'json' |
|
} |
|
} |
|
|
|
static getUIType(col) { |
|
switch (this.getAbstractType(col)) { |
|
case 'integer': |
|
return 'Number'; |
|
case "boolean": |
|
return 'Checkbox'; |
|
case 'float': |
|
return 'Decimal'; |
|
case "date": |
|
return 'Date'; |
|
case "datetime": |
|
return 'CreateTime'; |
|
case "time": |
|
return 'Time'; |
|
case 'year': |
|
return 'Year'; |
|
case 'string': |
|
return 'SingleLineText'; |
|
case "text": |
|
return 'LongText'; |
|
case 'blob': |
|
return 'Attachment' |
|
case "enum": |
|
return 'SingleSelect'; |
|
case "set": |
|
return 'MultiSelect'; |
|
case "json": |
|
return 'LongText'; |
|
} |
|
|
|
} |
|
|
|
|
|
static getDataTypeForUiType(col) { |
|
const colProp = {} |
|
switch (col.uidt) { |
|
case 'ID': |
|
colProp.dt = 'int4'; |
|
colProp.pk = true; |
|
colProp.un = true; |
|
colProp.ai = true; |
|
colProp.rqd = true; |
|
break; |
|
case 'ForeignKey': |
|
colProp.dt = 'character varying'; |
|
break; |
|
case 'SingleLineText': |
|
colProp.dt = 'character varying'; |
|
break; |
|
case 'LongText': |
|
colProp.dt = 'text'; |
|
break; |
|
case 'Attachment': |
|
colProp.dt = 'text'; |
|
break; |
|
case 'Checkbox': |
|
colProp.dt = 'bool'; |
|
break; |
|
case 'MultiSelect': |
|
colProp.dt = 'text'; |
|
break; |
|
case 'SingleSelect': |
|
colProp.dt = 'text'; |
|
break; |
|
case 'Collaborator': |
|
colProp.dt = 'character varying'; |
|
break; |
|
case 'Date': |
|
colProp.dt = 'character varying'; |
|
|
|
break; |
|
case 'Year': |
|
colProp.dt = 'year'; |
|
break; |
|
case 'Time': |
|
colProp.dt = 'time'; |
|
break; |
|
case 'PhoneNumber': |
|
colProp.dt = 'character varying'; |
|
colProp.validate = {"func": ["isMobilePhone"], "args": [""], "msg": ["Validation failed : isMobilePhone"]} |
|
break; |
|
case 'Email': |
|
colProp.dt = 'character varying'; |
|
colProp.validate = {"func": ["isEmail"], "args": [""], "msg": ["Validation failed : isEmail"]} |
|
break; |
|
case 'URL': |
|
colProp.dt = 'character varying'; |
|
colProp.validate = {"func": ["isURL"], "args": [""], "msg": ["Validation failed : isURL"]} |
|
break; |
|
case 'Number': |
|
colProp.dt = 'int8'; |
|
break; |
|
case 'Decimal': |
|
colProp.dt = 'decimal'; |
|
break; |
|
case 'Currency': |
|
colProp.dt = 'decimal'; |
|
colProp.validate = {"func": ["isCurrency"], "args": [""], "msg": ["Validation failed : isCurrency"]} |
|
break; |
|
case 'Percent': |
|
colProp.dt = 'double'; |
|
break; |
|
case 'Duration': |
|
colProp.dt = 'int8'; |
|
break; |
|
case 'Rating': |
|
colProp.dt = 'float8'; |
|
break; |
|
case 'Formula': |
|
colProp.dt = 'character varying'; |
|
break; |
|
case 'Rollup': |
|
colProp.dt = 'character varying'; |
|
break; |
|
case 'Count': |
|
colProp.dt = 'int8'; |
|
break; |
|
case 'Lookup': |
|
colProp.dt = 'character varying'; |
|
break; |
|
case 'DateTime': |
|
colProp.dt = 'datetime'; |
|
break; |
|
case 'CreateTime': |
|
colProp.dt = 'datetime'; |
|
break; |
|
case 'LastModifiedTime': |
|
colProp.dt = 'datetime'; |
|
break; |
|
case 'AutoNumber': |
|
colProp.dt = 'int'; |
|
break; |
|
case 'Barcode': |
|
colProp.dt = 'character varying'; |
|
break; |
|
case 'Button': |
|
colProp.dt = 'character varying'; |
|
break; |
|
default: |
|
colProp.dt = 'character varying'; |
|
break; |
|
} |
|
return colProp |
|
} |
|
|
|
|
|
static getDataTypeListForUiType(col) { |
|
switch (col.uidt) { |
|
case 'ID': |
|
case 'ForeignKey': |
|
return dbTypes; |
|
break; |
|
case 'SingleLineText': |
|
case 'LongText': |
|
case 'Attachment': |
|
case 'Collaborator': |
|
return [ |
|
"char", |
|
"character", |
|
"character varying", |
|
"text", |
|
]; |
|
break; |
|
case 'Checkbox': |
|
return [ |
|
"bit", |
|
"bool", |
|
"int2", |
|
"int4", |
|
"int8", |
|
"boolean", |
|
"smallint", |
|
"int", |
|
"integer", |
|
"bigint", |
|
"bigserial", |
|
"char", |
|
"int4range", |
|
"int8range", |
|
"serial", |
|
"serial2", |
|
"serial8", |
|
] |
|
break; |
|
case 'MultiSelect': |
|
return [ |
|
"text", |
|
]; |
|
break; |
|
case 'SingleSelect': |
|
return [ |
|
'anyenum', |
|
"text", |
|
]; |
|
break; |
|
case 'Year': |
|
return ['int']; |
|
break; |
|
case 'Time': |
|
return ["time", |
|
"time without time zone", |
|
"timestamp", |
|
"timestamp without time zone", |
|
"timestamptz", |
|
"timestamp with time zone", |
|
"timetz", |
|
"time with time zone",]; |
|
break; |
|
case 'PhoneNumber': |
|
case 'Email': |
|
return [ |
|
"character varying", |
|
]; |
|
break; |
|
case 'URL': |
|
return [ |
|
"character varying", |
|
"text", |
|
]; |
|
break; |
|
case 'Number': |
|
return [ |
|
"int", |
|
"integer", |
|
"bigint", |
|
"bigserial", |
|
"int2", |
|
"int4", |
|
"int8", |
|
"serial", |
|
"serial2", |
|
"serial8", |
|
"double precision", |
|
"float4", |
|
"float8", |
|
"smallint", |
|
"smallserial", |
|
] |
|
break; |
|
case 'Decimal': |
|
return [ |
|
"double precision", |
|
"float4", |
|
"float8", |
|
] |
|
break; |
|
case 'Currency': |
|
return [ |
|
"int", |
|
"integer", |
|
"bigint", |
|
"bigserial", |
|
"int2", |
|
"int4", |
|
"int8", |
|
"serial", |
|
"serial2", |
|
"serial8", |
|
"double precision", |
|
"money", "float4", |
|
"float8",]; |
|
break; |
|
case 'Percent': |
|
return [ |
|
"int", |
|
"integer", |
|
"bigint", |
|
"bigserial", |
|
"int2", |
|
"int4", |
|
"int8", |
|
"serial", |
|
"serial2", |
|
"serial8", |
|
"double precision", |
|
"float4", |
|
"float8", |
|
"smallint", |
|
"smallserial", |
|
] |
|
break; |
|
case 'Duration': |
|
return [ |
|
"int", |
|
"integer", |
|
"bigint", |
|
"bigserial", |
|
"int2", |
|
"int4", |
|
"int8", |
|
"serial", |
|
"serial2", |
|
"serial8", |
|
"double precision", |
|
"float4", |
|
"float8", |
|
"smallint", |
|
"smallserial",] |
|
break; |
|
case 'Rating': |
|
return [ |
|
"int", |
|
"integer", |
|
"bigint", |
|
"bigserial", |
|
"int2", |
|
"int4", |
|
"int8", |
|
"serial", |
|
"serial2", |
|
"serial8", |
|
"double precision", |
|
"float4", |
|
"float8", |
|
"smallint", |
|
"smallserial",] |
|
break; |
|
case 'Formula': |
|
return [ |
|
"text", |
|
"character varying", |
|
]; |
|
break; |
|
case 'Rollup': |
|
return [ |
|
"character varying", |
|
]; |
|
break; |
|
case 'Count': |
|
return [ |
|
"int", |
|
"integer", |
|
"bigint", |
|
"bigserial", |
|
"int2", |
|
"int4", |
|
"int8", |
|
"serial", |
|
"serial2", |
|
"serial8", |
|
"smallint", |
|
"smallserial", |
|
]; |
|
break; |
|
case 'Lookup': |
|
return [ |
|
"character varying", |
|
]; |
|
break; |
|
case 'Date': |
|
return [ |
|
"date", |
|
"timestamp", |
|
"timestamp without time zone", |
|
"timestamptz", |
|
"timestamp with time zone", |
|
]; |
|
break; |
|
case 'DateTime': |
|
case 'CreateTime': |
|
case 'LastModifiedTime': |
|
return [ |
|
"timestamp", |
|
"timestamp without time zone", |
|
"timestamptz", |
|
"timestamp with time zone", |
|
]; |
|
break; |
|
case 'AutoNumber': |
|
return |
|
return [ |
|
"int", |
|
"integer", |
|
"bigint", |
|
"bigserial", |
|
"int2", |
|
"int4", |
|
"int8", |
|
"serial", |
|
"serial2", |
|
"serial8", |
|
"smallint", |
|
"smallserial", |
|
]; |
|
break; |
|
case 'Barcode': |
|
return ['character varying']; |
|
break; |
|
case 'Geometry': |
|
return [ |
|
"polygon", |
|
"point", |
|
"circle", |
|
"box", |
|
"line", |
|
'lseg', |
|
'path', |
|
'circle' |
|
]; |
|
break; |
|
case 'Button': |
|
default: |
|
return dbTypes; |
|
break; |
|
} |
|
} |
|
|
|
|
|
} |
|
|
|
|
|
// module.exports = PgUiHelp; |
|
/** |
|
* @copyright Copyright (c) 2021, Xgene Cloud Ltd |
|
* |
|
* @author Naveen MR <oof1lab@gmail.com> |
|
* @author Pranav C Balan <pranavxc@gmail.com> |
|
* |
|
* @license GNU AGPL version 3 or any later version |
|
* |
|
* This program is free software: you can redistribute it and/or modify |
|
* it under the terms of the GNU Affero 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 Affero General Public License for more details. |
|
* |
|
* You should have received a copy of the GNU Affero General Public License |
|
* along with this program. If not, see <http://www.gnu.org/licenses/>. |
|
* |
|
*/
|
|
|