@keltoi/hydra 1.2.0 → 1.2.1
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/package.json +1 -1
- package/src/handler/index.js +2 -1
- package/src/index.js +2 -0
- package/src/model/error.js +23 -0
- package/src/model/logged.js +1 -3
- package/src/model/status.js +0 -1
- package/src/model/thing.js +0 -1
- package/src/repository/db/context.js +0 -2
- package/src/repository/db/index.js +8 -3
- package/src/repository/db/linked.js +0 -1
- package/src/repository/db/loggedRepository.js +9 -8
- package/src/repository/db/thingRepository.js +4 -2
- package/src/repository/db/tracedRepository.js +25 -13
- package/src/service/index.js +2 -1
package/package.json
CHANGED
package/src/handler/index.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import AppError from "../model/error";
|
|
1
2
|
import Context from "../repository/db/context";
|
|
2
3
|
|
|
3
4
|
export default class Handler {
|
|
@@ -12,6 +13,6 @@ export default class Handler {
|
|
|
12
13
|
|
|
13
14
|
handle(){}
|
|
14
15
|
handleError({ code, message }) {
|
|
15
|
-
return Promise.reject({ code, message });
|
|
16
|
+
return Promise.reject(new AppError({ code, message }));
|
|
16
17
|
}
|
|
17
18
|
}
|
package/src/index.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import AppError from './model/error.js'
|
|
1
2
|
import Traced from './model/traced.js'
|
|
2
3
|
import Logged from './model/logged.js'
|
|
3
4
|
import Model from './model/index.js'
|
|
@@ -18,6 +19,7 @@ import runWhenTrue from './helper/runWhenTrue.js'
|
|
|
18
19
|
import runWhenFalse from './helper/runWhenFalse.js'
|
|
19
20
|
|
|
20
21
|
export {
|
|
22
|
+
AppError,
|
|
21
23
|
Model,
|
|
22
24
|
Thing,
|
|
23
25
|
Traced,
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
class AppError {
|
|
2
|
+
#code
|
|
3
|
+
#message
|
|
4
|
+
|
|
5
|
+
constructor({ code=0, message='' }) {
|
|
6
|
+
this.#code = code
|
|
7
|
+
this.#message = message
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
get view() {
|
|
11
|
+
return {
|
|
12
|
+
code: this.code,
|
|
13
|
+
message: this.message
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
get code() { return this.#code }
|
|
18
|
+
get message() { return this.#message }
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export default AppError
|
package/src/model/logged.js
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
|
-
import knex, {
|
|
1
|
+
import knex, { TableBuilder } from "knex"
|
|
2
2
|
import Model from "./index.js"
|
|
3
|
-
import createTableIfNotExists from "../helper/runWhenTrue.js"
|
|
4
|
-
import runWhenTrue from "../helper/runWhenTrue.js"
|
|
5
3
|
import runWhenFalse from "../helper/runWhenFalse.js"
|
|
6
4
|
|
|
7
5
|
export default class Logged extends Model{
|
package/src/model/status.js
CHANGED
package/src/model/thing.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import knex from "knex";
|
|
2
2
|
import Model from "../../model/index.js";
|
|
3
3
|
import Context from "./context.js";
|
|
4
|
+
import AppError from "../../model/error.js";
|
|
4
5
|
|
|
5
6
|
|
|
6
7
|
export default class Repository{
|
|
@@ -13,7 +14,7 @@ export default class Repository{
|
|
|
13
14
|
static anyOrError(model,err={code:0,message:''}){
|
|
14
15
|
if (!!model) return model
|
|
15
16
|
|
|
16
|
-
throw err;
|
|
17
|
+
throw new AppError(err);
|
|
17
18
|
}
|
|
18
19
|
|
|
19
20
|
static setOrEmpty(array=[],modeling=(e)=>e){
|
|
@@ -67,11 +68,15 @@ export default class Repository{
|
|
|
67
68
|
this.myContext()
|
|
68
69
|
.where(model.key)
|
|
69
70
|
.first()
|
|
70
|
-
.then(model=>Repository
|
|
71
|
+
.then(model=>Repository
|
|
72
|
+
.anyOrError(model,{code:404,message:'Not found'})
|
|
73
|
+
)
|
|
71
74
|
.then(this.Entity.build)
|
|
72
75
|
|
|
73
76
|
list = ()=>
|
|
74
77
|
this.myContext()
|
|
75
78
|
.select()
|
|
76
|
-
.then(result=>Repository
|
|
79
|
+
.then(result=>Repository
|
|
80
|
+
.setOrEmpty(result,this.Entity.build)
|
|
81
|
+
)
|
|
77
82
|
}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import AbstractError from '../../model/error.js';
|
|
1
2
|
import Logged from '../../model/logged.js';
|
|
2
3
|
import Context from './context.js';
|
|
3
4
|
import Repository from './index.js';
|
|
@@ -7,34 +8,34 @@ export default class LoggedRepository extends Repository{
|
|
|
7
8
|
super(model,context)
|
|
8
9
|
}
|
|
9
10
|
|
|
10
|
-
get = (logged = new Logged())=>
|
|
11
|
+
get = (logged = new Logged()) =>
|
|
11
12
|
this.myContext()
|
|
12
13
|
.where({...logged.key})
|
|
13
14
|
.first()
|
|
14
15
|
.then(model => Repository.anyOrError(model,{code:404,message:'Not found'}))
|
|
15
16
|
.then(this.Entity.build)
|
|
16
17
|
|
|
17
|
-
before = (date = new Date(), order = 'asc')=>
|
|
18
|
+
before = (date = new Date(), order = 'asc') =>
|
|
18
19
|
this.myContext()
|
|
19
20
|
.where('createdAt','<',date.toISOString())
|
|
20
21
|
.select()
|
|
21
22
|
.orderBy('createdAt',order)
|
|
22
23
|
.then(result => Repository.setOrEmpty(result,this.Entity.build))
|
|
23
24
|
|
|
24
|
-
after = (date = new Date(), order = 'asc')=>
|
|
25
|
+
after = (date = new Date(), order = 'asc') =>
|
|
25
26
|
this.myContext()
|
|
26
27
|
.where('createdAt','>',date.toISOString())
|
|
27
28
|
.select()
|
|
28
29
|
.orderBy('createdAt',order)
|
|
29
30
|
.then(result => Repository.setOrEmpty(result,this.Entity.build))
|
|
30
31
|
|
|
31
|
-
list = (order='asc')=>
|
|
32
|
+
list = (order='asc') =>
|
|
32
33
|
this.myContext()
|
|
33
34
|
.select()
|
|
34
35
|
.orderBy('createdAt',order)
|
|
35
36
|
.then(result => Repository.setOrEmpty(result,this.Entity.build))
|
|
36
37
|
|
|
37
|
-
insert = (logged = new Logged())=>
|
|
38
|
+
insert = (logged = new Logged()) =>
|
|
38
39
|
this.myContext()
|
|
39
40
|
.insert({
|
|
40
41
|
...logged.entity,
|
|
@@ -43,7 +44,7 @@ export default class LoggedRepository extends Repository{
|
|
|
43
44
|
.then(ids => logged.key = ids[0])
|
|
44
45
|
.then(() => logged)
|
|
45
46
|
|
|
46
|
-
create = (logged = new Logged())=>
|
|
47
|
+
create = (logged = new Logged()) =>
|
|
47
48
|
this.myContext()
|
|
48
49
|
.insert({
|
|
49
50
|
...logged.entity,
|
|
@@ -51,8 +52,8 @@ export default class LoggedRepository extends Repository{
|
|
|
51
52
|
})
|
|
52
53
|
.then(() => logged)
|
|
53
54
|
|
|
54
|
-
update = ()=> Promise.reject(new
|
|
55
|
+
update = () => Promise.reject(new AbstractError({code:400,message:'Cannot update a logged object'}))
|
|
55
56
|
|
|
56
|
-
delete = ()=> Promise.reject(new
|
|
57
|
+
delete = () => Promise.reject(new AbstractError({code:400,message:'Cannot delete a logged object'}))
|
|
57
58
|
|
|
58
59
|
}
|
|
@@ -7,9 +7,11 @@ export default class ThingRepository extends Repository{
|
|
|
7
7
|
super(model,context)
|
|
8
8
|
}
|
|
9
9
|
|
|
10
|
-
getByName=(name='')=>
|
|
10
|
+
getByName = (name='') =>
|
|
11
11
|
this.myContext()
|
|
12
12
|
.where({name})
|
|
13
13
|
.select()
|
|
14
|
-
.then(result=>Repository
|
|
14
|
+
.then(result=>Repository
|
|
15
|
+
.setOrEmpty(result,this.Entity.build)
|
|
16
|
+
)
|
|
15
17
|
}
|
|
@@ -7,51 +7,63 @@ export default class TracedRepository extends Repository{
|
|
|
7
7
|
super(model,context)
|
|
8
8
|
}
|
|
9
9
|
|
|
10
|
-
deceased = (order = 'asc')=>
|
|
10
|
+
deceased = (order = 'asc') =>
|
|
11
11
|
this.myContext()
|
|
12
12
|
.where({active:false})
|
|
13
13
|
.select()
|
|
14
14
|
.orderBy(['createdAt','updatedAt'],order)
|
|
15
|
-
.then(result => Repository
|
|
15
|
+
.then(result => Repository
|
|
16
|
+
.setOrEmpty(result,this.Entity.build)
|
|
17
|
+
)
|
|
16
18
|
|
|
17
|
-
before = (date = new Date(), order = 'asc')=>
|
|
19
|
+
before = (date = new Date(), order = 'asc') =>
|
|
18
20
|
this.myContext()
|
|
19
21
|
.where('createdAt','<',date.toISOString())
|
|
20
22
|
.where({active:true})
|
|
21
23
|
.select()
|
|
22
24
|
.orderBy(['createdAt','updatedAt'],order)
|
|
23
|
-
.then(result => Repository
|
|
25
|
+
.then(result => Repository
|
|
26
|
+
.setOrEmpty(result,this.Entity.build)
|
|
27
|
+
)
|
|
24
28
|
|
|
25
|
-
after = (date=new Date(), order = 'asc')=>
|
|
29
|
+
after = (date=new Date(), order = 'asc') =>
|
|
26
30
|
this.myContext()
|
|
27
31
|
.where('createdAt','>',date.toISOString())
|
|
28
32
|
.where({active:true})
|
|
29
33
|
.select()
|
|
30
34
|
.orderBy(['createdAt','updatedAt'],order)
|
|
31
|
-
.then(result => Repository
|
|
35
|
+
.then(result => Repository
|
|
36
|
+
.setOrEmpty(result,this.Entity.build)
|
|
37
|
+
)
|
|
32
38
|
|
|
33
|
-
list = (order = 'asc')=>
|
|
39
|
+
list = (order = 'asc') =>
|
|
34
40
|
this.myContext()
|
|
35
41
|
.where({active:true})
|
|
36
42
|
.select()
|
|
37
43
|
.orderBy(['createdAt','updatedAt'],order)
|
|
38
|
-
.then(result => Repository
|
|
44
|
+
.then(result => Repository
|
|
45
|
+
.setOrEmpty(result,this.Entity.build)
|
|
46
|
+
)
|
|
39
47
|
|
|
40
|
-
last = ()=>
|
|
48
|
+
last = () =>
|
|
41
49
|
this.myContext()
|
|
42
50
|
.where({active:true})
|
|
43
51
|
.first()
|
|
44
52
|
.orderBy('createdAt',"desc")
|
|
45
|
-
.then(result => Repository
|
|
53
|
+
.then(result => Repository
|
|
54
|
+
.anyOrError(result,{code:404,message:'Not found'})
|
|
55
|
+
)
|
|
46
56
|
|
|
47
|
-
first = ()=>
|
|
57
|
+
first = () =>
|
|
48
58
|
this.myContext()
|
|
49
59
|
.where({active:true})
|
|
50
60
|
.first()
|
|
51
61
|
.orderBy('createdAt',"asc")
|
|
52
|
-
.then(result => Repository
|
|
62
|
+
.then(result => Repository
|
|
63
|
+
.anyOrError(result,{code:404,message:'Not found'})
|
|
64
|
+
)
|
|
53
65
|
|
|
54
|
-
insert = (traced=new Traced())=>
|
|
66
|
+
insert = (traced=new Traced()) =>
|
|
55
67
|
this.myContext()
|
|
56
68
|
.insert({
|
|
57
69
|
...traced.entity,
|
package/src/service/index.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import AppError from "../model/error"
|
|
1
2
|
import Context from "../repository/db/context"
|
|
2
3
|
|
|
3
4
|
export default class Service {
|
|
@@ -8,6 +9,6 @@ export default class Service {
|
|
|
8
9
|
|
|
9
10
|
get context(){return this.#context}
|
|
10
11
|
|
|
11
|
-
handleError = (code,message)=>Promise.reject({code,message})
|
|
12
|
+
handleError = (code,message)=>Promise.reject(new AppError({code,message}))
|
|
12
13
|
handleFailure = (err)=> this.handleError({code:500,message:err.message})
|
|
13
14
|
}
|