@magic-xpa/utils 4.1200.0-dev4120.21 → 4.1200.0-dev4120.212
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/fesm2022/magic-xpa-utils.mjs +1222 -72
- package/fesm2022/magic-xpa-utils.mjs.map +1 -1
- package/index.d.ts +3 -0
- package/package.json +2 -4
- package/src/MsgInterface.d.ts +5 -0
- package/src/StrUtil.d.ts +1 -0
- package/src/XMLConstants.d.ts +2 -0
- package/esm2022/index.mjs +0 -27
- package/esm2022/magic-xpa-utils.mjs +0 -2
- package/esm2022/src/Base64.mjs +0 -164
- package/esm2022/src/ChoiceUtils.mjs +0 -79
- package/esm2022/src/Constants.mjs +0 -74
- package/esm2022/src/DateTimeUtils.mjs +0 -54
- package/esm2022/src/DateUtil.mjs +0 -58
- package/esm2022/src/InternalInterface.mjs +0 -341
- package/esm2022/src/JSON_Utils.mjs +0 -7
- package/esm2022/src/Logger.mjs +0 -216
- package/esm2022/src/MagicConstants.mjs +0 -12
- package/esm2022/src/Misc.mjs +0 -98
- package/esm2022/src/MsgInterface.mjs +0 -192
- package/esm2022/src/PICInterface.mjs +0 -60
- package/esm2022/src/PlatformUtils.mjs +0 -11
- package/esm2022/src/Queue.mjs +0 -28
- package/esm2022/src/Randomizer.mjs +0 -34
- package/esm2022/src/RequestInfo.mjs +0 -28
- package/esm2022/src/Rtf.mjs +0 -614
- package/esm2022/src/StorageAttribute.mjs +0 -84
- package/esm2022/src/StrUtil.mjs +0 -453
- package/esm2022/src/SyncExecutionHelper.mjs +0 -21
- package/esm2022/src/UtilDateJpn.mjs +0 -232
- package/esm2022/src/UtilImeJpn.mjs +0 -13
- package/esm2022/src/UtilStrByteMode.mjs +0 -300
- package/esm2022/src/XMLConstants.mjs +0 -169
- package/esm2022/src/Xml/XmlParser.mjs +0 -247
- package/esm2022/src/enums.mjs +0 -1763
package/esm2022/src/Logger.mjs
DELETED
|
@@ -1,216 +0,0 @@
|
|
|
1
|
-
import { Logger_LogLevels, Logger_MessageDirection } from "./enums";
|
|
2
|
-
import { DateTime, Debug, Exception, NString, StringBuilder, Thread, isNullOrUndefined } from "@magic-xpa/mscorelib";
|
|
3
|
-
import { OSEnvironment } from "./PlatformUtils";
|
|
4
|
-
import { DateTimeUtils } from "./DateTimeUtils";
|
|
5
|
-
import { XMLConstants } from "./XMLConstants";
|
|
6
|
-
import { RequestInfo } from "./RequestInfo";
|
|
7
|
-
import { StrUtil } from "./StrUtil";
|
|
8
|
-
export var LogType;
|
|
9
|
-
(function (LogType) {
|
|
10
|
-
LogType[LogType["info"] = 1] = "info";
|
|
11
|
-
LogType[LogType["warning"] = 2] = "warning";
|
|
12
|
-
LogType[LogType["error"] = 3] = "error";
|
|
13
|
-
})(LogType || (LogType = {}));
|
|
14
|
-
export class Logger {
|
|
15
|
-
static instance = null;
|
|
16
|
-
LogLevel = 0;
|
|
17
|
-
ShouldBeep = false;
|
|
18
|
-
static set Instance(value) {
|
|
19
|
-
Logger.instance = value;
|
|
20
|
-
}
|
|
21
|
-
static get Instance() {
|
|
22
|
-
if (Logger.instance === null) {
|
|
23
|
-
Logger.instance = new Logger();
|
|
24
|
-
}
|
|
25
|
-
return Logger.instance;
|
|
26
|
-
}
|
|
27
|
-
Initialize(logLevel, shouldBeep) {
|
|
28
|
-
try {
|
|
29
|
-
this.LogLevel = logLevel;
|
|
30
|
-
this.ShouldBeep = shouldBeep;
|
|
31
|
-
}
|
|
32
|
-
catch (e) {
|
|
33
|
-
this.WriteDevToLog("ClientManager.init(): " + e.Message);
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
ShouldLog(logLevel) {
|
|
37
|
-
if (arguments.length === 1)
|
|
38
|
-
return this.ShouldLog_0(logLevel);
|
|
39
|
-
else
|
|
40
|
-
return this.ShouldLog_1();
|
|
41
|
-
}
|
|
42
|
-
ShouldLog_0(logLevel) {
|
|
43
|
-
return this.LogLevel === logLevel;
|
|
44
|
-
}
|
|
45
|
-
ShouldLog_1() {
|
|
46
|
-
return this.LogLevel > Logger_LogLevels.None;
|
|
47
|
-
}
|
|
48
|
-
ShouldLogServerRelatedMessages() {
|
|
49
|
-
return (this.ShouldLogExtendedServerRelatedMessages() || Logger.Instance.ShouldLog(Logger_LogLevels.Server)) && this.LogLevel !== Logger_LogLevels.Basic;
|
|
50
|
-
}
|
|
51
|
-
ShouldLogExtendedServerRelatedMessages() {
|
|
52
|
-
return (Logger.Instance.ShouldLog(Logger_LogLevels.ServerMessages) || Logger.Instance.ShouldLog(Logger_LogLevels.Support) || Logger.Instance.ShouldLog(Logger_LogLevels.Development)) && this.LogLevel !== Logger_LogLevels.Basic;
|
|
53
|
-
}
|
|
54
|
-
WriteToLog(msg, openIfNecessary, logType = LogType.info) {
|
|
55
|
-
if (this.LogLevel > Logger_LogLevels.None || openIfNecessary) {
|
|
56
|
-
msg = NString.Format("{0} {1}", (this.LogLevel === Logger_LogLevels.Basic) ? new Date().toISOString() : DateTimeUtils.ToString(DateTime.Now, XMLConstants.ERROR_LOG_TIME_FORMAT, this), msg);
|
|
57
|
-
switch (logType) {
|
|
58
|
-
case LogType.error:
|
|
59
|
-
console.error(msg);
|
|
60
|
-
break;
|
|
61
|
-
case LogType.warning:
|
|
62
|
-
console.warn(msg);
|
|
63
|
-
break;
|
|
64
|
-
default:
|
|
65
|
-
console.log(msg);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
WriteServerToLog(msg) {
|
|
70
|
-
if (this.ShouldLogServerRelatedMessages()) {
|
|
71
|
-
this.WriteToLog(NString.Format("Server, Thread={0}: ", Thread.CurrentThread.ManagedThreadId) + msg, false, LogType.info);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
WriteServerMessagesToLog(msg) {
|
|
75
|
-
if (this.ShouldLogExtendedServerRelatedMessages()) {
|
|
76
|
-
this.WriteToLog("Server#: " + msg, false, LogType.info);
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
WriteSupportToLog(msg, skipLine) {
|
|
80
|
-
if (this.LogLevel >= Logger_LogLevels.Support && this.LogLevel !== Logger_LogLevels.Basic) {
|
|
81
|
-
if (skipLine) {
|
|
82
|
-
this.WriteToLog("SUPPORT: " + msg, false, LogType.info);
|
|
83
|
-
}
|
|
84
|
-
else {
|
|
85
|
-
this.WriteToLog("SUPPORT: " + msg + OSEnvironment.EolSeq + "-----------------------------------------------------------------------------------------------------------", false, LogType.info);
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
WriteGuiToLog(msg) {
|
|
90
|
-
if (this.LogLevel >= Logger_LogLevels.Gui && this.LogLevel !== Logger_LogLevels.Basic) {
|
|
91
|
-
this.WriteToLog(msg, false, LogType.info);
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
WriteDevToLog(msg) {
|
|
95
|
-
if (this.LogLevel >= Logger_LogLevels.Development && this.LogLevel !== Logger_LogLevels.Basic) {
|
|
96
|
-
this.WriteToLog("DEV: " + msg, false, LogType.info);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
WriteBasicToLog(messageDirection, contextID, sessionCounter, clientID, serverID, responseTime, statusCode, httpHeaders, contentLength) {
|
|
100
|
-
if (this.LogLevel === Logger_LogLevels.Basic) {
|
|
101
|
-
let text = httpHeaders;
|
|
102
|
-
text = text.trim();
|
|
103
|
-
text = NString.Replace(text, "\r\n", "|");
|
|
104
|
-
let arg_E4_0 = "RIA,{0}_{1},{2},{3},{4},{5},-,{6},{7},{8},{9},{10},{11}";
|
|
105
|
-
let expr_3E = new Array(12);
|
|
106
|
-
expr_3E[1] = Thread.CurrentThread.ManagedThreadId;
|
|
107
|
-
expr_3E[2] = new Date().toISOString();
|
|
108
|
-
expr_3E[3] = ((messageDirection === Logger_MessageDirection.MessageLeaving) ? "MSGL" : "MSGE");
|
|
109
|
-
expr_3E[4] = contextID;
|
|
110
|
-
expr_3E[5] = sessionCounter;
|
|
111
|
-
expr_3E[6] = clientID;
|
|
112
|
-
expr_3E[7] = serverID;
|
|
113
|
-
expr_3E[8] = ((responseTime !== 0) ? responseTime.toString() : "-");
|
|
114
|
-
let arg_D3_1 = 9;
|
|
115
|
-
let arg_D3_2;
|
|
116
|
-
arg_D3_2 = statusCode;
|
|
117
|
-
expr_3E[arg_D3_1] = arg_D3_2;
|
|
118
|
-
expr_3E[10] = text;
|
|
119
|
-
expr_3E[11] = contentLength;
|
|
120
|
-
let value = NString.Format(arg_E4_0, expr_3E);
|
|
121
|
-
console.log(value);
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
WriteRequestInfoToLog(requestInfo, extraMessageStr) {
|
|
125
|
-
if (this.LogLevel === Logger_LogLevels.RequestInfo) {
|
|
126
|
-
console.log(extraMessageStr, RequestInfo.clone(requestInfo));
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
WriteBasicErrorToLog() {
|
|
130
|
-
Debug.Assert(this.LogLevel === Logger_LogLevels.Basic);
|
|
131
|
-
}
|
|
132
|
-
WriteErrorToLog(msg) {
|
|
133
|
-
this.WriteToLog("MagicWeb [ERROR]: " + StrUtil.getConsoleErorString(msg), true, LogType.error);
|
|
134
|
-
}
|
|
135
|
-
WriteExceptionToLog(msgOrEx, msg) {
|
|
136
|
-
if (msgOrEx instanceof Error) {
|
|
137
|
-
this.WriteExceptionToLog_2(msgOrEx, msg);
|
|
138
|
-
return;
|
|
139
|
-
}
|
|
140
|
-
if (arguments.length === 1 && (msgOrEx !== null || msgOrEx instanceof Exception)) {
|
|
141
|
-
this.WriteExceptionToLog_1(msgOrEx);
|
|
142
|
-
return;
|
|
143
|
-
}
|
|
144
|
-
this.WriteExceptionToLog_3(msgOrEx, msg);
|
|
145
|
-
}
|
|
146
|
-
WriteExceptionToLogWithMsg(msg) {
|
|
147
|
-
this.WriteToLog("MagicWeb [ERROR]: " + StrUtil.getConsoleErorString(msg), true, LogType.error);
|
|
148
|
-
}
|
|
149
|
-
WriteExceptionToLog_1(ex) {
|
|
150
|
-
this.WriteExceptionToLogWithMsg(NString.Format("{0} : {1}{2}{3}{4}", [
|
|
151
|
-
ex.GetType(), OSEnvironment.EolSeq, ex.StackTrace, OSEnvironment.EolSeq, ex.Message
|
|
152
|
-
]));
|
|
153
|
-
}
|
|
154
|
-
WriteExceptionToLog_2(ex, message) {
|
|
155
|
-
if (isNullOrUndefined(message))
|
|
156
|
-
this.WriteExceptionToLogWithMsg(NString.Format("{0}{1}{2}", [ex.stack, OSEnvironment.EolSeq, ex.message]));
|
|
157
|
-
else
|
|
158
|
-
this.WriteExceptionToLogWithMsg(NString.Format("{0}{1}{2}{4}{5}", [message, OSEnvironment.EolSeq, ex.stack, OSEnvironment.EolSeq, ex.message]));
|
|
159
|
-
}
|
|
160
|
-
WriteExceptionToLog_3(ex, msg) {
|
|
161
|
-
this.WriteExceptionToLogWithMsg(NString.Format("{0}, {1} : {2}{3}{4}{5}", [
|
|
162
|
-
ex.GetType(), msg, OSEnvironment.EolSeq, ex.StackTrace, OSEnvironment.EolSeq, ex.Message
|
|
163
|
-
]));
|
|
164
|
-
}
|
|
165
|
-
WriteWarningToLog(msgOrEx, msg) {
|
|
166
|
-
if (arguments.length === 1 && msgOrEx !== null) {
|
|
167
|
-
if (msgOrEx instanceof Exception)
|
|
168
|
-
this.WriteWarningToLog_1(msgOrEx);
|
|
169
|
-
else if (msgOrEx instanceof Error)
|
|
170
|
-
this.WriteWarningToLog_2(msgOrEx);
|
|
171
|
-
}
|
|
172
|
-
else
|
|
173
|
-
this.WriteWarningToLog_3(msgOrEx, msg);
|
|
174
|
-
}
|
|
175
|
-
WriteWarningToLogWithMsg(msg) {
|
|
176
|
-
if (this.LogLevel !== Logger_LogLevels.Basic) {
|
|
177
|
-
this.WriteToLog("MagicWeb [WARNING]: " + msg, true, LogType.warning);
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
WriteWarningToLog_1(ex) {
|
|
181
|
-
this.WriteWarningToLogWithMsg(ex.GetType() + " : " + OSEnvironment.EolSeq + ex.StackTrace + OSEnvironment.EolSeq + ex.Message);
|
|
182
|
-
}
|
|
183
|
-
WriteWarningToLog_2(ex) {
|
|
184
|
-
this.WriteWarningToLogWithMsg(NString.Format("{0}{1}{2}", [
|
|
185
|
-
ex.stack, OSEnvironment.EolSeq, ex.message
|
|
186
|
-
]));
|
|
187
|
-
}
|
|
188
|
-
WriteWarningToLog_3(ex, msg) {
|
|
189
|
-
this.WriteWarningToLogWithMsg(NString.Format("{0}, {1} : {2}{3}{4}{5}", [
|
|
190
|
-
ex.GetType(), msg, OSEnvironment.EolSeq, ex.StackTrace, OSEnvironment.EolSeq, ex.Message
|
|
191
|
-
]));
|
|
192
|
-
}
|
|
193
|
-
WriteStackTrace(stackTrace, framesToPrint, traceTitle) {
|
|
194
|
-
if (traceTitle === null) {
|
|
195
|
-
traceTitle = "Stack trace:";
|
|
196
|
-
}
|
|
197
|
-
let stringBuilder = new StringBuilder(traceTitle + OSEnvironment.EolSeq);
|
|
198
|
-
let frames = stackTrace.GetFrames();
|
|
199
|
-
let array = frames;
|
|
200
|
-
for (let i = 0; i < array.length; i = i + 1) {
|
|
201
|
-
let stackFrame = array[i];
|
|
202
|
-
framesToPrint = framesToPrint - 1;
|
|
203
|
-
stringBuilder.Append(stackFrame.toString());
|
|
204
|
-
if (framesToPrint === 0) {
|
|
205
|
-
stringBuilder.Append("\t... more stack frames ...\n");
|
|
206
|
-
break;
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
|
-
this.WriteToLog(stringBuilder.ToString(), true);
|
|
210
|
-
}
|
|
211
|
-
Flush() {
|
|
212
|
-
}
|
|
213
|
-
constructor() {
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Logger.js","sourceRoot":"","sources":["../../../../../projects/utils/src/Logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,uBAAuB,EAAC,MAAM,SAAS,CAAC;AAClE,OAAO,EAAC,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAc,aAAa,EAAE,MAAM,EAAE,iBAAiB,EAAC,MAAM,sBAAsB,CAAC;AAC/H,OAAO,EAAC,aAAa,EAAC,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAC,aAAa,EAAC,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAE5C,OAAO,EAAC,WAAW,EAAC,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAC;AAGlC,MAAM,CAAN,IAAY,OAIX;AAJD,WAAY,OAAO;IACjB,qCAAQ,CAAA;IACR,2CAAO,CAAA;IACP,uCAAK,CAAA;AACP,CAAC,EAJW,OAAO,KAAP,OAAO,QAIlB;AAOD,MAAM,OAAO,MAAM;IACjB,MAAM,CAAC,QAAQ,GAAW,IAAI,CAAC;IAC/B,QAAQ,GAAqB,CAAC,CAAC;IAK/B,UAAU,GAAY,KAAK,CAAC;IAE5B,MAAM,KAAK,QAAQ,CAAC,KAAa;QAC/B,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED,MAAM,KAAK,QAAQ;QACjB,IAAI,MAAM,CAAC,QAAQ,KAAK,IAAI,EAAE;YAC5B,MAAM,CAAC,QAAQ,GAAG,IAAI,MAAM,EAAE,CAAC;SAChC;QACD,OAAO,MAAM,CAAC,QAAQ,CAAC;IACzB,CAAC;IAOD,UAAU,CAAC,QAA0B,EAAE,UAAmB;QACxD,IAAI;YAEF,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YACzB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;SAY9B;QACD,OAAO,CAAC,EAAE;YACR,IAAI,CAAC,aAAa,CAAC,wBAAwB,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC;SAC1D;IACH,CAAC;IAQD,SAAS,CAAC,QAA2B;QACnC,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC;YACxB,OAAO,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;;YAElC,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;IAC9B,CAAC;IAEO,WAAW,CAAC,QAA0B;QAC5C,OAAO,IAAI,CAAC,QAAQ,KAAK,QAAQ,CAAC;IACpC,CAAC;IAEO,WAAW;QACjB,OAAO,IAAI,CAAC,QAAQ,GAAG,gBAAgB,CAAC,IAAI,CAAC;IAC/C,CAAC;IAED,8BAA8B;QAC5B,OAAO,CAAC,IAAI,CAAC,sCAAsC,EAAE,IAAI,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,IAAI,IAAI,CAAC,QAAQ,KAAK,gBAAgB,CAAC,KAAK,CAAC;IAC3J,CAAC;IAED,sCAAsC;QACpC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,gBAAgB,CAAC,cAAc,CAAC,IAAI,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC,IAAI,IAAI,CAAC,QAAQ,KAAK,gBAAgB,CAAC,KAAK,CAAC;IACpO,CAAC;IAMD,UAAU,CAAC,GAAW,EAAE,eAAwB,EAAE,UAAmB,OAAO,CAAC,IAAI;QAE/E,IAAI,IAAI,CAAC,QAAQ,GAAG,gBAAgB,CAAC,IAAI,IAAI,eAAe,EAAE;YAC5D,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,IAAI,CAAC,QAAQ,KAAK,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,YAAY,CAAC,qBAAqB,EAAE,IAAI,CAAC,EACjK,GAAG,CAAC,CAAC;YAE1B,QAAQ,OAAO,EAAE;gBACf,KAAK,OAAO,CAAC,KAAK;oBAChB,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oBACnB,MAAM;gBACR,KAAK,OAAO,CAAC,OAAO;oBAClB,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;oBAClB,MAAM;gBACR;oBACE,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;aACpB;SACF;IACH,CAAC;IAMD,gBAAgB,CAAC,GAAW;QAC1B,IAAI,IAAI,CAAC,8BAA8B,EAAE,EAAE;YACzC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,sBAAsB,EAAE,MAAM,CAAC,aAAa,CAAC,eAAe,CAAC,GAAG,GAAG,EAAE,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;SAC1H;IACH,CAAC;IAMD,wBAAwB,CAAC,GAAW;QAClC,IAAI,IAAI,CAAC,sCAAsC,EAAE,EAAE;YACjD,IAAI,CAAC,UAAU,CAAC,WAAW,GAAG,GAAG,EAAE,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;SACzD;IACH,CAAC;IAID,iBAAiB,CAAC,GAAW,EAAE,QAAiB;QAE9C,IAAI,IAAI,CAAC,QAAQ,IAAI,gBAAgB,CAAC,OAAO,IAAI,IAAI,CAAC,QAAQ,KAAK,gBAAgB,CAAC,KAAK,EAAE;YACzF,IAAI,QAAQ,EAAE;gBACZ,IAAI,CAAC,UAAU,CAAC,WAAW,GAAG,GAAG,EAAE,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;aACzD;iBACI;gBACH,IAAI,CAAC,UAAU,CAAC,WAAW,GAAG,GAAG,GAAG,aAAa,CAAC,MAAM,GAAG,6GAA6G,EAAE,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;aAChM;SACF;IACH,CAAC;IAMD,aAAa,CAAC,GAAW;QAEvB,IAAI,IAAI,CAAC,QAAQ,IAAI,gBAAgB,CAAC,GAAG,IAAI,IAAI,CAAC,QAAQ,KAAK,gBAAgB,CAAC,KAAK,EAAE;YACrF,IAAI,CAAC,UAAU,CAAC,GAAG,EAAE,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;SAC3C;IACH,CAAC;IAMD,aAAa,CAAC,GAAW;QACvB,IAAI,IAAI,CAAC,QAAQ,IAAI,gBAAgB,CAAC,WAAW,IAAI,IAAI,CAAC,QAAQ,KAAK,gBAAgB,CAAC,KAAK,EAAE;YAC7F,IAAI,CAAC,UAAU,CAAC,OAAO,GAAG,GAAG,EAAE,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;SACrD;IACH,CAAC;IASD,eAAe,CAAC,gBAAyC,EAAE,SAAiB,EAAE,cAAsB,EAAE,QAAgB,EAAE,QAAgB,EAAE,YAAoB,EAAE,UAAkB,EAAE,WAAmB,EAAE,aAAqB;QAC5N,IAAI,IAAI,CAAC,QAAQ,KAAK,gBAAgB,CAAC,KAAK,EAAE;YAC5C,IAAI,IAAI,GAAW,WAAW,CAAC;YAC/B,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;YACnB,IAAI,GAAG,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC;YAC1C,IAAI,QAAQ,GAAW,yDAAyD,CAAC;YACjF,IAAI,OAAO,GAAU,IAAI,KAAK,CAAM,EAAE,CAAC,CAAC;YAIxC,OAAO,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,aAAa,CAAC,eAAe,CAAC;YAClD,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;YACtC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,gBAAgB,KAAK,uBAAuB,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YAC/F,OAAO,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC;YACvB,OAAO,CAAC,CAAC,CAAC,GAAG,cAAc,CAAC;YAC5B,OAAO,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;YACtB,OAAO,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;YACtB,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACpE,IAAI,QAAQ,GAAW,CAAC,CAAC;YACzB,IAAI,QAAa,CAAC;YAClB,QAAQ,GAAG,UAAU,CAAC;YACtB,OAAO,CAAC,QAAQ,CAAC,GAAG,QAAQ,CAAC;YAC7B,OAAO,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC;YACnB,OAAO,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC;YAC5B,IAAI,KAAK,GAAW,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YACtD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;SACpB;IACH,CAAC;IAMD,qBAAqB,CAAC,WAAwB,EAAE,eAAuB;QACrE,IAAI,IAAI,CAAC,QAAQ,KAAK,gBAAgB,CAAC,WAAW,EAAE;YAIlD,OAAO,CAAC,GAAG,CAAC,eAAe,EAAE,WAAW,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;SAC9D;IACH,CAAC;IAUD,oBAAoB;QAClB,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,KAAK,gBAAgB,CAAC,KAAK,CAAC,CAAC;IAOzD,CAAC;IAMD,eAAe,CAAC,GAAW;QACzB,IAAI,CAAC,UAAU,CAAC,oBAAoB,GAAG,OAAO,CAAC,oBAAoB,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IACjG,CAAC;IASD,mBAAmB,CAAC,OAAY,EAAE,GAAY;QAC5C,IAAI,OAAO,YAAY,KAAK,EAAE;YAC5B,IAAI,CAAC,qBAAqB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YACzC,OAAO;SACR;QACD,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,OAAO,KAAK,IAAI,IAAI,OAAO,YAAY,SAAS,CAAC,EAAE;YAChF,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;YACpC,OAAO;SACR;QAED,IAAI,CAAC,qBAAqB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;IAC3C,CAAC;IAED,0BAA0B,CAAC,GAAW;QACpC,IAAI,CAAC,UAAU,CAAC,oBAAoB,GAAG,OAAO,CAAC,oBAAoB,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IACjG,CAAC;IAEO,qBAAqB,CAAC,EAAa;QACzC,IAAI,CAAC,0BAA0B,CAAC,OAAO,CAAC,MAAM,CAAC,oBAAoB,EAAE;YACnE,EAAE,CAAC,OAAO,EAAE,EAAE,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,UAAU,EAAE,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO;SACpF,CAAC,CAAC,CAAC;IACN,CAAC;IAEO,qBAAqB,CAAC,EAAS,EAAE,OAAe;QACtD,IAAI,iBAAiB,CAAC,OAAO,CAAC;YAC5B,IAAI,CAAC,0BAA0B,CAAC,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;;YAE3G,IAAI,CAAC,0BAA0B,CAAC,OAAO,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,OAAO,EAAE,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,KAAK,EAAE,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACpJ,CAAC;IAEO,qBAAqB,CAAC,EAAa,EAAE,GAAW;QACtD,IAAI,CAAC,0BAA0B,CAAC,OAAO,CAAC,MAAM,CAAC,yBAAyB,EAAE;YACxE,EAAE,CAAC,OAAO,EAAE,EAAE,GAAG,EAAE,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,UAAU,EAAE,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO;SACzF,CAAC,CAAC,CAAC;IACN,CAAC;IAOD,iBAAiB,CAAC,OAAY,EAAE,GAAY;QAC1C,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,KAAK,IAAI,EAAE;YAC9C,IAAI,OAAO,YAAY,SAAS;gBAC9B,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;iBAC/B,IAAI,OAAO,YAAY,KAAK;gBAC/B,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;SACrC;;YAEC,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;IAC3C,CAAC;IAED,wBAAwB,CAAC,GAAW;QAElC,IAAI,IAAI,CAAC,QAAQ,KAAK,gBAAgB,CAAC,KAAK,EAAE;YAC5C,IAAI,CAAC,UAAU,CAAC,sBAAsB,GAAG,GAAG,EAAE,IAAI,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;SACtE;IACH,CAAC;IAEO,mBAAmB,CAAC,EAAa;QACvC,IAAI,CAAC,wBAAwB,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,GAAG,aAAa,CAAC,MAAM,GAAG,EAAE,CAAC,UAAU,GAAG,aAAa,CAAC,MAAM,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC;IACjI,CAAC;IAEO,mBAAmB,CAAC,EAAS;QACnC,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE;YACxD,EAAE,CAAC,KAAK,EAAE,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO;SAC3C,CAAC,CAAC,CAAC;IACN,CAAC;IAEO,mBAAmB,CAAC,EAAa,EAAE,GAAW;QACpD,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,MAAM,CAAC,yBAAyB,EAAE;YACtE,EAAE,CAAC,OAAO,EAAE,EAAE,GAAG,EAAE,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,UAAU,EAAE,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO;SACzF,CAAC,CAAC,CAAC;IACN,CAAC;IAED,eAAe,CAAC,UAAsB,EAAE,aAAqB,EAAE,UAAkB;QAE/E,IAAI,UAAU,KAAK,IAAI,EAAE;YACvB,UAAU,GAAG,cAAc,CAAC;SAC7B;QACD,IAAI,aAAa,GAAkB,IAAI,aAAa,CAAC,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;QACxF,IAAI,MAAM,GAAmB,UAAU,CAAC,SAAS,EAAE,CAAC;QACpD,IAAI,KAAK,GAAmB,MAAM,CAAC;QACnC,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;YACnD,IAAI,UAAU,GAAiB,KAAK,CAAC,CAAC,CAAC,CAAC;YACxC,aAAa,GAAG,aAAa,GAAG,CAAC,CAAC;YAElC,aAAa,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,CAAC;YAE5C,IAAI,aAAa,KAAK,CAAC,EAAE;gBACvB,aAAa,CAAC,MAAM,CAAC,+BAA+B,CAAC,CAAC;gBACtD,MAAM;aACP;SACF;QACD,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,CAAC;IAClD,CAAC;IAKD,KAAK;IAEL,CAAC;IAED;IACA,CAAC","sourcesContent":["import {Logger_LogLevels, Logger_MessageDirection} from \"./enums\";\r\nimport {DateTime, Debug, Exception, NString, StackTrace, StringBuilder, Thread, isNullOrUndefined} from \"@magic-xpa/mscorelib\";\r\nimport {OSEnvironment} from \"./PlatformUtils\";\r\nimport {DateTimeUtils} from \"./DateTimeUtils\";\r\nimport {XMLConstants} from \"./XMLConstants\";\r\nimport * as JSStackTrace from 'stacktrace-js';\r\nimport {RequestInfo} from \"./RequestInfo\";\r\nimport {StrUtil} from \"./StrUtil\";\r\nimport JSStackFrame = JSStackTrace.StackFrame;\r\n\r\nexport enum LogType {\r\n  info = 1,\r\n  warning,\r\n  error\r\n}\r\n\r\n\r\n/// <summary>\r\n/// Logger class will take care of client side logging . It will check for various log levels and accordingly will write messages in log file.\r\n/// </summary>\r\n//@dynamic\r\nexport class Logger {\r\n  static instance: Logger = null;\r\n  LogLevel: Logger_LogLevels = 0; // InternalLogLevel\r\n\r\n  /// <summary>\r\n  /// While writing the error messages in the file play the beep.\r\n  /// </summary>\r\n  ShouldBeep: boolean = false;\r\n\r\n  static set Instance(value: Logger) {\r\n    Logger.instance = value;\r\n  }\r\n\r\n  static get Instance(): Logger {\r\n    if (Logger.instance === null) {\r\n      Logger.instance = new Logger();\r\n    }\r\n    return Logger.instance;\r\n  }\r\n\r\n/// <summary>\r\n  /// Initialize logger\r\n  /// </summary>\r\n  /// <param name=\"logLevel\"></param>\r\n  /// <param name=\"internalLogSync\"></param>\r\n  Initialize(logLevel: Logger_LogLevels, shouldBeep: boolean): void {\r\n    try {\r\n      // let logSync: LogSyncMode  = LogSyncMode.Session;\r\n      this.LogLevel = logLevel;\r\n      this.ShouldBeep = shouldBeep;\r\n\r\n      // TODO: implement\r\n//   String strLogSync = internalLogSync;\r\n//   if (!string.IsNullOrEmpty(strLogSync))\r\n// {\r\n//   if (strLogSync.StartsWith(\"M\", StringComparison.CurrentCultureIgnoreCase))\r\n//   logSync = LogSyncMode.Message;\r\n//   else if (strLogSync.StartsWith(\"F\", StringComparison.CurrentCultureIgnoreCase))\r\n//   logSync = LogSyncMode.Flush;\r\n// }\r\n//\r\n    }\r\n    catch (e) {\r\n      this.WriteDevToLog(\"ClientManager.init(): \" + e.Message);\r\n    }\r\n  }\r\n\r\n  /// <summary></summary>\r\n  /// <param name=\"logLevel\"></param>\r\n  /// <returns></returns>\r\n\r\n  ShouldLog(logLevel: Logger_LogLevels): boolean;\r\n  ShouldLog(): boolean;\r\n  ShouldLog(logLevel?: Logger_LogLevels): boolean {\r\n    if (arguments.length === 1)\r\n      return this.ShouldLog_0(logLevel);\r\n    else\r\n      return this.ShouldLog_1();\r\n  }\r\n\r\n  private ShouldLog_0(logLevel: Logger_LogLevels): boolean {\r\n    return this.LogLevel === logLevel;\r\n  }\r\n\r\n  private ShouldLog_1(): boolean {\r\n    return this.LogLevel > Logger_LogLevels.None;\r\n  }\r\n\r\n  ShouldLogServerRelatedMessages(): boolean {\r\n    return (this.ShouldLogExtendedServerRelatedMessages() || Logger.Instance.ShouldLog(Logger_LogLevels.Server)) && this.LogLevel !== Logger_LogLevels.Basic;\r\n  }\r\n\r\n  ShouldLogExtendedServerRelatedMessages(): boolean {\r\n    return (Logger.Instance.ShouldLog(Logger_LogLevels.ServerMessages) || Logger.Instance.ShouldLog(Logger_LogLevels.Support) || Logger.Instance.ShouldLog(Logger_LogLevels.Development)) && this.LogLevel !== Logger_LogLevels.Basic;\r\n  }\r\n\r\n  /// <summary></summary>\r\n  /// <param name=\"msg\"></param>\r\n  /// <param name=\"openIfNecessary\">open the log file if not opened yet</param>\r\n\r\n  WriteToLog(msg: string, openIfNecessary: boolean, logType: LogType = LogType.info): void {\r\n\r\n    if (this.LogLevel > Logger_LogLevels.None || openIfNecessary) {\r\n      msg = NString.Format(\"{0} {1}\", (this.LogLevel === Logger_LogLevels.Basic) ? new Date().toISOString() : DateTimeUtils.ToString(DateTime.Now, XMLConstants.ERROR_LOG_TIME_FORMAT, this),\r\n                           msg);\r\n\r\n      switch (logType) {\r\n        case LogType.error:\r\n          console.error(msg);\r\n          break;\r\n        case LogType.warning:\r\n          console.warn(msg);\r\n          break;\r\n        default:\r\n          console.log(msg);\r\n      }\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  /// write a server access to the log\r\n  /// </summary>\r\n  /// <param name=\"msg\">the message to write to the log</param>\r\n  WriteServerToLog(msg: string): void {\r\n    if (this.ShouldLogServerRelatedMessages()) {\r\n      this.WriteToLog(NString.Format(\"Server, Thread={0}: \", Thread.CurrentThread.ManagedThreadId) + msg, false, LogType.info);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  /// write a server access to the log, including the content\r\n  /// </summary>\r\n  /// <param name=\"msg\">the message to write to the log</param>\r\n  WriteServerMessagesToLog(msg: string): void {\r\n    if (this.ShouldLogExtendedServerRelatedMessages()) {\r\n      this.WriteToLog(\"Server#: \" + msg, false, LogType.info);\r\n    }\r\n  }\r\n\r\n  /// <summary>Write a QC message to the log</summary>\r\n  /// <param name=\"msg\">the message to write to the log</param>\r\n  WriteSupportToLog(msg: string, skipLine: boolean): void {\r\n\r\n    if (this.LogLevel >= Logger_LogLevels.Support && this.LogLevel !== Logger_LogLevels.Basic) {\r\n      if (skipLine) {\r\n        this.WriteToLog(\"SUPPORT: \" + msg, false, LogType.info);\r\n      }\r\n      else {\r\n        this.WriteToLog(\"SUPPORT: \" + msg + OSEnvironment.EolSeq + \"-----------------------------------------------------------------------------------------------------------\", false, LogType.info);\r\n      }\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  /// write a performance message to the log\r\n  /// </summary>\r\n  /// <param name=\"msg\">the message to write to the log</param>\r\n  WriteGuiToLog(msg: string): void {\r\n\r\n    if (this.LogLevel >= Logger_LogLevels.Gui && this.LogLevel !== Logger_LogLevels.Basic) {\r\n      this.WriteToLog(msg, false, LogType.info);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  /// write a developer message to the log\r\n  /// </summary>\r\n  /// <param name=\"msg\">the message to write to the log</param>\r\n  WriteDevToLog(msg: string): void {\r\n    if (this.LogLevel >= Logger_LogLevels.Development && this.LogLevel !== Logger_LogLevels.Basic) {\r\n      this.WriteToLog(\"DEV: \" + msg, false, LogType.info);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  /// Writes a basic level entry to log\r\n  /// </summary>\r\n  /// <param name=\"messageDirection\">message direction relative to the current module (RIA client). Can be either MessageEntering or MessageLeaving</param>\r\n  /// <param name=\"statusCode\">HTTP status code</param>\r\n  /// <param name=\"contentLength\">length of the http message</param>\r\n  /// <param name=\"httpHeaders\">HTTP headers</param>\r\n  WriteBasicToLog(messageDirection: Logger_MessageDirection, contextID: string, sessionCounter: number, clientID: string, serverID: string, responseTime: number, statusCode: string, httpHeaders: string, contentLength: number): void {\r\n    if (this.LogLevel === Logger_LogLevels.Basic) {\r\n      let text: string = httpHeaders;\r\n      text = text.trim();\r\n      text = NString.Replace(text, \"\\r\\n\", \"|\");\r\n      let arg_E4_0: string = \"RIA,{0}_{1},{2},{3},{4},{5},-,{6},{7},{8},{9},{10},{11}\";\r\n      let expr_3E: any[] = new Array<any>(12);\r\n\r\n      // TODO : need to check How to handle Process class.\r\n      // expr_3E[0] = Process.GetCurrentProcess().Id;\r\n      expr_3E[1] = Thread.CurrentThread.ManagedThreadId;\r\n      expr_3E[2] = new Date().toISOString();\r\n      expr_3E[3] = ((messageDirection === Logger_MessageDirection.MessageLeaving) ? \"MSGL\" : \"MSGE\");\r\n      expr_3E[4] = contextID;\r\n      expr_3E[5] = sessionCounter;\r\n      expr_3E[6] = clientID;\r\n      expr_3E[7] = serverID;\r\n      expr_3E[8] = ((responseTime !== 0) ? responseTime.toString() : \"-\");\r\n      let arg_D3_1: number = 9;\r\n      let arg_D3_2: any;\r\n      arg_D3_2 = statusCode;\r\n      expr_3E[arg_D3_1] = arg_D3_2;\r\n      expr_3E[10] = text;\r\n      expr_3E[11] = contentLength;\r\n      let value: string = NString.Format(arg_E4_0, expr_3E);\r\n      console.log(value);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  /// Writes request information to log\r\n  /// </summary>\r\n  /// <param name=\"clientSession\">The clientSession object to be logged</param>\r\n  WriteRequestInfoToLog(requestInfo: RequestInfo, extraMessageStr: string): void {\r\n    if (this.LogLevel === Logger_LogLevels.RequestInfo) {\r\n\r\n      // Chrome debugger automatically recomputes logged objects.\r\n      // Hence, clone the requestInfo object to print the details at the time of logging\r\n      console.log(extraMessageStr, RequestInfo.clone(requestInfo));\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  /// Writes a request exception basic level entry to log\r\n  /// </summary>\r\n  /// <param name=\"contextID\"></param>\r\n  /// <param name=\"sessionCounter\"></param>\r\n  /// <param name=\"clientID\"></param>\r\n  /// <param name=\"serverID\"></param>\r\n  /// <param name=\"ex\">the logged exception</param>\r\n  WriteBasicErrorToLog(): void {\r\n    Debug.Assert(this.LogLevel === Logger_LogLevels.Basic);\r\n\r\n    // TODO : Need to check how to handle Process\r\n    // let value: string = NString.Format(\"RIA,{0}_{1},{2},{3},{4},{5},-,{6},{7},-,-,-,{8} {9}\", [\r\n    // Process.GetCurrentProcess().Id, Thread.CurrentThread.ManagedThreadId, DateTime.UtcNow.ToString(\"yyyy-MM-ddTHH:mm:ss.fffffffZ\"), \"RES\", contextID, sessionCounter, clientID, serverID, ex.GetType(), ex.Message\r\n    // ]);\r\n    // NConsole.WriteLine(value);\r\n  }\r\n\r\n  /// <summary>\r\n  /// Write an error to the log\r\n  /// </summary>\r\n  /// <param name=\"msg\">the message to write to the log</param>\r\n  WriteErrorToLog(msg: string): void {\r\n    this.WriteToLog(\"MagicWeb [ERROR]: \" + StrUtil.getConsoleErorString(msg), true, LogType.error);\r\n  }\r\n\r\n  /// <summary>\r\n  /// Write an internal error to the log. Also prints stack trace along with the message\r\n  /// </summary>\r\n  /// <param name=\"msg\">the message to write to the log</param>\r\n  WriteExceptionToLog(ex: Exception): void;\r\n  WriteExceptionToLog(ex: Error): void;\r\n  WriteExceptionToLog(ex: Exception, msg: string): void;\r\n  WriteExceptionToLog(msgOrEx: any, msg?: string): void {\r\n    if (msgOrEx instanceof Error) {\r\n      this.WriteExceptionToLog_2(msgOrEx, msg);\r\n      return;\r\n    }\r\n    if (arguments.length === 1 && (msgOrEx !== null || msgOrEx instanceof Exception)) {\r\n      this.WriteExceptionToLog_1(msgOrEx);\r\n      return;\r\n    }\r\n\r\n    this.WriteExceptionToLog_3(msgOrEx, msg);\r\n  }\r\n\r\n  WriteExceptionToLogWithMsg(msg: string): void {\r\n    this.WriteToLog(\"MagicWeb [ERROR]: \" + StrUtil.getConsoleErorString(msg), true, LogType.error);\r\n  }\r\n\r\n  private WriteExceptionToLog_1(ex: Exception): void {\r\n    this.WriteExceptionToLogWithMsg(NString.Format(\"{0} : {1}{2}{3}{4}\", [\r\n      ex.GetType(), OSEnvironment.EolSeq, ex.StackTrace, OSEnvironment.EolSeq, ex.Message\r\n    ]));\r\n  }\r\n\r\n  private WriteExceptionToLog_2(ex: Error, message: string): void {\r\n    if (isNullOrUndefined(message))\r\n      this.WriteExceptionToLogWithMsg(NString.Format(\"{0}{1}{2}\", [ex.stack, OSEnvironment.EolSeq, ex.message]));\r\n    else\r\n      this.WriteExceptionToLogWithMsg(NString.Format(\"{0}{1}{2}{4}{5}\", [message, OSEnvironment.EolSeq, ex.stack, OSEnvironment.EolSeq, ex.message]));\r\n  }\r\n\r\n  private WriteExceptionToLog_3(ex: Exception, msg: string): void {\r\n    this.WriteExceptionToLogWithMsg(NString.Format(\"{0}, {1} : {2}{3}{4}{5}\", [\r\n      ex.GetType(), msg, OSEnvironment.EolSeq, ex.StackTrace, OSEnvironment.EolSeq, ex.Message\r\n    ]));\r\n  }\r\n\r\n  /// <summary> write a warning to the log</summary>\r\n  /// <param name=\"msg\">the message to write to the log</param>\r\n  WriteWarningToLog(ex: Exception): void;\r\n  WriteWarningToLog(ex: Exception, msg: string): void;\r\n  WriteWarningToLog(ex: Error): void;\r\n  WriteWarningToLog(msgOrEx: any, msg?: string): void {\r\n    if (arguments.length === 1 && msgOrEx !== null) {\r\n      if (msgOrEx instanceof Exception)\r\n        this.WriteWarningToLog_1(msgOrEx);\r\n      else if (msgOrEx instanceof Error)\r\n        this.WriteWarningToLog_2(msgOrEx);\r\n    }\r\n    else\r\n      this.WriteWarningToLog_3(msgOrEx, msg);\r\n  }\r\n\r\n  WriteWarningToLogWithMsg(msg: string): void {\r\n\r\n    if (this.LogLevel !== Logger_LogLevels.Basic) {\r\n      this.WriteToLog(\"MagicWeb [WARNING]: \" + msg, true, LogType.warning);\r\n    }\r\n  }\r\n\r\n  private WriteWarningToLog_1(ex: Exception): void {\r\n    this.WriteWarningToLogWithMsg(ex.GetType() + \" : \" + OSEnvironment.EolSeq + ex.StackTrace + OSEnvironment.EolSeq + ex.Message);\r\n  }\r\n\r\n  private WriteWarningToLog_2(ex: Error): void {\r\n    this.WriteWarningToLogWithMsg(NString.Format(\"{0}{1}{2}\", [\r\n      ex.stack, OSEnvironment.EolSeq, ex.message\r\n    ]));\r\n  }\r\n\r\n  private WriteWarningToLog_3(ex: Exception, msg: string): void {\r\n    this.WriteWarningToLogWithMsg(NString.Format(\"{0}, {1} : {2}{3}{4}{5}\", [\r\n      ex.GetType(), msg, OSEnvironment.EolSeq, ex.StackTrace, OSEnvironment.EolSeq, ex.Message\r\n    ]));\r\n  }\r\n\r\n  WriteStackTrace(stackTrace: StackTrace, framesToPrint: number, traceTitle: string): void {\r\n\r\n    if (traceTitle === null) {\r\n      traceTitle = \"Stack trace:\";\r\n    }\r\n    let stringBuilder: StringBuilder = new StringBuilder(traceTitle + OSEnvironment.EolSeq);\r\n    let frames: JSStackFrame[] = stackTrace.GetFrames();\r\n    let array: JSStackFrame[] = frames;\r\n    for (let i: number = 0; i < array.length; i = i + 1) {\r\n      let stackFrame: JSStackFrame = array[i];\r\n      framesToPrint = framesToPrint - 1;\r\n\r\n      stringBuilder.Append(stackFrame.toString());\r\n\r\n      if (framesToPrint === 0) {\r\n        stringBuilder.Append(\"\\t... more stack frames ...\\n\");\r\n        break;\r\n      }\r\n    }\r\n    this.WriteToLog(stringBuilder.ToString(), true);\r\n  }\r\n\r\n  /// <summary>\r\n  /// Flush the log writer.\r\n  /// </summary>\r\n  Flush(): void {\r\n\r\n  }\r\n\r\n  constructor() {\r\n  }\r\n}\r\n"]}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
export var MagicProperties;
|
|
2
|
-
(function (MagicProperties) {
|
|
3
|
-
MagicProperties["LineDivider"] = "line_divider";
|
|
4
|
-
MagicProperties["ImageFile"] = "image_file";
|
|
5
|
-
MagicProperties["Wallpaper"] = "wallpaper";
|
|
6
|
-
})(MagicProperties || (MagicProperties = {}));
|
|
7
|
-
export var BindingLevel;
|
|
8
|
-
(function (BindingLevel) {
|
|
9
|
-
BindingLevel[BindingLevel["Control"] = 1] = "Control";
|
|
10
|
-
BindingLevel[BindingLevel["Character"] = 2] = "Character";
|
|
11
|
-
})(BindingLevel || (BindingLevel = {}));
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWFnaWNDb25zdGFudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91dGlscy9zcmMvTWFnaWNDb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksZUFJWDtBQUpELFdBQVksZUFBZTtJQUN6QiwrQ0FBNEIsQ0FBQTtJQUM1QiwyQ0FBd0IsQ0FBQTtJQUN4QiwwQ0FBdUIsQ0FBQTtBQUN6QixDQUFDLEVBSlcsZUFBZSxLQUFmLGVBQWUsUUFJMUI7QUFFRCxNQUFNLENBQU4sSUFBWSxZQUlYO0FBSkQsV0FBWSxZQUFZO0lBRXRCLHFEQUFXLENBQUE7SUFDWCx5REFBUyxDQUFBO0FBQ1gsQ0FBQyxFQUpXLFlBQVksS0FBWixZQUFZLFFBSXZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gTWFnaWNQcm9wZXJ0aWVzIHtcclxuICBMaW5lRGl2aWRlciA9IFwibGluZV9kaXZpZGVyXCIsXHJcbiAgSW1hZ2VGaWxlID0gXCJpbWFnZV9maWxlXCIsXHJcbiAgV2FsbHBhcGVyID0gXCJ3YWxscGFwZXJcIixcclxufVxyXG5cclxuZXhwb3J0IGVudW0gQmluZGluZ0xldmVsXHJcbntcclxuICBDb250cm9sID0gMSxcclxuICBDaGFyYWN0ZXJcclxufVxyXG4iXX0=
|
package/esm2022/src/Misc.mjs
DELETED
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
import { StringBuilder, NString, NNumber, DateTime, RefParam } from "@magic-xpa/mscorelib";
|
|
2
|
-
export class Misc {
|
|
3
|
-
static WriteStackTrace(throwable) {
|
|
4
|
-
console.log(throwable.Message);
|
|
5
|
-
console.log(throwable.StackTrace);
|
|
6
|
-
}
|
|
7
|
-
static ToSByteArray(byteArray) {
|
|
8
|
-
let sbyteArray = null;
|
|
9
|
-
if (byteArray !== null) {
|
|
10
|
-
sbyteArray = new Int8Array(byteArray.length);
|
|
11
|
-
for (let i = 0; i < byteArray.length; i = i + 1) {
|
|
12
|
-
sbyteArray[i] = byteArray[i];
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
return sbyteArray;
|
|
16
|
-
}
|
|
17
|
-
static ToByteArray(sbyteArray) {
|
|
18
|
-
let byteArray = null;
|
|
19
|
-
if (sbyteArray !== null) {
|
|
20
|
-
byteArray = new Uint8Array(sbyteArray.length);
|
|
21
|
-
for (let i = 0; i < sbyteArray.length; i = i + 1) {
|
|
22
|
-
byteArray[i] = sbyteArray[i];
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
return byteArray;
|
|
26
|
-
}
|
|
27
|
-
static CompareByteArray(source, destination, numberOfBytes) {
|
|
28
|
-
if (source.length >= numberOfBytes && destination.length >= numberOfBytes) {
|
|
29
|
-
for (let len = 0; len < numberOfBytes; len++) {
|
|
30
|
-
if (source[len] !== destination[len])
|
|
31
|
-
return false;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
else
|
|
35
|
-
return false;
|
|
36
|
-
return true;
|
|
37
|
-
}
|
|
38
|
-
static URShift(number, bits) {
|
|
39
|
-
let result;
|
|
40
|
-
if (number >= 0) {
|
|
41
|
-
result = number >> bits;
|
|
42
|
-
}
|
|
43
|
-
else {
|
|
44
|
-
result = (number >> bits) + (2 << ~bits);
|
|
45
|
-
}
|
|
46
|
-
return result;
|
|
47
|
-
}
|
|
48
|
-
static getSystemMilliseconds() {
|
|
49
|
-
return Math.floor((DateTime.Now.Ticks - 621355968000000000) / 10000);
|
|
50
|
-
}
|
|
51
|
-
static CompareIntArrays(arrayOne, arrayTwo) {
|
|
52
|
-
let areEqual = false;
|
|
53
|
-
if (arrayOne === arrayTwo) {
|
|
54
|
-
areEqual = true;
|
|
55
|
-
}
|
|
56
|
-
else {
|
|
57
|
-
if (arrayOne !== null && arrayTwo !== null) {
|
|
58
|
-
if (arrayOne.length === arrayTwo.length) {
|
|
59
|
-
for (let i = 0; i < arrayOne.length; i = i + 1) {
|
|
60
|
-
if (arrayOne[i] !== arrayTwo[i]) {
|
|
61
|
-
break;
|
|
62
|
-
}
|
|
63
|
-
areEqual = true;
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
return areEqual;
|
|
69
|
-
}
|
|
70
|
-
static GetCommaSeperatedString(intArray) {
|
|
71
|
-
let temp = new StringBuilder();
|
|
72
|
-
for (let val = 0; val < intArray.length; val = val + 1) {
|
|
73
|
-
let value = intArray[val];
|
|
74
|
-
if (temp.Length > 0) {
|
|
75
|
-
temp.Append(",");
|
|
76
|
-
}
|
|
77
|
-
temp.Append(value);
|
|
78
|
-
}
|
|
79
|
-
return temp.ToString();
|
|
80
|
-
}
|
|
81
|
-
static GetIntArray(commaSeparatedValue) {
|
|
82
|
-
let intArray = new Array(0);
|
|
83
|
-
if (!NString.IsNullOrEmpty(commaSeparatedValue)) {
|
|
84
|
-
let vals = commaSeparatedValue.split(',');
|
|
85
|
-
intArray = new Array(vals.length);
|
|
86
|
-
let outInt = new RefParam(0);
|
|
87
|
-
for (let iCtr = 0; iCtr < vals.length; iCtr = iCtr + 1) {
|
|
88
|
-
NNumber.TryParse(vals[iCtr], outInt);
|
|
89
|
-
intArray[iCtr] = outInt.value;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
return intArray;
|
|
93
|
-
}
|
|
94
|
-
static IsWebUrl(fileName) {
|
|
95
|
-
return fileName.toLowerCase().startsWith("http");
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Misc.js","sourceRoot":"","sources":["../../../../../projects/utils/src/Misc.ts"],"names":[],"mappings":"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","sourcesContent":["// In order to convert some functionality to Visual C#, the Java Language Conversion Assistant\r\n// creates \"support classes\" that duplicate the original functionality.\r\n//\r\n// Support classes replicate the functionality of the original code, but in some cases they are\r\n// substantially different architecturally. Although every effort is made to preserve the\r\n// original architecture of the application in the converted project, the user should be aware that\r\n// the primary goal of these support classes is to replicate functionality, and that at times\r\n// the architecture of the resulting solution may differ somewhat.\r\n\r\n\r\nimport {\r\n  Exception, StringBuilder,\r\n  NString, NNumber,\r\n  DateTime, RefParam\r\n} from \"@magic-xpa/mscorelib\";\r\n\r\n\r\n\r\n/// <summary>\r\n/// Contains conversion support elements such as classes, interfaces and static methods.\r\n/// </summary>\r\nexport class Misc {\r\n\r\n  /// <summary>\r\n  /// Writes the exception stack trace to the received stream\r\n  /// </summary>\r\n  /// <param name=\"throwable\">Exception to obtain information from</param>\r\n  /// <param name=\"stream\">Output sream used to write to</param>\r\n  static WriteStackTrace(throwable: Exception): void {\r\n    console.log(throwable.Message);\r\n    console.log(throwable.StackTrace);\r\n  }\r\n\r\n  /// <summary>\r\n  /// Receives a byte array and returns it transformed in an byte array\r\n  /// </summary>\r\n  /// <param name=\"byteArray\">Byte array to process</param>\r\n  /// <returns>The transformed array</returns>\r\n  static ToSByteArray(byteArray: Uint8Array): Int8Array {\r\n    let sbyteArray: Int8Array = null;\r\n    if (byteArray !== null) {\r\n      sbyteArray = new Int8Array(byteArray.length);\r\n      for (let i: number = 0; i < byteArray.length; i = i + 1) {\r\n        sbyteArray[i] = <number>byteArray[i];\r\n      }\r\n    }\r\n    return sbyteArray;\r\n  }\r\n\r\n  /// <summary>\r\n  /// Receives sbyte array and returns it transformed in a byte array\r\n  /// </summary>\r\n  /// <param name=\"sbyteArray\">sbyte array to process</param>\r\n  /// <returns>The transformed array</returns>\r\n  static ToByteArray(sbyteArray: Int8Array): Uint8Array {\r\n    let byteArray: Uint8Array = null;\r\n    if (sbyteArray !== null) {\r\n      byteArray = new Uint8Array(sbyteArray.length);\r\n      for (let i: number = 0; i < sbyteArray.length; i = i + 1) {\r\n        byteArray[i] = <number>sbyteArray[i];\r\n      }\r\n    }\r\n    return byteArray;\r\n  }\r\n\r\n  /// <summary> Compares number of bytes in two byte arrays</summary>\r\n  /// <param name=\"source\"></param>\r\n  /// <param name=\"destination\"></param>\r\n  /// <param name=\"numberOfBytes\"></param>\r\n  /// <returns> boolen true if equal</returns>\r\n  static CompareByteArray(source: Uint8Array, destination: Uint8Array, numberOfBytes: number): boolean {\r\n    if (source.length >= numberOfBytes && destination.length >= numberOfBytes) {\r\n      for (let len: number = 0; len < numberOfBytes; len++) {\r\n        if (source[len] !== destination[len])\r\n          return false;\r\n      }\r\n    }\r\n    else\r\n      return false;\r\n\r\n    return true;\r\n  }\r\n\r\n  /// <summary>\r\n  /// Performs an unsigned bitwise right shift with the specified number\r\n  /// </summary>\r\n  /// <param name=\"number\">Number to operate on</param>\r\n  /// <param name=\"bits\">Ammount of bits to shift</param>\r\n  /// <returns>The resulting number from the shift operation</returns>\r\n  // TODO: instead of calling URShift(number, bits), we can use((uint)number) >> bits.\r\n  static URShift(number: number, bits: number): number {\r\n    let result: number;\r\n    if (number >= 0) {\r\n      result = number >> bits;\r\n    }\r\n    else {\r\n      result = (number >> bits) + (2 << ~bits);\r\n    }\r\n    return result;\r\n  }\r\n\r\n  /// <summary>\r\n  /// get system's time in milliseconds\r\n  /// </summary>\r\n  /// <returns></returns>\r\n  static getSystemMilliseconds(): number {\r\n    // TODO - check if we need this adjustment\r\n    return Math.floor((DateTime.Now.Ticks - 621355968000000000) / 10000);\r\n  }\r\n\r\n  /// <summary>\r\n  /// Compares 2 int arrays\r\n  /// </summary>\r\n  /// <param name=\"arrayOne\"></param>\r\n  /// <param name=\"arrayTwo\"></param>\r\n  /// <returns>true if arrays are equal else false</returns>\r\n  static CompareIntArrays(arrayOne: number[], arrayTwo: number[]): boolean {\r\n    let areEqual: boolean = false;\r\n    if (arrayOne === arrayTwo) {\r\n      areEqual = true;\r\n    }\r\n    else {\r\n      if (arrayOne !== null && arrayTwo !== null) {\r\n        if (arrayOne.length === arrayTwo.length) {\r\n          for (let i: number = 0; i < arrayOne.length; i = i + 1) {\r\n            if (arrayOne[i] !== arrayTwo[i]) {\r\n              break;\r\n            }\r\n            areEqual = true;\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return areEqual;\r\n  }\r\n\r\n  /// <summary>\r\n  /// Returns the comma separated string for the values passed in int array.\r\n  /// </summary>\r\n  /// <param name=\"values\">Integer array</param>\r\n  /// <returns>comma separated string</returns>\r\n  static GetCommaSeperatedString(intArray: number[]): string {\r\n    let temp: StringBuilder = new StringBuilder();\r\n    for (let val: number = 0; val < intArray.length; val = val + 1) {\r\n      let value: number = intArray[val];\r\n      if (temp.Length > 0) {\r\n        temp.Append(\",\");\r\n      }\r\n      temp.Append(value);\r\n    }\r\n    return temp.ToString();\r\n  }\r\n\r\n  /// <summary>\r\n  /// Returns int array out of comma separated string\r\n  /// </summary>\r\n  /// <param name=\"value\">comma separated string</param>\r\n  /// <returns>Integer array</returns>\r\n  static GetIntArray(commaSeparatedValue: string): number[] {\r\n    let intArray: number[] = new Array<number>(0);\r\n\r\n    if (!NString.IsNullOrEmpty(commaSeparatedValue)) {\r\n      let vals: string[] = commaSeparatedValue.split(',');\r\n      intArray = new Array<number>(vals.length);\r\n\r\n      let outInt: RefParam<number> = new RefParam(0);\r\n      for (let iCtr: number = 0; iCtr < vals.length; iCtr = iCtr + 1) {\r\n        NNumber.TryParse(vals[iCtr], outInt);\r\n        intArray[iCtr] = outInt.value;\r\n      }\r\n    }\r\n\r\n    return intArray;\r\n  }\r\n\r\n  static IsWebUrl(fileName: string): boolean {\r\n    return fileName.toLowerCase().startsWith(\"http\");\r\n  }\r\n}\r\n"]}
|