beech-api 3.5.12 → 3.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +400 -185
- package/index.js +2 -3
- package/package.json +9 -6
- package/packages/cli/beech +2 -2
- package/packages/cli/bin/{beech.js → beech-app.js} +86 -28
- package/packages/cli/bin/beech-service.js +40 -212
- package/packages/cli/core/auth/Credentials.js +76 -35
- package/packages/cli/core/auth/Passport.js +318 -188
- package/packages/cli/core/auth/_Request.js +12 -0
- package/packages/cli/core/configure/_gitignore +9 -1
- package/packages/cli/core/configure/app.config-basic.js +10 -10
- package/packages/cli/core/configure/app.config-sequelize.js +12 -12
- package/packages/cli/core/configure/beech.config.js +8 -0
- package/packages/cli/core/configure/global.config-basic.js +4 -4
- package/packages/cli/core/configure/global.config-sequelize.js +4 -4
- package/packages/cli/core/configure/passport.config.js +5 -15
- package/packages/cli/core/databases/mysql.js +53 -29
- package/packages/cli/core/databases/sequelize.js +135 -107
- package/packages/cli/core/databases/test.js +168 -0
- package/packages/cli/core/file-walk/file-walk.js +31 -14
- package/packages/cli/core/generator/_add-on +15 -2
- package/packages/cli/core/generator/_endpoints +15 -82
- package/packages/cli/core/generator/_endpoints_basic +39 -0
- package/packages/cli/core/generator/_help +12 -11
- package/packages/cli/core/generator/_help_create +11 -0
- package/packages/cli/core/generator/{_service → _help_service} +4 -1
- package/packages/cli/core/generator/_models +20 -15
- package/packages/cli/core/generator/{_basic-models → _models_basic} +0 -2
- package/packages/cli/core/generator/_package +4 -3
- package/packages/cli/core/generator/index.js +302 -95
- package/packages/cli/core/helpers/math.js +55 -0
- package/packages/cli/core/helpers/poolEntity.js +31 -0
- package/packages/cli/core/index.js +96 -28
- package/packages/cli/core/origin/index.js +2 -0
- package/packages/cli/core/origin/whitelist/cors.js +91 -0
- package/packages/cli/core/services/http.express.js +338 -203
- package/packages/cli/core/test/utils.js +5 -5
- package/packages/lib/index.js +4 -0
- package/packages/lib/src/endpoint.js +98 -0
- package/packages/lib/src/salt.js +3 -0
- package/packages/lib/src/schema.js +62 -0
- package/packages/lib/src/user.js +196 -0
- package/packages/package.json +4 -7
- package/packages/cli/core/generator/_create +0 -7
- package/packages/lib/beech.js +0 -136
- package/packages/lib/salt.js +0 -3
- package/packages/src-/Add-on.js +0 -9
- package/packages/src-/endpoints/hello-endpoints.js +0 -118
- package/packages/src-/endpoints/test2-endpoints.js +0 -75
- package/packages/src-/endpoints/testSequalize-endpoints.js +0 -23
- package/packages/src-/helpers/Test2.js +0 -11
- package/packages/src-/helpers/my/Test.js +0 -11
- package/packages/src-/helpers/my/Test2.js +0 -11
- package/packages/src-/helpers/my/Test3.js +0 -11
- package/packages/src-/helpers/my/Test4.js +0 -11
- package/packages/src-/models/Jubu.js +0 -29
- package/packages/src-/models/Jubu2.js +0 -20
- package/packages/src-/models/Map_master.js +0 -22
- package/packages/src-/models/Test.js +0 -29
- package/packages/src-/models/Test2.js +0 -29
- package/packages/src-/models/User2Sequelize.js +0 -23
- package/packages/src-/models/Users-sqlite.js +0 -21
- package/packages/src-/models/Users.js +0 -53
- package/packages/src-/models/Uuuuuxxx.js +0 -23
- package/packages/src-/models/xxx/Uuuuuxxx.js +0 -23
- /package/packages/cli/core/generator/{_basic-helpers → _helpers_basic} +0 -0
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
// You can require something
|
|
2
|
-
|
|
3
|
-
exports.init = () => {
|
|
4
|
-
// Initiate with basic request currently support GET, POST, PUT, PATCH and DELETE
|
|
5
|
-
|
|
6
|
-
/@GET/
|
|
7
|
-
endpoint.get('/test2', Credentials, (req, res) => {
|
|
8
|
-
// basic get method
|
|
9
|
-
let data = {};
|
|
10
|
-
data.code = 200;
|
|
11
|
-
data.message = 'Got a GET request.';
|
|
12
|
-
// @return
|
|
13
|
-
res.json(data);
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
/@POST/
|
|
17
|
-
endpoint.post('/test2', Credentials, (req, res) => {
|
|
18
|
-
/**
|
|
19
|
-
* @param Integer id
|
|
20
|
-
*
|
|
21
|
-
* @return json
|
|
22
|
-
*/
|
|
23
|
-
let id = req.body.id;
|
|
24
|
-
let data = {};
|
|
25
|
-
data.code = 200;
|
|
26
|
-
data.message = 'Got a POST request.';
|
|
27
|
-
// @return
|
|
28
|
-
res.json(data);
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
/@PUT/
|
|
32
|
-
endpoint.put('/test2/:id', Credentials, (req, res) => {
|
|
33
|
-
/**
|
|
34
|
-
* @param Integer id
|
|
35
|
-
*
|
|
36
|
-
* @return json
|
|
37
|
-
*/
|
|
38
|
-
let id = req.params.id;
|
|
39
|
-
let data = {};
|
|
40
|
-
data.code = 200;
|
|
41
|
-
data.message = 'Got a PUT request at /test2/' + id;
|
|
42
|
-
// @return
|
|
43
|
-
res.json(data);
|
|
44
|
-
});
|
|
45
|
-
|
|
46
|
-
/@PATCH/
|
|
47
|
-
endpoint.patch('/test2/:id', Credentials, (req, res) => {
|
|
48
|
-
/**
|
|
49
|
-
* @param Integer id
|
|
50
|
-
*
|
|
51
|
-
* @return json
|
|
52
|
-
*/
|
|
53
|
-
let id = req.params.id;
|
|
54
|
-
let data = {};
|
|
55
|
-
data.code = 200;
|
|
56
|
-
data.message = 'Got a PATCH request at /test2/' + id;
|
|
57
|
-
// @return
|
|
58
|
-
res.json(data);
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
/@DELETE/
|
|
62
|
-
endpoint.delete('/test2/:id', Credentials, (req, res) => {
|
|
63
|
-
/**
|
|
64
|
-
* @param Integer id
|
|
65
|
-
*
|
|
66
|
-
* @return json
|
|
67
|
-
*/
|
|
68
|
-
let id = req.params.id;
|
|
69
|
-
let data = {};
|
|
70
|
-
data.code = 200;
|
|
71
|
-
data.message = 'Got a DELETE request at /test2/' + id;
|
|
72
|
-
// @return
|
|
73
|
-
res.json(data);
|
|
74
|
-
});
|
|
75
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
const Users = require("@/models/Users");
|
|
2
|
-
const Test = require("@/models/Test");
|
|
3
|
-
|
|
4
|
-
exports.init = () => {
|
|
5
|
-
// Initiate with basic request currently support GET, POST, PUT, PATCH and DELETE
|
|
6
|
-
|
|
7
|
-
/@GET/
|
|
8
|
-
endpoint.get('/testSequalize', Credentials, async (req, res) => {
|
|
9
|
-
|
|
10
|
-
let data = {};
|
|
11
|
-
data.code = 200;
|
|
12
|
-
|
|
13
|
-
data.results = await Users.getData();
|
|
14
|
-
|
|
15
|
-
data.resultTest = await Test.getData();
|
|
16
|
-
|
|
17
|
-
// @return
|
|
18
|
-
res.json(data);
|
|
19
|
-
});
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
const data = [
|
|
2
|
-
{ "id": 1, "name": "Oggy" },
|
|
3
|
-
{ "id": 2, "name": "Jack" },
|
|
4
|
-
{ "id": 3, "name": "The Cockroaches Gang" }
|
|
5
|
-
];
|
|
6
|
-
|
|
7
|
-
module.exports = {
|
|
8
|
-
|
|
9
|
-
// Example basic function get constant data
|
|
10
|
-
getData() {
|
|
11
|
-
return data;
|
|
12
|
-
},
|
|
13
|
-
|
|
14
|
-
// Example basic function get data from Database (must be return promise)
|
|
15
|
-
findAll() {
|
|
16
|
-
return new Promise((resolve, reject) => {
|
|
17
|
-
try {
|
|
18
|
-
// call mysql `default_db` connection
|
|
19
|
-
mysql.default_db.query("SELECT * FROM jubu", (err, results) => {
|
|
20
|
-
if (err) { reject(err) }
|
|
21
|
-
resolve(results);
|
|
22
|
-
});
|
|
23
|
-
} catch (error) {
|
|
24
|
-
reject(error);
|
|
25
|
-
}
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
// You can asign datatype see more: https://sequelize.org/docs/v6/core-concepts/model-basics/#data-types
|
|
2
|
-
const Jubu2 = sql.default_db.define("jubu2", {
|
|
3
|
-
id: DataTypes.INTEGER,
|
|
4
|
-
examField1: DataTypes.STRING,
|
|
5
|
-
examField2: DataTypes.DATE,
|
|
6
|
-
});
|
|
7
|
-
|
|
8
|
-
module.exports = {
|
|
9
|
-
|
|
10
|
-
// Example basic function get one constant data
|
|
11
|
-
async getJubu2ById(id) {
|
|
12
|
-
return await Jubu2.findOne({ where: { id: id } });
|
|
13
|
-
},
|
|
14
|
-
|
|
15
|
-
// Example basic function get all data from Database (must be return promise)
|
|
16
|
-
async findAll() {
|
|
17
|
-
return await Jubu2.findAll();
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
// You can asign datatype see more: https://sequelize.org/docs/v6/core-concepts/model-basics/#data-types
|
|
2
|
-
const Map_master = sql.mysql_first_db.define("map_master", {
|
|
3
|
-
id: {
|
|
4
|
-
type: DataTypes.INTEGER,
|
|
5
|
-
autoIncrement: true,
|
|
6
|
-
primaryKey: true
|
|
7
|
-
},
|
|
8
|
-
});
|
|
9
|
-
|
|
10
|
-
module.exports = {
|
|
11
|
-
|
|
12
|
-
// Example basic function get one constant data
|
|
13
|
-
async findMap_masterById(id) {
|
|
14
|
-
return await Map_master.findOne({ where: { id: id } });
|
|
15
|
-
},
|
|
16
|
-
|
|
17
|
-
// Example basic function get all data from Database (must be return promise)
|
|
18
|
-
async findAll() {
|
|
19
|
-
return await Map_master.findAll();
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
const data = [
|
|
2
|
-
{ "id": 1, "name": "Oggy" },
|
|
3
|
-
{ "id": 2, "name": "Jack" },
|
|
4
|
-
{ "id": 3, "name": "The Cockroaches Gang" }
|
|
5
|
-
];
|
|
6
|
-
|
|
7
|
-
module.exports = {
|
|
8
|
-
|
|
9
|
-
// Example basic function get constant data
|
|
10
|
-
getData() {
|
|
11
|
-
return data;
|
|
12
|
-
},
|
|
13
|
-
|
|
14
|
-
// Example basic function get data from MySQL (must be return promise)
|
|
15
|
-
findAll() {
|
|
16
|
-
return new Promise((resolve, reject) => {
|
|
17
|
-
try {
|
|
18
|
-
// call mysql `default_db` connection
|
|
19
|
-
mysql.default_db.query("SELECT * FROM test", (err, results) => {
|
|
20
|
-
if (err) { reject(err) }
|
|
21
|
-
resolve(results);
|
|
22
|
-
});
|
|
23
|
-
} catch (error) {
|
|
24
|
-
reject(error);
|
|
25
|
-
}
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
const data = [
|
|
2
|
-
{ "id": 1, "name": "Oggy" },
|
|
3
|
-
{ "id": 2, "name": "Jack" },
|
|
4
|
-
{ "id": 3, "name": "The Cockroaches Gang" }
|
|
5
|
-
];
|
|
6
|
-
|
|
7
|
-
module.exports = {
|
|
8
|
-
|
|
9
|
-
// Example basic function get constant data
|
|
10
|
-
getData() {
|
|
11
|
-
return data;
|
|
12
|
-
},
|
|
13
|
-
|
|
14
|
-
// Example basic function get data from MySQL (must be return promise)
|
|
15
|
-
findAll() {
|
|
16
|
-
return new Promise((resolve, reject) => {
|
|
17
|
-
try {
|
|
18
|
-
// call mysql `default_db` connection
|
|
19
|
-
mysql.default_db.query("SELECT * FROM test2", (err, results) => {
|
|
20
|
-
if (err) { reject(err) }
|
|
21
|
-
resolve(results);
|
|
22
|
-
});
|
|
23
|
-
} catch (error) {
|
|
24
|
-
reject(error);
|
|
25
|
-
}
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
// You can asign datatype see more: https://sequelize.org/docs/v6/core-concepts/model-basics/#data-types
|
|
2
|
-
const User2Sequelize = sql.mysql_first_db.define("users", {
|
|
3
|
-
id: {
|
|
4
|
-
type: DataTypes.INTEGER,
|
|
5
|
-
autoIncrement: true,
|
|
6
|
-
primaryKey: true
|
|
7
|
-
},
|
|
8
|
-
name: DataTypes.STRING,
|
|
9
|
-
});
|
|
10
|
-
|
|
11
|
-
module.exports = {
|
|
12
|
-
|
|
13
|
-
// Example basic function get one constant data
|
|
14
|
-
async findUser2SequelizeById(id) {
|
|
15
|
-
return await User2Sequelize.findOne({ where: { 'id': id } });
|
|
16
|
-
},
|
|
17
|
-
|
|
18
|
-
// Example basic function get all data from Database (must be return promise)
|
|
19
|
-
async findAll() {
|
|
20
|
-
return await User2Sequelize.findAll();
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
const Users = sql.sqlite_db.define("users", {
|
|
2
|
-
id: {
|
|
3
|
-
type: DataTypes.INTEGER,
|
|
4
|
-
autoIncrement: true,
|
|
5
|
-
primaryKey: true
|
|
6
|
-
},
|
|
7
|
-
});
|
|
8
|
-
|
|
9
|
-
module.exports = {
|
|
10
|
-
|
|
11
|
-
// Example basic function get one constant data
|
|
12
|
-
findUsersById(id) {
|
|
13
|
-
return Users.findOne({ where: { id: id } });
|
|
14
|
-
},
|
|
15
|
-
|
|
16
|
-
// Example basic function get all data from table users
|
|
17
|
-
findAll() {
|
|
18
|
-
return Users.findAll();
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
}
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
// You can asign datatype see more: https://sequelize.org/docs/v6/core-concepts/model-basics/#data-types
|
|
2
|
-
const Users = sql.mysql_first_db.define('users', {
|
|
3
|
-
id: {
|
|
4
|
-
type: DataTypes.INTEGER,
|
|
5
|
-
autoIncrement: true,
|
|
6
|
-
primaryKey: true
|
|
7
|
-
},
|
|
8
|
-
username: DataTypes.STRING,
|
|
9
|
-
password: {
|
|
10
|
-
type: DataTypes.STRING,
|
|
11
|
-
set(value) {
|
|
12
|
-
// Storing passwords in plaintext in the database is terrible.
|
|
13
|
-
// Hashing the value with an appropriate cryptographic hash function is better.
|
|
14
|
-
this.setDataValue('password', hash(value));
|
|
15
|
-
}
|
|
16
|
-
},
|
|
17
|
-
name: DataTypes.STRING,
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
module.exports = {
|
|
23
|
-
|
|
24
|
-
// Example basic function get constant data
|
|
25
|
-
getData() {
|
|
26
|
-
let user = Users.findAll();
|
|
27
|
-
//console.log(user);
|
|
28
|
-
return user;
|
|
29
|
-
},
|
|
30
|
-
|
|
31
|
-
// Example basic function get data from MySQL (must be return promise)
|
|
32
|
-
findAll() {
|
|
33
|
-
return new Promise(async (resolve, reject) => {
|
|
34
|
-
try {
|
|
35
|
-
|
|
36
|
-
let raw = await sql.default_db.query("SELECT * FROM users LIMIT 1", { type: QueryTypes.SELECT }); // mysql
|
|
37
|
-
//let raw = await sql.second_db.query("SELECT * FROM usercon LIMIT 10"); // sqlite
|
|
38
|
-
// let raw = await this.sql.thirdth_db.query("SELECT TOP 10 * FROM usercon"); // mssql
|
|
39
|
-
|
|
40
|
-
//console.log(sql);
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
resolve(raw);
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
} catch (error) {
|
|
48
|
-
reject(error);
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
const Uuuuuxxx = sql.second_db.define("uuuuuxxx", {
|
|
2
|
-
id: {
|
|
3
|
-
type: DataTypes.INTEGER,
|
|
4
|
-
autoIncrement: true,
|
|
5
|
-
primaryKey: true,
|
|
6
|
-
},
|
|
7
|
-
examField1: DataTypes.STRING, // asign more DataTypes see more: https://sequelize.org/docs/v6/core-concepts/model-basics/#data-types
|
|
8
|
-
examField2: DataTypes.DATE,
|
|
9
|
-
});
|
|
10
|
-
|
|
11
|
-
module.exports = {
|
|
12
|
-
|
|
13
|
-
// Example basic function get one by id
|
|
14
|
-
findUuuuuxxxById(id) {
|
|
15
|
-
return Uuuuuxxx.findOne({ where: { id: id } });
|
|
16
|
-
},
|
|
17
|
-
|
|
18
|
-
// Example basic function get all data from table uuuuuxxx
|
|
19
|
-
findAll() {
|
|
20
|
-
return Uuuuuxxx.findAll();
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
const Uuuuuxxx = sql.second_db.define("uuuuuxxx", {
|
|
2
|
-
id: {
|
|
3
|
-
type: DataTypes.INTEGER,
|
|
4
|
-
autoIncrement: true,
|
|
5
|
-
primaryKey: true,
|
|
6
|
-
},
|
|
7
|
-
examField1: DataTypes.STRING, // asign more DataTypes see more: https://sequelize.org/docs/v6/core-concepts/model-basics/#data-types
|
|
8
|
-
examField2: DataTypes.DATE,
|
|
9
|
-
});
|
|
10
|
-
|
|
11
|
-
module.exports = {
|
|
12
|
-
|
|
13
|
-
// Example basic function get one by id
|
|
14
|
-
findUuuuuxxxById(id) {
|
|
15
|
-
return Uuuuuxxx.findOne({ where: { id: id } });
|
|
16
|
-
},
|
|
17
|
-
|
|
18
|
-
// Example basic function get all data from table uuuuuxxx
|
|
19
|
-
findAll() {
|
|
20
|
-
return Uuuuuxxx.findAll();
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
}
|
|
File without changes
|