@dra2020/baseclient 1.0.13 → 1.0.14
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/LICENSE +21 -0
- package/README.md +37 -0
- package/dist/all/all.d.ts +36 -0
- package/dist/all/allclient.d.ts +18 -0
- package/dist/base.js +33010 -0
- package/dist/base.js.map +1 -0
- package/dist/baseclient.js +8991 -0
- package/dist/baseclient.js.map +1 -0
- package/dist/context/all.d.ts +1 -0
- package/dist/context/context.d.ts +13 -0
- package/dist/dbabstract/all.d.ts +1 -0
- package/dist/dbabstract/db.d.ts +83 -0
- package/dist/dbdynamo/all.d.ts +1 -0
- package/dist/dbdynamo/dbdynamo.d.ts +190 -0
- package/dist/filterexpr/all.d.ts +1 -0
- package/dist/filterexpr/filterexpr.d.ts +64 -0
- package/dist/fsm/all.d.ts +1 -0
- package/dist/fsm/fsm.d.ts +118 -0
- package/dist/fsmfile/all.d.ts +1 -0
- package/dist/fsmfile/fsmfile.d.ts +47 -0
- package/dist/jsonstream/all.d.ts +1 -0
- package/dist/jsonstream/jsonstream.d.ts +130 -0
- package/dist/lambda/all.d.ts +1 -0
- package/dist/lambda/env.d.ts +10 -0
- package/dist/lambda/lambda.d.ts +18 -0
- package/dist/logabstract/all.d.ts +1 -0
- package/dist/logabstract/log.d.ts +26 -0
- package/dist/logclient/all.d.ts +1 -0
- package/dist/logclient/log.d.ts +6 -0
- package/dist/logserver/all.d.ts +5 -0
- package/dist/logserver/log.d.ts +11 -0
- package/dist/logserver/logaccum.d.ts +154 -0
- package/dist/logserver/logblob.d.ts +24 -0
- package/dist/logserver/logconcat.d.ts +55 -0
- package/dist/logserver/logkey.d.ts +28 -0
- package/dist/memsqs/all.d.ts +4 -0
- package/dist/memsqs/client.d.ts +13 -0
- package/dist/memsqs/loopback.d.ts +11 -0
- package/dist/memsqs/orderedlist.d.ts +19 -0
- package/dist/memsqs/queue.d.ts +84 -0
- package/dist/memsqs/server.d.ts +37 -0
- package/dist/ot-editutil/all.d.ts +2 -0
- package/dist/ot-editutil/oteditutil.d.ts +14 -0
- package/dist/ot-editutil/otmaputil.d.ts +21 -0
- package/dist/ot-js/all.d.ts +9 -0
- package/dist/ot-js/otarray.d.ts +111 -0
- package/dist/ot-js/otclientengine.d.ts +38 -0
- package/dist/ot-js/otcomposite.d.ts +37 -0
- package/dist/ot-js/otcounter.d.ts +17 -0
- package/dist/ot-js/otengine.d.ts +22 -0
- package/dist/ot-js/otmap.d.ts +19 -0
- package/dist/ot-js/otserverengine.d.ts +38 -0
- package/dist/ot-js/otsession.d.ts +111 -0
- package/dist/ot-js/ottypes.d.ts +29 -0
- package/dist/poly/all.d.ts +15 -0
- package/dist/poly/blend.d.ts +1 -0
- package/dist/poly/boundbox.d.ts +16 -0
- package/dist/poly/cartesian.d.ts +5 -0
- package/dist/poly/graham-scan.d.ts +8 -0
- package/dist/poly/hash.d.ts +1 -0
- package/dist/poly/matrix.d.ts +24 -0
- package/dist/poly/minbound.d.ts +1 -0
- package/dist/poly/poly.d.ts +52 -0
- package/dist/poly/polybin.d.ts +5 -0
- package/dist/poly/polylabel.d.ts +7 -0
- package/dist/poly/polypack.d.ts +30 -0
- package/dist/poly/polyround.d.ts +1 -0
- package/dist/poly/polysimplify.d.ts +1 -0
- package/dist/poly/quad.d.ts +48 -0
- package/dist/poly/selfintersect.d.ts +1 -0
- package/dist/poly/shamos.d.ts +1 -0
- package/dist/poly/simplify.d.ts +2 -0
- package/dist/poly/topo.d.ts +46 -0
- package/dist/poly/union.d.ts +48 -0
- package/dist/storage/all.d.ts +4 -0
- package/dist/storage/datablob.d.ts +9 -0
- package/dist/storage/env.d.ts +10 -0
- package/dist/storage/splitsblob.d.ts +13 -0
- package/dist/storage/storage.d.ts +166 -0
- package/dist/storages3/all.d.ts +1 -0
- package/dist/storages3/s3.d.ts +62 -0
- package/dist/util/all.d.ts +5 -0
- package/dist/util/bintrie.d.ts +93 -0
- package/dist/util/countedhash.d.ts +19 -0
- package/dist/util/gradient.d.ts +15 -0
- package/dist/util/indexedarray.d.ts +15 -0
- package/dist/util/util.d.ts +68 -0
- package/docs/context.md +2 -0
- package/docs/dbabstract.md +2 -0
- package/docs/dbdynamo.md +2 -0
- package/docs/fsm.md +243 -0
- package/docs/fsmfile.md +2 -0
- package/docs/jsonstream.md +44 -0
- package/docs/lambda.md +2 -0
- package/docs/logabstract.md +2 -0
- package/docs/logclient.md +2 -0
- package/docs/logserver.md +2 -0
- package/docs/ot-editutil.md +2 -0
- package/docs/ot-js.md +95 -0
- package/docs/poly.md +103 -0
- package/docs/storage.md +2 -0
- package/docs/storages3.md +2 -0
- package/docs/util.md +2 -0
- package/lib/all/all.ts +41 -0
- package/lib/all/allclient.ts +19 -0
- package/lib/context/all.ts +1 -0
- package/lib/context/context.ts +82 -0
- package/lib/dbabstract/all.ts +1 -0
- package/lib/dbabstract/db.ts +246 -0
- package/lib/dbdynamo/all.ts +1 -0
- package/lib/dbdynamo/dbdynamo.ts +1551 -0
- package/lib/filterexpr/all.ts +1 -0
- package/lib/filterexpr/filterexpr.ts +625 -0
- package/lib/fsm/all.ts +1 -0
- package/lib/fsm/fsm.ts +549 -0
- package/lib/fsmfile/all.ts +1 -0
- package/lib/fsmfile/fsmfile.ts +236 -0
- package/lib/jsonstream/all.ts +1 -0
- package/lib/jsonstream/jsonstream.ts +940 -0
- package/lib/lambda/all.ts +1 -0
- package/lib/lambda/env.ts +13 -0
- package/lib/lambda/lambda.ts +120 -0
- package/lib/logabstract/all.ts +1 -0
- package/lib/logabstract/log.ts +55 -0
- package/lib/logclient/all.ts +1 -0
- package/lib/logclient/log.ts +105 -0
- package/lib/logserver/all.ts +5 -0
- package/lib/logserver/log.ts +565 -0
- package/lib/logserver/logaccum.ts +1445 -0
- package/lib/logserver/logblob.ts +84 -0
- package/lib/logserver/logconcat.ts +313 -0
- package/lib/logserver/logkey.ts +125 -0
- package/lib/memsqs/all.ts +4 -0
- package/lib/memsqs/client.ts +268 -0
- package/lib/memsqs/loopback.ts +64 -0
- package/lib/memsqs/orderedlist.ts +74 -0
- package/lib/memsqs/queue.ts +395 -0
- package/lib/memsqs/server.ts +262 -0
- package/lib/ot-editutil/all.ts +2 -0
- package/lib/ot-editutil/oteditutil.ts +180 -0
- package/lib/ot-editutil/otmaputil.ts +209 -0
- package/lib/ot-js/all.ts +9 -0
- package/lib/ot-js/otarray.ts +1168 -0
- package/lib/ot-js/otclientengine.ts +327 -0
- package/lib/ot-js/otcomposite.ts +247 -0
- package/lib/ot-js/otcounter.ts +145 -0
- package/lib/ot-js/otengine.ts +71 -0
- package/lib/ot-js/otmap.ts +144 -0
- package/lib/ot-js/otserverengine.ts +329 -0
- package/lib/ot-js/otsession.ts +199 -0
- package/lib/ot-js/ottypes.ts +98 -0
- package/lib/poly/all.ts +15 -0
- package/lib/poly/blend.ts +27 -0
- package/lib/poly/boundbox.ts +102 -0
- package/lib/poly/cartesian.ts +130 -0
- package/lib/poly/graham-scan.ts +401 -0
- package/lib/poly/hash.ts +15 -0
- package/lib/poly/matrix.ts +309 -0
- package/lib/poly/minbound.ts +211 -0
- package/lib/poly/poly.ts +767 -0
- package/lib/poly/polybin.ts +218 -0
- package/lib/poly/polylabel.ts +204 -0
- package/lib/poly/polypack.ts +458 -0
- package/lib/poly/polyround.ts +30 -0
- package/lib/poly/polysimplify.ts +24 -0
- package/lib/poly/quad.ts +272 -0
- package/lib/poly/selfintersect.ts +87 -0
- package/lib/poly/shamos.ts +297 -0
- package/lib/poly/simplify.ts +119 -0
- package/lib/poly/topo.ts +525 -0
- package/lib/poly/union.ts +371 -0
- package/lib/storage/all.ts +4 -0
- package/lib/storage/datablob.ts +36 -0
- package/lib/storage/env.ts +14 -0
- package/lib/storage/splitsblob.ts +63 -0
- package/lib/storage/storage.ts +604 -0
- package/lib/storages3/all.ts +1 -0
- package/lib/storages3/s3.ts +576 -0
- package/lib/util/all.ts +5 -0
- package/lib/util/bintrie.ts +603 -0
- package/lib/util/countedhash.ts +83 -0
- package/lib/util/gradient.ts +108 -0
- package/lib/util/indexedarray.ts +80 -0
- package/lib/util/util.ts +695 -0
- package/package.json +8 -8
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './lambda';
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import * as Context from '../context/all';
|
|
2
|
+
import * as LogAbstract from '../logabstract/all';
|
|
3
|
+
import * as FSM from '../fsm/all';
|
|
4
|
+
|
|
5
|
+
import * as Lambda from './lambda';
|
|
6
|
+
|
|
7
|
+
export interface Environment
|
|
8
|
+
{
|
|
9
|
+
context: Context.IContext,
|
|
10
|
+
log: LogAbstract.ILog,
|
|
11
|
+
fsmManager: FSM.FsmManager;
|
|
12
|
+
lambdaManager: Lambda.Manager;
|
|
13
|
+
}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
// Shared libraries
|
|
2
|
+
import * as Util from '../util/all';
|
|
3
|
+
import * as Context from '../context/all';
|
|
4
|
+
import * as LogAbstract from '../logabstract/all';
|
|
5
|
+
import * as FSM from '../fsm/all';
|
|
6
|
+
|
|
7
|
+
import { Environment } from './env';
|
|
8
|
+
|
|
9
|
+
import * as Lambda from 'aws-sdk/clients/lambda';
|
|
10
|
+
|
|
11
|
+
class FsmList extends FSM.Fsm
|
|
12
|
+
{
|
|
13
|
+
constructor(env: Environment)
|
|
14
|
+
{
|
|
15
|
+
super(env);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
get env(): Environment { return this._env as Environment }
|
|
19
|
+
|
|
20
|
+
tick(): void
|
|
21
|
+
{
|
|
22
|
+
if (this.ready && this.state === FSM.FSM_STARTING)
|
|
23
|
+
{
|
|
24
|
+
this.setState(FSM.FSM_PENDING);
|
|
25
|
+
this.env.lambdaManager.awslambda.listFunctions({}, (err: any, data: any) => {
|
|
26
|
+
if (err)
|
|
27
|
+
{
|
|
28
|
+
this.env.log.chatter(`listFunctions: failed: ${JSON.stringify(err)}`);
|
|
29
|
+
}
|
|
30
|
+
else
|
|
31
|
+
{
|
|
32
|
+
this.env.log.chatter(`listFunctions: success: ${JSON.stringify(data)}`);
|
|
33
|
+
}
|
|
34
|
+
this.setState(err ? FSM.FSM_ERROR : FSM.FSM_DONE);
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
export class FsmInvoke extends FSM.Fsm
|
|
41
|
+
{
|
|
42
|
+
name: string;
|
|
43
|
+
params: any;
|
|
44
|
+
result: any;
|
|
45
|
+
|
|
46
|
+
constructor(env: Environment, name: string, params: any)
|
|
47
|
+
{
|
|
48
|
+
super(env);
|
|
49
|
+
this.name = name;
|
|
50
|
+
this.params = Util.shallowAssignImmutable({ context: { production: env.context.xnumber('production') } }, params);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
get env(): Environment { return this._env as Environment }
|
|
54
|
+
|
|
55
|
+
tick(): void
|
|
56
|
+
{
|
|
57
|
+
if (this.ready && this.state === FSM.FSM_STARTING)
|
|
58
|
+
{
|
|
59
|
+
this.setState(FSM.FSM_PENDING);
|
|
60
|
+
let awsparam: any = {
|
|
61
|
+
FunctionName: `${this.name}:${this.env.context.xflag('production') ? 'production' : 'development'}`,
|
|
62
|
+
InvocationType: 'RequestResponse',
|
|
63
|
+
LogType: 'None',
|
|
64
|
+
Payload: JSON.stringify(this.params)
|
|
65
|
+
};
|
|
66
|
+
this.env.lambdaManager.awslambda.invoke(awsparam, (err: any, data: any) => {
|
|
67
|
+
let payload: any = data && data.Payload ? data.Payload : null;
|
|
68
|
+
try
|
|
69
|
+
{
|
|
70
|
+
this.result = (typeof payload === 'string') ? JSON.parse(payload) : payload;
|
|
71
|
+
}
|
|
72
|
+
catch (exception)
|
|
73
|
+
{
|
|
74
|
+
this.result = payload;
|
|
75
|
+
}
|
|
76
|
+
if (err)
|
|
77
|
+
{
|
|
78
|
+
this.env.log.chatter(`lambdamanager: invoke ${this.name} error: ${JSON.stringify(err)}`);
|
|
79
|
+
this.env.log.error({ event: 'lambdamanager: invoke error', detail: JSON.stringify(this.result) });
|
|
80
|
+
this.setState(FSM.FSM_ERROR);
|
|
81
|
+
}
|
|
82
|
+
else if (this.result && this.result.errorMessage)
|
|
83
|
+
{
|
|
84
|
+
this.result = { result: 1, message: this.result.errorMessage };
|
|
85
|
+
this.env.log.chatter(`lambdamanager: invoke failure: ${this.name}`);
|
|
86
|
+
this.env.log.event(`lambdamanager: invoke failure: ${this.name}`);
|
|
87
|
+
this.setState(FSM.FSM_ERROR);
|
|
88
|
+
}
|
|
89
|
+
else
|
|
90
|
+
{
|
|
91
|
+
this.env.log.event(`lambdamanager: invoke success: ${this.name}`);
|
|
92
|
+
this.setState(FSM.FSM_DONE);
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
export class Manager extends FSM.Fsm
|
|
100
|
+
{
|
|
101
|
+
awslambda: Lambda;
|
|
102
|
+
|
|
103
|
+
constructor(env: Environment)
|
|
104
|
+
{
|
|
105
|
+
super(env);
|
|
106
|
+
this.awslambda = new Lambda({ apiVersion: '2015-03-31', region: 'us-west-2' });
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
get env(): Environment { return this._env as Environment }
|
|
110
|
+
|
|
111
|
+
invoke(name: string, params?: any): FsmInvoke
|
|
112
|
+
{
|
|
113
|
+
return new FsmInvoke(this.env, name, params);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
export function create(env: Environment): Manager
|
|
118
|
+
{
|
|
119
|
+
return new Manager(env);
|
|
120
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './log';
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import * as Util from '../util/all';
|
|
2
|
+
import * as FSM from '../fsm/all';
|
|
3
|
+
|
|
4
|
+
export interface ILog
|
|
5
|
+
{
|
|
6
|
+
dump: () => FSM.Fsm;
|
|
7
|
+
stamp: (o: any) => void;
|
|
8
|
+
log: (o: any, verbosity?: number) => void;
|
|
9
|
+
event: (o: any, verbosity?: number) => void;
|
|
10
|
+
error: (o: any) => void;
|
|
11
|
+
value: (o: any, verbosity?: number) => void;
|
|
12
|
+
chatter: (s: string) => void;
|
|
13
|
+
chatters: () => string[];
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export class Timer
|
|
17
|
+
{
|
|
18
|
+
ilog: ILog;
|
|
19
|
+
o: any;
|
|
20
|
+
verbosity: number;
|
|
21
|
+
elapsed: Util.Elapsed;
|
|
22
|
+
|
|
23
|
+
constructor(ilog: ILog, kind: string, o: any, verbosity: number = 0)
|
|
24
|
+
{
|
|
25
|
+
this.ilog = ilog;
|
|
26
|
+
if (typeof o === 'string') o = { event: o };
|
|
27
|
+
this.o = o;
|
|
28
|
+
this.o.kind = kind;
|
|
29
|
+
this.verbosity = verbosity;
|
|
30
|
+
this.elapsed = new Util.Elapsed();
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
log(): void
|
|
34
|
+
{
|
|
35
|
+
this.elapsed.end();
|
|
36
|
+
this.o.ms = this.elapsed.ms();
|
|
37
|
+
this.ilog.log(this.o, this.verbosity);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export class AsyncTimer extends Timer
|
|
42
|
+
{
|
|
43
|
+
constructor(ilog: ILog, o: any, verbosity: number = 0)
|
|
44
|
+
{
|
|
45
|
+
super(ilog, 'async', o, verbosity);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
export class SyncTimer extends Timer
|
|
50
|
+
{
|
|
51
|
+
constructor(ilog: ILog, o: any, verbosity: number = 0)
|
|
52
|
+
{
|
|
53
|
+
super(ilog, 'sync', o, verbosity);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './log';
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import * as Context from '../context/all';
|
|
2
|
+
import * as LogAbstract from '../logabstract/all';
|
|
3
|
+
import * as Util from '../util/all';
|
|
4
|
+
import * as FSM from '../fsm/all';
|
|
5
|
+
|
|
6
|
+
export interface LogEnvironment
|
|
7
|
+
{
|
|
8
|
+
context: Context.IContext;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
class LogManager implements LogAbstract.ILog
|
|
12
|
+
{
|
|
13
|
+
env: LogEnvironment;
|
|
14
|
+
count: number;
|
|
15
|
+
|
|
16
|
+
constructor(env: LogEnvironment)
|
|
17
|
+
{
|
|
18
|
+
this.env = env;
|
|
19
|
+
this.count = 0;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
dump(): FSM.Fsm { return null; }
|
|
23
|
+
|
|
24
|
+
print(o: any): void
|
|
25
|
+
{
|
|
26
|
+
let sa: string[] = [];
|
|
27
|
+
|
|
28
|
+
if (o._count !== undefined)
|
|
29
|
+
sa.push(String(o._count));
|
|
30
|
+
if (o.kind === 'error')
|
|
31
|
+
{
|
|
32
|
+
sa.push('error');
|
|
33
|
+
sa.push(o.event);
|
|
34
|
+
}
|
|
35
|
+
else if (o.kind !== 'value')
|
|
36
|
+
{
|
|
37
|
+
sa.push('info');
|
|
38
|
+
sa.push(o.event);
|
|
39
|
+
}
|
|
40
|
+
else
|
|
41
|
+
{
|
|
42
|
+
sa.push('value');
|
|
43
|
+
sa.push(o.event);
|
|
44
|
+
sa.push(String(o.value));
|
|
45
|
+
}
|
|
46
|
+
if (o.detail !== undefined)
|
|
47
|
+
sa.push(o.detail);
|
|
48
|
+
console.log(sa.join(': '));
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
stamp(o: any): void
|
|
52
|
+
{
|
|
53
|
+
this.log(o);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
log(o: any, verbosity: number = 0): void
|
|
57
|
+
{
|
|
58
|
+
// Show some restraint
|
|
59
|
+
if (verbosity > this.env.context.xnumber('verbosity'))
|
|
60
|
+
return;
|
|
61
|
+
|
|
62
|
+
// Inject some standard properties
|
|
63
|
+
o._time = Util.Now();
|
|
64
|
+
o._count = this.count++;
|
|
65
|
+
if (o.kind === undefined)
|
|
66
|
+
o.kind = 'misc';
|
|
67
|
+
this.print(o);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
|
|
71
|
+
event(o: any, verbosity: number = 0): void
|
|
72
|
+
{
|
|
73
|
+
if (typeof o === 'string') o = { event: o };
|
|
74
|
+
o.kind = 'event';
|
|
75
|
+
this.log(o, verbosity);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
error(o: any): void
|
|
79
|
+
{
|
|
80
|
+
if (typeof o === 'string') o = { event: o };
|
|
81
|
+
o.kind = 'error';
|
|
82
|
+
this.log(o);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
value(o: any, verbosity: number = 0): void
|
|
86
|
+
{
|
|
87
|
+
o.kind = 'value';
|
|
88
|
+
this.log(o, verbosity);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
chatter(s: string): void
|
|
92
|
+
{
|
|
93
|
+
console.log(s);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
chatters(): string[]
|
|
97
|
+
{
|
|
98
|
+
return null;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
export function create(env: LogEnvironment): LogAbstract.ILog
|
|
103
|
+
{
|
|
104
|
+
return new LogManager(env);
|
|
105
|
+
}
|