ionic-logging-service 16.0.0 → 17.0.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.
Files changed (26) hide show
  1. package/README.md +1 -0
  2. package/esm2022/lib/ajax-appender.model.mjs +149 -0
  3. package/esm2022/lib/local-storage-appender.model.mjs +177 -0
  4. package/{esm2020 → esm2022}/lib/logging-service.module.mjs +5 -5
  5. package/{esm2020 → esm2022}/lib/logging.service.mjs +4 -4
  6. package/esm2022/lib/memory-appender.model.mjs +133 -0
  7. package/{fesm2015 → fesm2022}/ionic-logging-service.mjs +14 -14
  8. package/{fesm2020 → fesm2022}/ionic-logging-service.mjs.map +1 -1
  9. package/package.json +7 -13
  10. package/esm2020/lib/ajax-appender.model.mjs +0 -149
  11. package/esm2020/lib/local-storage-appender.model.mjs +0 -177
  12. package/esm2020/lib/memory-appender.model.mjs +0 -133
  13. package/fesm2015/ionic-logging-service.mjs.map +0 -1
  14. package/fesm2020/ionic-logging-service.mjs +0 -992
  15. /package/{esm2020 → esm2022}/ionic-logging-service.mjs +0 -0
  16. /package/{esm2020 → esm2022}/lib/ajax-appender.configuration.mjs +0 -0
  17. /package/{esm2020 → esm2022}/lib/browser-console-appender.configuration.mjs +0 -0
  18. /package/{esm2020 → esm2022}/lib/json-layout.model.mjs +0 -0
  19. /package/{esm2020 → esm2022}/lib/local-storage-appender.configuration.mjs +0 -0
  20. /package/{esm2020 → esm2022}/lib/log-level.converter.mjs +0 -0
  21. /package/{esm2020 → esm2022}/lib/log-level.model.mjs +0 -0
  22. /package/{esm2020 → esm2022}/lib/log-message.model.mjs +0 -0
  23. /package/{esm2020 → esm2022}/lib/logger.model.mjs +0 -0
  24. /package/{esm2020 → esm2022}/lib/logging-service.configuration.mjs +0 -0
  25. /package/{esm2020 → esm2022}/lib/memory-appender.configuration.mjs +0 -0
  26. /package/{esm2020 → esm2022}/public_api.mjs +0 -0
package/README.md CHANGED
@@ -4,6 +4,7 @@
4
4
 
5
5
  | ionic-logging-service | Ionic | Angular
6
6
  | ------ | -------- | ------
7
+ | 17.0.0 | >= 6.1.9 | ^16.0.0
7
8
  | 16.0.0 | >= 6.1.9 | ^15.0.0
8
9
  | 15.0.0 | >= 6.1.9 | ^14.0.0
9
10
  | 14.0.0 | >= 6.0.0 | ^13.0.0
@@ -0,0 +1,149 @@
1
+ import { EventEmitter } from "@angular/core";
2
+ import * as log4javascript from "log4javascript";
3
+ import { JsonLayout } from "./json-layout.model";
4
+ import { LogLevelConverter } from "./log-level.converter";
5
+ /**
6
+ * An appender which sends the log messages to a server via HTTP.
7
+ *
8
+ * A typical configuration could be:
9
+ *
10
+ * ```json
11
+ * {
12
+ * "url": "https://my.backend.xy/LoggingBackend",
13
+ * "batchSize": 10,
14
+ * "timerInterval": 60000,
15
+ * "threshold": "INFO"
16
+ * }
17
+ * ```
18
+ */
19
+ export class AjaxAppender extends log4javascript.Appender {
20
+ static { this.batchSizeDefault = 1; }
21
+ static { this.timerIntervalDefault = 0; }
22
+ static { this.thresholdDefault = "WARN"; }
23
+ /**
24
+ * Creates a new instance of the appender.
25
+ *
26
+ * @param configuration configuration for the appender.
27
+ */
28
+ constructor(configuration) {
29
+ super();
30
+ if (!configuration) {
31
+ throw new Error("configuration must be not empty");
32
+ }
33
+ if (!configuration.url) {
34
+ throw new Error("url must be not empty");
35
+ }
36
+ this.ajaxAppender = new log4javascript.AjaxAppender(configuration.url, configuration.withCredentials);
37
+ this.url = configuration.url;
38
+ this.withCredentials = configuration.withCredentials;
39
+ this.ajaxAppender.setLayout(new JsonLayout(false, false));
40
+ this.ajaxAppender.addHeader("Content-Type", "application/json; charset=utf-8");
41
+ this.ajaxAppender.setSendAllOnUnload(true);
42
+ this.appenderFailed = new EventEmitter();
43
+ this.ajaxAppender.setFailCallback((message) => {
44
+ this.appenderFailed.emit(message);
45
+ });
46
+ // process remaining configuration
47
+ this.configure({
48
+ batchSize: configuration.batchSize || AjaxAppender.batchSizeDefault,
49
+ threshold: configuration.threshold || AjaxAppender.thresholdDefault,
50
+ timerInterval: configuration.timerInterval || AjaxAppender.timerIntervalDefault,
51
+ url: configuration.url,
52
+ withCredentials: configuration.withCredentials
53
+ });
54
+ }
55
+ /**
56
+ * Configures the logging depending on the given configuration.
57
+ *
58
+ * Only the defined properties get overwritten.
59
+ * Neither url nor withCredentials can be modified.
60
+ *
61
+ * @param configuration configuration data.
62
+ */
63
+ configure(configuration) {
64
+ if (configuration) {
65
+ if (configuration.url && configuration.url !== this.url) {
66
+ throw new Error("url must not be changed");
67
+ }
68
+ if (configuration.withCredentials && configuration.withCredentials !== this.withCredentials) {
69
+ throw new Error("withCredentials must not be changed");
70
+ }
71
+ if (configuration.batchSize) {
72
+ this.setBatchSize(configuration.batchSize);
73
+ }
74
+ if (typeof configuration.timerInterval === "number") {
75
+ this.setTimerInterval(configuration.timerInterval);
76
+ }
77
+ if (configuration.threshold) {
78
+ const convertedThreshold = LogLevelConverter.levelToLog4Javascript(LogLevelConverter.levelFromString(configuration.threshold));
79
+ this.setThreshold(convertedThreshold);
80
+ }
81
+ }
82
+ }
83
+ /**
84
+ * Appender-specific method to append a log message.
85
+ *
86
+ * @param loggingEvent event to be appended.
87
+ */
88
+ append(loggingEvent) {
89
+ this.ajaxAppender.append(loggingEvent);
90
+ }
91
+ /**
92
+ * Gets the appender's name.
93
+ * Mainly for unit testing purposes.
94
+ *
95
+ * @return appender's name
96
+ */
97
+ toString() {
98
+ return "Ionic.Logging.AjaxAppender";
99
+ }
100
+ /**
101
+ * Get the internally used appender.
102
+ * Mainly for unit testing purposes.
103
+ */
104
+ getInternalAppender() {
105
+ return this.ajaxAppender;
106
+ }
107
+ /**
108
+ * Returns the number of log messages sent in each request.
109
+ */
110
+ getBatchSize() {
111
+ return this.ajaxAppender.getBatchSize();
112
+ }
113
+ /**
114
+ * Sets the number of log messages to send in each request.
115
+ *
116
+ * @param batchSize new batch size
117
+ */
118
+ setBatchSize(batchSize) {
119
+ this.ajaxAppender.setBatchSize(batchSize);
120
+ }
121
+ /**
122
+ * Returns the appender's layout.
123
+ */
124
+ getLayout() {
125
+ return this.ajaxAppender.getLayout();
126
+ }
127
+ /**
128
+ * Sets the appender's layout.
129
+ */
130
+ setLayout(layout) {
131
+ this.ajaxAppender.setLayout(layout);
132
+ }
133
+ /**
134
+ * Returns the length of time in milliseconds between each sending of queued log messages.
135
+ */
136
+ getTimerInterval() {
137
+ return this.ajaxAppender.getTimerInterval();
138
+ }
139
+ /**
140
+ * Sets the length of time in milliseconds between each sending of queued log messages.
141
+ *
142
+ * @param timerInterval new timer interval
143
+ */
144
+ setTimerInterval(timerInterval) {
145
+ this.ajaxAppender.setTimed(timerInterval > 0);
146
+ this.ajaxAppender.setTimerInterval(timerInterval);
147
+ }
148
+ }
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ajax-appender.model.js","sourceRoot":"","sources":["../../../../projects/ionic-logging-service/src/lib/ajax-appender.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from \"@angular/core\";\n\nimport * as log4javascript from \"log4javascript\";\n\nimport { AjaxAppenderConfiguration } from \"./ajax-appender.configuration\";\nimport { JsonLayout } from \"./json-layout.model\";\nimport { LogLevelConverter } from \"./log-level.converter\";\n\n/**\n * An appender which sends the log messages to a server via HTTP.\n *\n * A typical configuration could be:\n *\n * ```json\n * {\n *   \"url\": \"https://my.backend.xy/LoggingBackend\",\n *   \"batchSize\": 10,\n *   \"timerInterval\": 60000,\n *   \"threshold\": \"INFO\"\n * }\n * ```\n */\nexport class AjaxAppender extends log4javascript.Appender {\n\n\tprivate static batchSizeDefault = 1;\n\tprivate static timerIntervalDefault = 0;\n\tprivate static thresholdDefault = \"WARN\";\n\n\t/**\n\t * Event triggered when the appender could not send log messages to the server.\n\t *\n\t * @param message error message\n\t */\n\tpublic appenderFailed: EventEmitter<string>;\n\n\tprivate ajaxAppender: log4javascript.AjaxAppender;\n\tprivate url: string;\n\tprivate withCredentials: boolean;\n\n\t/**\n\t * Creates a new instance of the appender.\n\t *\n\t * @param configuration configuration for the appender.\n\t */\n\tconstructor(configuration: AjaxAppenderConfiguration) {\n\t\tsuper();\n\n\t\tif (!configuration) {\n\t\t\tthrow new Error(\"configuration must be not empty\");\n\t\t}\n\t\tif (!configuration.url) {\n\t\t\tthrow new Error(\"url must be not empty\");\n\t\t}\n\t\tthis.ajaxAppender = new log4javascript.AjaxAppender(configuration.url, configuration.withCredentials);\n\t\tthis.url = configuration.url;\n\t\tthis.withCredentials = configuration.withCredentials;\n\n\t\tthis.ajaxAppender.setLayout(new JsonLayout(false, false));\n\t\tthis.ajaxAppender.addHeader(\"Content-Type\", \"application/json; charset=utf-8\");\n\t\tthis.ajaxAppender.setSendAllOnUnload(true);\n\n\t\tthis.appenderFailed = new EventEmitter<string>();\n\t\tthis.ajaxAppender.setFailCallback((message: any) => {\n\t\t\tthis.appenderFailed.emit(message);\n\t\t});\n\n\t\t// process remaining configuration\n\t\tthis.configure({\n\t\t\tbatchSize: configuration.batchSize || AjaxAppender.batchSizeDefault,\n\t\t\tthreshold: configuration.threshold || AjaxAppender.thresholdDefault,\n\t\t\ttimerInterval: configuration.timerInterval || AjaxAppender.timerIntervalDefault,\n\t\t\turl: configuration.url,\n\t\t\twithCredentials: configuration.withCredentials\n\t\t});\n\n\t}\n\n\t/**\n\t * Configures the logging depending on the given configuration.\n\t *\n\t * Only the defined properties get overwritten.\n\t * Neither url nor withCredentials can be modified.\n\t *\n\t * @param configuration configuration data.\n\t */\n\tpublic configure(configuration: AjaxAppenderConfiguration): void {\n\t\tif (configuration) {\n\t\t\tif (configuration.url && configuration.url !== this.url) {\n\t\t\t\tthrow new Error(\"url must not be changed\");\n\t\t\t}\n\t\t\tif (configuration.withCredentials && configuration.withCredentials !== this.withCredentials) {\n\t\t\t\tthrow new Error(\"withCredentials must not be changed\");\n\t\t\t}\n\t\t\tif (configuration.batchSize) {\n\t\t\t\tthis.setBatchSize(configuration.batchSize);\n\t\t\t}\n\t\t\tif (typeof configuration.timerInterval === \"number\") {\n\t\t\t\tthis.setTimerInterval(configuration.timerInterval);\n\t\t\t}\n\t\t\tif (configuration.threshold) {\n\t\t\t\tconst convertedThreshold = LogLevelConverter.levelToLog4Javascript(\n\t\t\t\t\tLogLevelConverter.levelFromString(configuration.threshold));\n\t\t\t\tthis.setThreshold(convertedThreshold);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Appender-specific method to append a log message.\n\t *\n\t * @param loggingEvent event to be appended.\n\t */\n\tpublic append(loggingEvent: log4javascript.LoggingEvent): void {\n\t\tthis.ajaxAppender.append(loggingEvent);\n\t}\n\n\t/**\n\t * Gets the appender's name.\n\t * Mainly for unit testing purposes.\n\t *\n\t * @return appender's name\n\t */\n\tpublic toString(): string {\n\t\treturn \"Ionic.Logging.AjaxAppender\";\n\t}\n\n\t/**\n\t * Get the internally used appender.\n\t * Mainly for unit testing purposes.\n\t */\n\tpublic getInternalAppender(): log4javascript.AjaxAppender {\n\t\treturn this.ajaxAppender;\n\t}\n\n\t/**\n\t * Returns the number of log messages sent in each request.\n\t */\n\tpublic getBatchSize(): number {\n\t\treturn this.ajaxAppender.getBatchSize();\n\t}\n\n\t/**\n\t * Sets the number of log messages to send in each request.\n\t *\n\t * @param batchSize new batch size\n\t */\n\tpublic setBatchSize(batchSize: number): void {\n\t\tthis.ajaxAppender.setBatchSize(batchSize);\n\t}\n\n\t/**\n\t * Returns the appender's layout.\n\t */\n\tpublic getLayout(): log4javascript.Layout {\n\t\treturn this.ajaxAppender.getLayout();\n\t}\n\n\t/**\n\t * Sets the appender's layout.\n\t */\n\tpublic setLayout(layout: log4javascript.Layout): void {\n\t\tthis.ajaxAppender.setLayout(layout);\n\t}\n\n\t/**\n\t * Returns the length of time in milliseconds between each sending of queued log messages.\n\t */\n\tpublic getTimerInterval(): number {\n\t\treturn this.ajaxAppender.getTimerInterval();\n\t}\n\n\t/**\n\t * Sets the length of time in milliseconds between each sending of queued log messages.\n\t *\n\t * @param timerInterval new timer interval\n\t */\n\tpublic setTimerInterval(timerInterval: number): void {\n\t\tthis.ajaxAppender.setTimed(timerInterval > 0);\n\t\tthis.ajaxAppender.setTimerInterval(timerInterval);\n\t}\n}\n"]}
@@ -0,0 +1,177 @@
1
+ import * as log4javascript from "log4javascript";
2
+ import { LogLevelConverter } from "./log-level.converter";
3
+ import { LogLevel } from "./log-level.model";
4
+ /**
5
+ * An appender which stores the log messages in the browser's local storage.
6
+ *
7
+ * The messages are saved JSON-serialized.
8
+ * You have to configure which key is used for storing the messages.
9
+ *
10
+ * A typical configuration could be:
11
+ *
12
+ * ```json
13
+ * {
14
+ * "localStorageKey": "myLogs",
15
+ * "maxMessages": 500,
16
+ * "threshold": "INFO"
17
+ * }
18
+ * ```
19
+ */
20
+ export class LocalStorageAppender extends log4javascript.Appender {
21
+ static { this.maxMessagesDefault = 250; }
22
+ static { this.thresholdDefault = "WARN"; }
23
+ /**
24
+ * Creates a new instance of the appender.
25
+ *
26
+ * @param configuration configuration for the appender.
27
+ */
28
+ constructor(configuration) {
29
+ super();
30
+ if (!configuration) {
31
+ throw new Error("configuration must be not empty");
32
+ }
33
+ if (!configuration.localStorageKey || configuration.localStorageKey === "") {
34
+ throw new Error("localStorageKey must be not empty");
35
+ }
36
+ this.localStorageKey = configuration.localStorageKey;
37
+ // read existing logMessages
38
+ this.logMessages = LocalStorageAppender.loadLogMessages(this.localStorageKey);
39
+ // process remaining configuration
40
+ this.configure({
41
+ localStorageKey: configuration.localStorageKey,
42
+ maxMessages: configuration.maxMessages || LocalStorageAppender.maxMessagesDefault,
43
+ threshold: configuration.threshold || LocalStorageAppender.thresholdDefault,
44
+ });
45
+ }
46
+ /**
47
+ * Load log messages from local storage which are stored there under the given key.
48
+ *
49
+ * @param localStorageKey local storage key
50
+ * @return stored messages
51
+ */
52
+ static loadLogMessages(localStorageKey) {
53
+ let logMessages;
54
+ if (!localStorageKey || localStorage.getItem(localStorageKey) === null) {
55
+ logMessages = [];
56
+ }
57
+ else {
58
+ logMessages = JSON.parse(localStorage.getItem(localStorageKey));
59
+ for (const logMessage of logMessages) {
60
+ // timestamps are serialized as strings
61
+ logMessage.timeStamp = new Date(logMessage.timeStamp);
62
+ }
63
+ }
64
+ return logMessages;
65
+ }
66
+ /**
67
+ * Remove log messages from local storage which are stored there under the given key.
68
+ *
69
+ * @param localStorageKey local storage key
70
+ */
71
+ static removeLogMessages(localStorageKey) {
72
+ localStorage.removeItem(localStorageKey);
73
+ }
74
+ /**
75
+ * Configures the logging depending on the given configuration.
76
+ *
77
+ * Only the defined properties get overwritten.
78
+ * The localStorageKey cannot be modified.
79
+ *
80
+ * @param configuration configuration data.
81
+ */
82
+ configure(configuration) {
83
+ if (configuration) {
84
+ if (configuration.localStorageKey && configuration.localStorageKey !== this.localStorageKey) {
85
+ throw new Error("localStorageKey must not be changed");
86
+ }
87
+ if (configuration.maxMessages) {
88
+ this.setMaxMessages(configuration.maxMessages);
89
+ }
90
+ if (configuration.threshold) {
91
+ const convertedThreshold = LogLevelConverter.levelToLog4Javascript(LogLevelConverter.levelFromString(configuration.threshold));
92
+ this.setThreshold(convertedThreshold);
93
+ }
94
+ }
95
+ }
96
+ /**
97
+ * Appender-specific method to append a log message.
98
+ *
99
+ * @param loggingEvent event to be appended.
100
+ */
101
+ append(loggingEvent) {
102
+ // if logMessages is already full, remove oldest element
103
+ while (this.logMessages.length >= this.maxMessages) {
104
+ this.logMessages.shift();
105
+ }
106
+ // add event to logMessages
107
+ const message = {
108
+ level: LogLevel[LogLevelConverter.levelFromLog4Javascript(loggingEvent.level)],
109
+ logger: typeof loggingEvent.logger !== "undefined" ? loggingEvent.logger.name : undefined,
110
+ message: loggingEvent.messages.slice(1),
111
+ methodName: loggingEvent.messages[0],
112
+ timeStamp: loggingEvent.timeStamp,
113
+ };
114
+ this.logMessages.push(message);
115
+ // write values to localStorage
116
+ localStorage.setItem(this.localStorageKey, JSON.stringify(this.logMessages));
117
+ }
118
+ /**
119
+ * Gets the appender's name.
120
+ * Mainly for unit testing purposes.
121
+ *
122
+ * @return appender's name
123
+ */
124
+ toString() {
125
+ return "Ionic.Logging.LocalStorageAppender";
126
+ }
127
+ /**
128
+ * Get the key which is used to store the messages in the local storage.
129
+ */
130
+ getLocalStorageKey() {
131
+ return this.localStorageKey;
132
+ }
133
+ /**
134
+ * Get the maximum number of messages which will be stored in local storage.
135
+ */
136
+ getMaxMessages() {
137
+ return this.maxMessages;
138
+ }
139
+ /**
140
+ * Set the maximum number of messages which will be stored in local storage.
141
+ *
142
+ * If the appender stores currently more messages than the new value allows, the oldest messages get removed.
143
+ *
144
+ * @param value new maximum number
145
+ */
146
+ setMaxMessages(value) {
147
+ if (this.maxMessages !== value) {
148
+ this.maxMessages = value;
149
+ if (this.logMessages.length > this.maxMessages) {
150
+ // there are too much logMessages for the new value, therefore remove oldest messages
151
+ while (this.logMessages.length > this.maxMessages) {
152
+ this.logMessages.shift();
153
+ }
154
+ // write values to localStorage
155
+ localStorage.setItem(this.localStorageKey, JSON.stringify(this.logMessages));
156
+ }
157
+ }
158
+ }
159
+ /**
160
+ * Gets all messages stored in local storage.
161
+ * Mainly for unit testing purposes.
162
+ *
163
+ * @return stored messages
164
+ */
165
+ getLogMessages() {
166
+ return this.logMessages;
167
+ }
168
+ /**
169
+ * Removes all messages from local storage.
170
+ * Mainly for unit testing purposes.
171
+ */
172
+ clearLog() {
173
+ this.logMessages = [];
174
+ localStorage.removeItem(this.localStorageKey);
175
+ }
176
+ }
177
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"local-storage-appender.model.js","sourceRoot":"","sources":["../../../../projects/ionic-logging-service/src/lib/local-storage-appender.model.ts"],"names":[],"mappings":"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","sourcesContent":["import * as log4javascript from \"log4javascript\";\n\nimport { LocalStorageAppenderConfiguration } from \"./local-storage-appender.configuration\";\nimport { LogLevelConverter } from \"./log-level.converter\";\nimport { LogLevel } from \"./log-level.model\";\nimport { LogMessage } from \"./log-message.model\";\n\n/**\n * An appender which stores the log messages in the browser's local storage.\n *\n * The messages are saved JSON-serialized.\n * You have to configure which key is used for storing the messages.\n *\n * A typical configuration could be:\n *\n * ```json\n * {\n *   \"localStorageKey\": \"myLogs\",\n *   \"maxMessages\": 500,\n *   \"threshold\": \"INFO\"\n * }\n * ```\n */\nexport class LocalStorageAppender extends log4javascript.Appender {\n\n\tprivate static maxMessagesDefault = 250;\n\tprivate static thresholdDefault = \"WARN\";\n\n\tprivate maxMessages: number;\n\n\tprivate localStorageKey: string;\n\tprivate logMessages: LogMessage[];\n\n\t/**\n\t * Creates a new instance of the appender.\n\t *\n\t * @param configuration configuration for the appender.\n\t */\n\tconstructor(configuration: LocalStorageAppenderConfiguration) {\n\t\tsuper();\n\n\t\tif (!configuration) {\n\t\t\tthrow new Error(\"configuration must be not empty\");\n\t\t}\n\t\tif (!configuration.localStorageKey || configuration.localStorageKey === \"\") {\n\t\t\tthrow new Error(\"localStorageKey must be not empty\");\n\t\t}\n\t\tthis.localStorageKey = configuration.localStorageKey;\n\n\t\t// read existing logMessages\n\t\tthis.logMessages = LocalStorageAppender.loadLogMessages(this.localStorageKey);\n\n\t\t// process remaining configuration\n\t\tthis.configure({\n\t\t\tlocalStorageKey: configuration.localStorageKey,\n\t\t\tmaxMessages: configuration.maxMessages || LocalStorageAppender.maxMessagesDefault,\n\t\t\tthreshold: configuration.threshold || LocalStorageAppender.thresholdDefault,\n\t\t});\n\t}\n\n\t/**\n\t * Load log messages from local storage which are stored there under the given key.\n\t *\n\t * @param localStorageKey local storage key\n\t * @return stored messages\n\t */\n\tpublic static loadLogMessages(localStorageKey: string): LogMessage[] {\n\t\tlet logMessages: LogMessage[];\n\n\t\tif (!localStorageKey || localStorage.getItem(localStorageKey) === null) {\n\t\t\tlogMessages = [];\n\t\t} else {\n\t\t\tlogMessages = JSON.parse(localStorage.getItem(localStorageKey));\n\t\t\tfor (const logMessage of logMessages) {\n\t\t\t\t// timestamps are serialized as strings\n\t\t\t\tlogMessage.timeStamp = new Date(logMessage.timeStamp);\n\t\t\t}\n\t\t}\n\n\t\treturn logMessages;\n\t}\n\n\t/**\n\t * Remove log messages from local storage which are stored there under the given key.\n\t *\n\t * @param localStorageKey local storage key\n\t */\n\tpublic static removeLogMessages(localStorageKey: string): void {\n\t\tlocalStorage.removeItem(localStorageKey);\n\t}\n\n\t/**\n\t * Configures the logging depending on the given configuration.\n\t *\n\t * Only the defined properties get overwritten.\n\t * The localStorageKey cannot be modified.\n\t *\n\t * @param configuration configuration data.\n\t */\n\tpublic configure(configuration: LocalStorageAppenderConfiguration): void {\n\t\tif (configuration) {\n\t\t\tif (configuration.localStorageKey && configuration.localStorageKey !== this.localStorageKey) {\n\t\t\t\tthrow new Error(\"localStorageKey must not be changed\");\n\t\t\t}\n\t\t\tif (configuration.maxMessages) {\n\t\t\t\tthis.setMaxMessages(configuration.maxMessages);\n\t\t\t}\n\t\t\tif (configuration.threshold) {\n\t\t\t\tconst convertedThreshold = LogLevelConverter.levelToLog4Javascript(\n\t\t\t\t\tLogLevelConverter.levelFromString(configuration.threshold));\n\t\t\t\tthis.setThreshold(convertedThreshold);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Appender-specific method to append a log message.\n\t *\n\t * @param loggingEvent event to be appended.\n\t */\n\tpublic append(loggingEvent: log4javascript.LoggingEvent): void {\n\t\t// if logMessages is already full, remove oldest element\n\t\twhile (this.logMessages.length >= this.maxMessages) {\n\t\t\tthis.logMessages.shift();\n\t\t}\n\t\t// add event to logMessages\n\t\tconst message: LogMessage = {\n\t\t\tlevel: LogLevel[LogLevelConverter.levelFromLog4Javascript(loggingEvent.level)],\n\t\t\tlogger: typeof loggingEvent.logger !== \"undefined\" ? loggingEvent.logger.name : undefined,\n\t\t\tmessage: loggingEvent.messages.slice(1),\n\t\t\tmethodName: loggingEvent.messages[0],\n\t\t\ttimeStamp: loggingEvent.timeStamp,\n\t\t};\n\t\tthis.logMessages.push(message);\n\n\t\t// write values to localStorage\n\t\tlocalStorage.setItem(this.localStorageKey, JSON.stringify(this.logMessages));\n\t}\n\n\t/**\n\t * Gets the appender's name.\n\t * Mainly for unit testing purposes.\n\t *\n\t * @return appender's name\n\t */\n\tpublic toString(): string {\n\t\treturn \"Ionic.Logging.LocalStorageAppender\";\n\t}\n\n\t/**\n\t * Get the key which is used to store the messages in the local storage.\n\t */\n\tpublic getLocalStorageKey(): string {\n\t\treturn this.localStorageKey;\n\t}\n\n\t/**\n\t * Get the maximum number of messages which will be stored in local storage.\n\t */\n\tpublic getMaxMessages(): number {\n\t\treturn this.maxMessages;\n\t}\n\n\t/**\n\t * Set the maximum number of messages which will be stored in local storage.\n\t *\n\t * If the appender stores currently more messages than the new value allows, the oldest messages get removed.\n\t *\n\t * @param value new maximum number\n\t */\n\tpublic setMaxMessages(value: number): void {\n\t\tif (this.maxMessages !== value) {\n\t\t\tthis.maxMessages = value;\n\n\t\t\tif (this.logMessages.length > this.maxMessages) {\n\t\t\t\t// there are too much logMessages for the new value, therefore remove oldest messages\n\t\t\t\twhile (this.logMessages.length > this.maxMessages) {\n\t\t\t\t\tthis.logMessages.shift();\n\t\t\t\t}\n\n\t\t\t\t// write values to localStorage\n\t\t\t\tlocalStorage.setItem(this.localStorageKey, JSON.stringify(this.logMessages));\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Gets all messages stored in local storage.\n\t * Mainly for unit testing purposes.\n\t *\n\t * @return stored messages\n\t */\n\tpublic getLogMessages(): LogMessage[] {\n\t\treturn this.logMessages;\n\t}\n\n\t/**\n\t * Removes all messages from local storage.\n\t * Mainly for unit testing purposes.\n\t */\n\tpublic clearLog(): void {\n\t\tthis.logMessages = [];\n\t\tlocalStorage.removeItem(this.localStorageKey);\n\t}\n}\n"]}
@@ -1,11 +1,11 @@
1
1
  import { NgModule } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
3
  export class LoggingServiceModule {
4
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: LoggingServiceModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
5
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.3", ngImport: i0, type: LoggingServiceModule }); }
6
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: LoggingServiceModule }); }
4
7
  }
5
- LoggingServiceModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: LoggingServiceModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
6
- LoggingServiceModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.0.4", ngImport: i0, type: LoggingServiceModule });
7
- LoggingServiceModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: LoggingServiceModule });
8
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: LoggingServiceModule, decorators: [{
8
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: LoggingServiceModule, decorators: [{
9
9
  type: NgModule,
10
10
  args: [{
11
11
  imports: [],
@@ -13,4 +13,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImpor
13
13
  exports: []
14
14
  }]
15
15
  }] });
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy1zZXJ2aWNlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2lvbmljLWxvZ2dpbmctc2VydmljZS9zcmMvbGliL2xvZ2dpbmctc2VydmljZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFVekMsTUFBTSxPQUFPLG9CQUFvQjs7aUhBQXBCLG9CQUFvQjtrSEFBcEIsb0JBQW9CO2tIQUFwQixvQkFBb0I7MkZBQXBCLG9CQUFvQjtrQkFSaEMsUUFBUTttQkFBQztvQkFDVCxPQUFPLEVBQUUsRUFDUjtvQkFDRCxZQUFZLEVBQUUsRUFDYjtvQkFDRCxPQUFPLEVBQUUsRUFDUjtpQkFDRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuQE5nTW9kdWxlKHtcblx0aW1wb3J0czogW1xuXHRdLFxuXHRkZWNsYXJhdGlvbnM6IFtcblx0XSxcblx0ZXhwb3J0czogW1xuXHRdXG59KVxuZXhwb3J0IGNsYXNzIExvZ2dpbmdTZXJ2aWNlTW9kdWxlIHsgfVxuIl19
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy1zZXJ2aWNlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2lvbmljLWxvZ2dpbmctc2VydmljZS9zcmMvbGliL2xvZ2dpbmctc2VydmljZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFVekMsTUFBTSxPQUFPLG9CQUFvQjs4R0FBcEIsb0JBQW9COytHQUFwQixvQkFBb0I7K0dBQXBCLG9CQUFvQjs7MkZBQXBCLG9CQUFvQjtrQkFSaEMsUUFBUTttQkFBQztvQkFDVCxPQUFPLEVBQUUsRUFDUjtvQkFDRCxZQUFZLEVBQUUsRUFDYjtvQkFDRCxPQUFPLEVBQUUsRUFDUjtpQkFDRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuQE5nTW9kdWxlKHtcblx0aW1wb3J0czogW1xuXHRdLFxuXHRkZWNsYXJhdGlvbnM6IFtcblx0XSxcblx0ZXhwb3J0czogW1xuXHRdXG59KVxuZXhwb3J0IGNsYXNzIExvZ2dpbmdTZXJ2aWNlTW9kdWxlIHsgfVxuIl19
@@ -155,13 +155,13 @@ export class LoggingService {
155
155
  LocalStorageAppender.removeLogMessages(localStorageKey);
156
156
  this.logMessagesChanged.emit();
157
157
  }
158
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: LoggingService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
159
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: LoggingService, providedIn: "root" }); }
158
160
  }
159
- LoggingService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: LoggingService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
160
- LoggingService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: LoggingService, providedIn: "root" });
161
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: LoggingService, decorators: [{
161
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: LoggingService, decorators: [{
162
162
  type: Injectable,
163
163
  args: [{
164
164
  providedIn: "root"
165
165
  }]
166
166
  }], ctorParameters: function () { return []; } });
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logging.service.js","sourceRoot":"","sources":["../../../../projects/ionic-logging-service/src/lib/logging.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Injectable, Optional } from \"@angular/core\";\n\nimport * as log4javascript from \"log4javascript\";\n\nimport { AjaxAppender } from \"./ajax-appender.model\";\nimport { LocalStorageAppender } from \"./local-storage-appender.model\";\nimport { LogLevelConverter } from \"./log-level.converter\";\nimport { LogMessage } from \"./log-message.model\";\nimport { Logger } from \"./logger.model\";\nimport { LoggingServiceConfiguration } from \"./logging-service.configuration\";\nimport { MemoryAppender } from \"./memory-appender.model\";\n\n/**\n * Service for logging functionality.\n *\n * By default, the following settings are used:\n *  - logger: root with level WARN\n *  - appender: BrowserConsoleAppender with threshold DEBUG and MemoryAppender with threshold ALL\n *\n * Via [configure](#configure), it is possible to amend these settings.\n */\n@Injectable({\n\tprovidedIn: \"root\"\n})\nexport class LoggingService {\n\n\t/**\n\t * Event triggered when the log messages got (potentially) change.\n\t * This can happen when:\n\t * - new message was added\n\t * - all message where removed from memory\n\t * - all massages where removed for one spcific LocalStorageAppender\n\t */\n\tpublic logMessagesChanged: EventEmitter<void>;\n\n\t/**\n\t * Event triggered when ajax appender could not send log messages to the server.\n\t *\n\t * @param message error message\n\t */\n\tpublic ajaxAppenderFailed: EventEmitter<string>;\n\n\tprivate memoryAppender: MemoryAppender;\n\tprivate browserConsoleAppender: log4javascript.BrowserConsoleAppender;\n\n\t/**\n\t * Creates a new instance of the service.\n\t */\n\tconstructor() {\n\n\t\t// prevent log4javascript to show alerts on case of errors\n\t\tlog4javascript.logLog.setQuietMode(true);\n\n\t\t// create event emitter\n\t\tthis.logMessagesChanged = new EventEmitter<void>();\n\t\tthis.ajaxAppenderFailed = new EventEmitter<string>();\n\n\t\t// configure appender\n\t\tconst logger = log4javascript.getRootLogger();\n\t\tlogger.setLevel(log4javascript.Level.WARN);\n\n\t\t// browser console appender for debugger\n\t\tthis.browserConsoleAppender = new log4javascript.BrowserConsoleAppender();\n\t\tthis.browserConsoleAppender.setLayout(new log4javascript.PatternLayout(\"%d{HH:mm:ss,SSS} %c %m\"));\n\t\tthis.browserConsoleAppender.setThreshold(log4javascript.Level.ALL);\n\t\tlogger.addAppender(this.browserConsoleAppender);\n\n\t\t// in-memory appender for display on log messages page\n\t\tthis.memoryAppender = new MemoryAppender();\n\t\tthis.memoryAppender.setLayout(new log4javascript.PatternLayout(\"%d{HH:mm:ss,SSS} %c %m\"));\n\t\tthis.memoryAppender.setOnLogMessagesChangedCallback((message) => {\n\t\t\tthis.logMessagesChanged.emit();\n\t\t});\n\t\tlogger.addAppender(this.memoryAppender);\n\n\t\tthis.configure();\n\t}\n\n\t/**\n\t * Configures the logging depending on the given configuration.\n\t *\n\t * @param configuration configuration data.\n\t */\n\tpublic configure(configuration?: LoggingServiceConfiguration): void {\n\n\t\tif (typeof configuration === \"undefined\") {\n\t\t\tconfiguration = {};\n\t\t}\n\n\t\t// set log levels\n\t\tif (typeof configuration.logLevels !== \"undefined\") {\n\t\t\tfor (const level of configuration.logLevels) {\n\t\t\t\tlet logger: log4javascript.Logger;\n\t\t\t\tif (level.loggerName === \"root\") {\n\t\t\t\t\tlogger = log4javascript.getRootLogger();\n\t\t\t\t} else {\n\t\t\t\t\tlogger = log4javascript.getLogger(level.loggerName);\n\t\t\t\t}\n\t\t\t\ttry {\n\t\t\t\t\tlogger.setLevel(LogLevelConverter.levelToLog4Javascript(LogLevelConverter.levelFromString(level.logLevel)));\n\t\t\t\t} catch (e) {\n\t\t\t\t\tthrow new Error(`invalid log level ${level.logLevel}`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// configure AjaxAppender\n\t\tif (typeof configuration.ajaxAppender !== \"undefined\") {\n\t\t\tconst ajaxAppender = new AjaxAppender(configuration.ajaxAppender);\n\t\t\tajaxAppender.appenderFailed.subscribe((message: string) => {\n\t\t\t\tthis.ajaxAppenderFailed.emit(message);\n\t\t\t});\n\t\t\tlog4javascript.getRootLogger().addAppender(ajaxAppender);\n\t\t}\n\n\t\t// configure LocalStorageAppender\n\t\tif (typeof configuration.localStorageAppender !== \"undefined\") {\n\t\t\tconst localStorageAppender = new LocalStorageAppender(configuration.localStorageAppender);\n\t\t\tlog4javascript.getRootLogger().addAppender(localStorageAppender);\n\n\t\t\t// ensure that an eventual memoryAppender is behind the localStorageAppender\n\t\t\tconst appenders = new Logger().getInternalLogger().getEffectiveAppenders();\n\t\t\tconst memoryAppender = appenders.find((a) => a.toString() === \"Ionic.Logging.MemoryAppender\") as MemoryAppender;\n\t\t\tif (memoryAppender) {\n\t\t\t\tlog4javascript.getRootLogger().removeAppender(memoryAppender);\n\t\t\t\tlog4javascript.getRootLogger().addAppender(memoryAppender);\n\t\t\t}\n\t\t}\n\n\t\t// configure MemoryAppender\n\t\tif (configuration.memoryAppender) {\n\t\t\tthis.memoryAppender.configure(configuration.memoryAppender);\n\t\t}\n\n\t\t// configure BrowserConsoleAppender\n\t\tif (configuration.browserConsoleAppender) {\n\t\t\tif (configuration.browserConsoleAppender.threshold) {\n\t\t\t\tconst convertedThreshold = LogLevelConverter.levelToLog4Javascript(\n\t\t\t\t\tLogLevelConverter.levelFromString(configuration.browserConsoleAppender.threshold));\n\t\t\t\tthis.browserConsoleAppender.setThreshold(convertedThreshold);\n\t\t\t}\n\t\t}\n\n\t}\n\n\t/**\n\t * Gets the root logger from which all other loggers derive.\n\t *\n\t * @return root logger\n\t */\n\tpublic getRootLogger(): Logger {\n\t\treturn new Logger();\n\t}\n\n\t/**\n\t * Gets a logger with the specified name, creating it if a logger with that name does not already exist.\n\t *\n\t * @param loggerName name of the logger\n\t * @return logger\n\t */\n\tpublic getLogger(loggerName: string): Logger {\n\t\treturn new Logger(loggerName);\n\t}\n\n\t/**\n\t * Gets the last log messages.\n\t *\n\t * The log messages are retrieved from the internal [MemoryAppender](../memoryappender.html).\n\t * That means you will get only the most current messages. The number of the messages is limited\n\t * by its maxMessages value.\n\t *\n\t * @return log messages\n\t */\n\tpublic getLogMessages(): LogMessage[] {\n\t\treturn this.memoryAppender.getLogMessages();\n\t}\n\n\t/**\n\t * Loads the log messages written by the LocalStorageAppender with the given key.\n\t *\n\t * @param localStorageKey key for the local storage\n\t * @returns log messages\n\t */\n\tpublic getLogMessagesFromLocalStorage(localStorageKey: string): LogMessage[] {\n\t\treturn LocalStorageAppender.loadLogMessages(localStorageKey);\n\t}\n\n\t/**\n\t * Remove all log messages.\n\t */\n\tpublic removeLogMessages(): void {\n\t\tthis.memoryAppender.removeLogMessages();\n\t\tthis.logMessagesChanged.emit();\n\t}\n\n\t/**\n\t * Removes the log messages written by the LocalStorageAppender with the given key.\n\t *\n\t * @param localStorageKey key for the local storage\n\t */\n\tpublic removeLogMessagesFromLocalStorage(localStorageKey: string): void {\n\t\tLocalStorageAppender.removeLogMessages(localStorageKey);\n\t\tthis.logMessagesChanged.emit();\n\t}\n}\n"]}
167
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logging.service.js","sourceRoot":"","sources":["../../../../projects/ionic-logging-service/src/lib/logging.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Injectable, Optional } from \"@angular/core\";\n\nimport * as log4javascript from \"log4javascript\";\n\nimport { AjaxAppender } from \"./ajax-appender.model\";\nimport { LocalStorageAppender } from \"./local-storage-appender.model\";\nimport { LogLevelConverter } from \"./log-level.converter\";\nimport { LogMessage } from \"./log-message.model\";\nimport { Logger } from \"./logger.model\";\nimport { LoggingServiceConfiguration } from \"./logging-service.configuration\";\nimport { MemoryAppender } from \"./memory-appender.model\";\n\n/**\n * Service for logging functionality.\n *\n * By default, the following settings are used:\n *  - logger: root with level WARN\n *  - appender: BrowserConsoleAppender with threshold DEBUG and MemoryAppender with threshold ALL\n *\n * Via [configure](#configure), it is possible to amend these settings.\n */\n@Injectable({\n\tprovidedIn: \"root\"\n})\nexport class LoggingService {\n\n\t/**\n\t * Event triggered when the log messages got (potentially) change.\n\t * This can happen when:\n\t * - new message was added\n\t * - all message where removed from memory\n\t * - all massages where removed for one spcific LocalStorageAppender\n\t */\n\tpublic logMessagesChanged: EventEmitter<void>;\n\n\t/**\n\t * Event triggered when ajax appender could not send log messages to the server.\n\t *\n\t * @param message error message\n\t */\n\tpublic ajaxAppenderFailed: EventEmitter<string>;\n\n\tprivate memoryAppender: MemoryAppender;\n\tprivate browserConsoleAppender: log4javascript.BrowserConsoleAppender;\n\n\t/**\n\t * Creates a new instance of the service.\n\t */\n\tconstructor() {\n\n\t\t// prevent log4javascript to show alerts on case of errors\n\t\tlog4javascript.logLog.setQuietMode(true);\n\n\t\t// create event emitter\n\t\tthis.logMessagesChanged = new EventEmitter<void>();\n\t\tthis.ajaxAppenderFailed = new EventEmitter<string>();\n\n\t\t// configure appender\n\t\tconst logger = log4javascript.getRootLogger();\n\t\tlogger.setLevel(log4javascript.Level.WARN);\n\n\t\t// browser console appender for debugger\n\t\tthis.browserConsoleAppender = new log4javascript.BrowserConsoleAppender();\n\t\tthis.browserConsoleAppender.setLayout(new log4javascript.PatternLayout(\"%d{HH:mm:ss,SSS} %c %m\"));\n\t\tthis.browserConsoleAppender.setThreshold(log4javascript.Level.ALL);\n\t\tlogger.addAppender(this.browserConsoleAppender);\n\n\t\t// in-memory appender for display on log messages page\n\t\tthis.memoryAppender = new MemoryAppender();\n\t\tthis.memoryAppender.setLayout(new log4javascript.PatternLayout(\"%d{HH:mm:ss,SSS} %c %m\"));\n\t\tthis.memoryAppender.setOnLogMessagesChangedCallback((message) => {\n\t\t\tthis.logMessagesChanged.emit();\n\t\t});\n\t\tlogger.addAppender(this.memoryAppender);\n\n\t\tthis.configure();\n\t}\n\n\t/**\n\t * Configures the logging depending on the given configuration.\n\t *\n\t * @param configuration configuration data.\n\t */\n\tpublic configure(configuration?: LoggingServiceConfiguration): void {\n\n\t\tif (typeof configuration === \"undefined\") {\n\t\t\tconfiguration = {};\n\t\t}\n\n\t\t// set log levels\n\t\tif (typeof configuration.logLevels !== \"undefined\") {\n\t\t\tfor (const level of configuration.logLevels) {\n\t\t\t\tlet logger: log4javascript.Logger;\n\t\t\t\tif (level.loggerName === \"root\") {\n\t\t\t\t\tlogger = log4javascript.getRootLogger();\n\t\t\t\t} else {\n\t\t\t\t\tlogger = log4javascript.getLogger(level.loggerName);\n\t\t\t\t}\n\t\t\t\ttry {\n\t\t\t\t\tlogger.setLevel(LogLevelConverter.levelToLog4Javascript(LogLevelConverter.levelFromString(level.logLevel)));\n\t\t\t\t} catch (e) {\n\t\t\t\t\tthrow new Error(`invalid log level ${level.logLevel}`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// configure AjaxAppender\n\t\tif (typeof configuration.ajaxAppender !== \"undefined\") {\n\t\t\tconst ajaxAppender = new AjaxAppender(configuration.ajaxAppender);\n\t\t\tajaxAppender.appenderFailed.subscribe((message: string) => {\n\t\t\t\tthis.ajaxAppenderFailed.emit(message);\n\t\t\t});\n\t\t\tlog4javascript.getRootLogger().addAppender(ajaxAppender);\n\t\t}\n\n\t\t// configure LocalStorageAppender\n\t\tif (typeof configuration.localStorageAppender !== \"undefined\") {\n\t\t\tconst localStorageAppender = new LocalStorageAppender(configuration.localStorageAppender);\n\t\t\tlog4javascript.getRootLogger().addAppender(localStorageAppender);\n\n\t\t\t// ensure that an eventual memoryAppender is behind the localStorageAppender\n\t\t\tconst appenders = new Logger().getInternalLogger().getEffectiveAppenders();\n\t\t\tconst memoryAppender = appenders.find((a) => a.toString() === \"Ionic.Logging.MemoryAppender\") as MemoryAppender;\n\t\t\tif (memoryAppender) {\n\t\t\t\tlog4javascript.getRootLogger().removeAppender(memoryAppender);\n\t\t\t\tlog4javascript.getRootLogger().addAppender(memoryAppender);\n\t\t\t}\n\t\t}\n\n\t\t// configure MemoryAppender\n\t\tif (configuration.memoryAppender) {\n\t\t\tthis.memoryAppender.configure(configuration.memoryAppender);\n\t\t}\n\n\t\t// configure BrowserConsoleAppender\n\t\tif (configuration.browserConsoleAppender) {\n\t\t\tif (configuration.browserConsoleAppender.threshold) {\n\t\t\t\tconst convertedThreshold = LogLevelConverter.levelToLog4Javascript(\n\t\t\t\t\tLogLevelConverter.levelFromString(configuration.browserConsoleAppender.threshold));\n\t\t\t\tthis.browserConsoleAppender.setThreshold(convertedThreshold);\n\t\t\t}\n\t\t}\n\n\t}\n\n\t/**\n\t * Gets the root logger from which all other loggers derive.\n\t *\n\t * @return root logger\n\t */\n\tpublic getRootLogger(): Logger {\n\t\treturn new Logger();\n\t}\n\n\t/**\n\t * Gets a logger with the specified name, creating it if a logger with that name does not already exist.\n\t *\n\t * @param loggerName name of the logger\n\t * @return logger\n\t */\n\tpublic getLogger(loggerName: string): Logger {\n\t\treturn new Logger(loggerName);\n\t}\n\n\t/**\n\t * Gets the last log messages.\n\t *\n\t * The log messages are retrieved from the internal [MemoryAppender](../memoryappender.html).\n\t * That means you will get only the most current messages. The number of the messages is limited\n\t * by its maxMessages value.\n\t *\n\t * @return log messages\n\t */\n\tpublic getLogMessages(): LogMessage[] {\n\t\treturn this.memoryAppender.getLogMessages();\n\t}\n\n\t/**\n\t * Loads the log messages written by the LocalStorageAppender with the given key.\n\t *\n\t * @param localStorageKey key for the local storage\n\t * @returns log messages\n\t */\n\tpublic getLogMessagesFromLocalStorage(localStorageKey: string): LogMessage[] {\n\t\treturn LocalStorageAppender.loadLogMessages(localStorageKey);\n\t}\n\n\t/**\n\t * Remove all log messages.\n\t */\n\tpublic removeLogMessages(): void {\n\t\tthis.memoryAppender.removeLogMessages();\n\t\tthis.logMessagesChanged.emit();\n\t}\n\n\t/**\n\t * Removes the log messages written by the LocalStorageAppender with the given key.\n\t *\n\t * @param localStorageKey key for the local storage\n\t */\n\tpublic removeLogMessagesFromLocalStorage(localStorageKey: string): void {\n\t\tLocalStorageAppender.removeLogMessages(localStorageKey);\n\t\tthis.logMessagesChanged.emit();\n\t}\n}\n"]}
@@ -0,0 +1,133 @@
1
+ import * as log4javascript from "log4javascript";
2
+ import { LogLevelConverter } from "./log-level.converter";
3
+ import { LogLevel } from "./log-level.model";
4
+ /**
5
+ * An appender which stores the log messages in the browser's memory.
6
+ *
7
+ * The MemoryAppender is enabled by default.
8
+ * If you do not specify anything else, it is using this configuration:
9
+ *
10
+ * ```JSON
11
+ * {
12
+ * "memoryAppender": [
13
+ * {
14
+ * "maxMessages": 250,
15
+ * "threshold": "ALL"
16
+ * }
17
+ * }
18
+ * ```
19
+ */
20
+ export class MemoryAppender extends log4javascript.Appender {
21
+ static { this.maxMessagesDefault = 250; }
22
+ static { this.thresholdDefault = "ALL"; }
23
+ /**
24
+ * Creates a new instance of the appender.
25
+ *
26
+ * @param configuration configuration for the appender.
27
+ */
28
+ constructor(configuration) {
29
+ super();
30
+ this.logMessages = [];
31
+ // process configuration
32
+ configuration = configuration || {};
33
+ this.configure({
34
+ maxMessages: configuration.maxMessages || MemoryAppender.maxMessagesDefault,
35
+ threshold: configuration.threshold || MemoryAppender.thresholdDefault,
36
+ });
37
+ this.maxMessages = MemoryAppender.maxMessagesDefault;
38
+ }
39
+ /**
40
+ * Configures the logging depending on the given configuration.
41
+ * Only the defined properties get overwritten.
42
+ *
43
+ * @param configuration configuration data.
44
+ */
45
+ configure(configuration) {
46
+ if (configuration) {
47
+ if (configuration.maxMessages) {
48
+ this.setMaxMessages(configuration.maxMessages);
49
+ }
50
+ if (configuration.threshold) {
51
+ const convertedThreshold = LogLevelConverter.levelToLog4Javascript(LogLevelConverter.levelFromString(configuration.threshold));
52
+ this.setThreshold(convertedThreshold);
53
+ }
54
+ }
55
+ }
56
+ /**
57
+ * Appender-specific method to append a log message.
58
+ *
59
+ * @param loggingEvent event to be appended.
60
+ */
61
+ append(loggingEvent) {
62
+ // if logMessages is already full, remove oldest element
63
+ while (this.logMessages.length >= this.maxMessages) {
64
+ this.logMessages.shift();
65
+ }
66
+ // add event to logMessages
67
+ const message = {
68
+ level: LogLevel[LogLevelConverter.levelFromLog4Javascript(loggingEvent.level)],
69
+ logger: typeof loggingEvent.logger === "object" ? loggingEvent.logger.name : undefined,
70
+ message: loggingEvent.messages.slice(1),
71
+ methodName: loggingEvent.messages[0],
72
+ timeStamp: loggingEvent.timeStamp,
73
+ };
74
+ this.logMessages.push(message);
75
+ // inform about new message
76
+ if (typeof this.onLogMessagesChangedCallback === "function") {
77
+ this.onLogMessagesChangedCallback(message);
78
+ }
79
+ }
80
+ /**
81
+ * Gets the appender's name.
82
+ * Mainly for unit testing purposes.
83
+ *
84
+ * @return appender's name
85
+ */
86
+ toString() {
87
+ return "Ionic.Logging.MemoryAppender";
88
+ }
89
+ /**
90
+ * Get the maximum number of messages which will be stored in memory.
91
+ */
92
+ getMaxMessages() {
93
+ return this.maxMessages;
94
+ }
95
+ /**
96
+ * Set the maximum number of messages which will be stored in memory.
97
+ *
98
+ * If the appender stores currently more messages than the new value allows, the oldest messages get removed.
99
+ *
100
+ * @param value new maximum number
101
+ */
102
+ setMaxMessages(value) {
103
+ this.maxMessages = value;
104
+ // if there are too much logMessages for the new value, remove oldest messages
105
+ if (this.logMessages.length > this.maxMessages) {
106
+ this.logMessages.splice(0, this.logMessages.length - this.maxMessages);
107
+ }
108
+ }
109
+ /**
110
+ * Gets all messages stored in memory.
111
+ *
112
+ * @return stored messages
113
+ */
114
+ getLogMessages() {
115
+ return this.logMessages;
116
+ }
117
+ /**
118
+ * Remove all messages stored in memory.
119
+ */
120
+ removeLogMessages() {
121
+ this.logMessages.splice(0);
122
+ }
123
+ /**
124
+ * Registers a callback which will be called every time a new message is appended.
125
+ * This could be useful if you want to show new messages in realtime.
126
+ *
127
+ * @param callback callback to be called
128
+ */
129
+ setOnLogMessagesChangedCallback(callback) {
130
+ this.onLogMessagesChangedCallback = callback;
131
+ }
132
+ }
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"memory-appender.model.js","sourceRoot":"","sources":["../../../../projects/ionic-logging-service/src/lib/memory-appender.model.ts"],"names":[],"mappings":"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","sourcesContent":["import * as log4javascript from \"log4javascript\";\n\nimport { LogLevelConverter } from \"./log-level.converter\";\nimport { LogLevel } from \"./log-level.model\";\nimport { LogMessage } from \"./log-message.model\";\nimport { MemoryAppenderConfiguration } from \"./memory-appender.configuration\";\n\n/**\n * An appender which stores the log messages in the browser's memory.\n *\n * The MemoryAppender is enabled by default.\n * If you do not specify anything else, it is using this configuration:\n *\n * ```JSON\n * {\n *   \"memoryAppender\": [\n *     {\n *       \"maxMessages\": 250,\n *       \"threshold\": \"ALL\"\n *     }\n * }\n * ```\n */\nexport class MemoryAppender extends log4javascript.Appender {\n\n\tprivate static maxMessagesDefault = 250;\n\tprivate static thresholdDefault = \"ALL\";\n\n\tprivate maxMessages: number;\n\n\tprivate logMessages: LogMessage[];\n\tprivate onLogMessagesChangedCallback: (message: LogMessage) => void;\n\n\t/**\n\t * Creates a new instance of the appender.\n\t *\n\t * @param configuration configuration for the appender.\n\t */\n\tconstructor(configuration?: MemoryAppenderConfiguration) {\n\t\tsuper();\n\n\t\tthis.logMessages = [];\n\n\t\t// process configuration\n\t\tconfiguration = configuration || {};\n\t\tthis.configure({\n\t\t\tmaxMessages: configuration.maxMessages || MemoryAppender.maxMessagesDefault,\n\t\t\tthreshold: configuration.threshold || MemoryAppender.thresholdDefault,\n\t\t});\n\n\t\tthis.maxMessages = MemoryAppender.maxMessagesDefault;\n\t}\n\n\t/**\n\t * Configures the logging depending on the given configuration.\n\t * Only the defined properties get overwritten.\n\t *\n\t * @param configuration configuration data.\n\t */\n\tpublic configure(configuration: MemoryAppenderConfiguration): void {\n\t\tif (configuration) {\n\t\t\tif (configuration.maxMessages) {\n\t\t\t\tthis.setMaxMessages(configuration.maxMessages);\n\t\t\t}\n\t\t\tif (configuration.threshold) {\n\t\t\t\tconst convertedThreshold = LogLevelConverter.levelToLog4Javascript(\n\t\t\t\t\tLogLevelConverter.levelFromString(configuration.threshold));\n\t\t\t\tthis.setThreshold(convertedThreshold);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Appender-specific method to append a log message.\n\t *\n\t * @param loggingEvent event to be appended.\n\t */\n\tpublic append(loggingEvent: log4javascript.LoggingEvent): void {\n\t\t// if logMessages is already full, remove oldest element\n\t\twhile (this.logMessages.length >= this.maxMessages) {\n\t\t\tthis.logMessages.shift();\n\t\t}\n\t\t// add event to logMessages\n\t\tconst message: LogMessage = {\n\t\t\tlevel: LogLevel[LogLevelConverter.levelFromLog4Javascript(loggingEvent.level)],\n\t\t\tlogger: typeof loggingEvent.logger === \"object\" ? loggingEvent.logger.name : undefined,\n\t\t\tmessage: loggingEvent.messages.slice(1),\n\t\t\tmethodName: loggingEvent.messages[0],\n\t\t\ttimeStamp: loggingEvent.timeStamp,\n\t\t};\n\t\tthis.logMessages.push(message);\n\n\t\t// inform about new message\n\t\tif (typeof this.onLogMessagesChangedCallback === \"function\") {\n\t\t\tthis.onLogMessagesChangedCallback(message);\n\t\t}\n\t}\n\n\t/**\n\t * Gets the appender's name.\n\t * Mainly for unit testing purposes.\n\t *\n\t * @return appender's name\n\t */\n\tpublic toString(): string {\n\t\treturn \"Ionic.Logging.MemoryAppender\";\n\t}\n\n\t/**\n\t * Get the maximum number of messages which will be stored in memory.\n\t */\n\tpublic getMaxMessages(): number {\n\t\treturn this.maxMessages;\n\t}\n\n\t/**\n\t * Set the maximum number of messages which will be stored in memory.\n\t *\n\t * If the appender stores currently more messages than the new value allows, the oldest messages get removed.\n\t *\n\t * @param value new maximum number\n\t */\n\tpublic setMaxMessages(value: number): void {\n\t\tthis.maxMessages = value;\n\n\t\t// if there are too much logMessages for the new value, remove oldest messages\n\t\tif (this.logMessages.length > this.maxMessages) {\n\t\t\tthis.logMessages.splice(0, this.logMessages.length - this.maxMessages);\n\t\t}\n\t}\n\n\t/**\n\t * Gets all messages stored in memory.\n\t *\n\t * @return stored messages\n\t */\n\tpublic getLogMessages(): LogMessage[] {\n\t\treturn this.logMessages;\n\t}\n\n\t/**\n\t * Remove all messages stored in memory.\n\t */\n\tpublic removeLogMessages(): void {\n\t\tthis.logMessages.splice(0);\n\t}\n\n\t/**\n\t * Registers a callback which will be called every time a new message is appended.\n\t * This could be useful if you want to show new messages in realtime.\n\t *\n\t * @param callback callback to be called\n\t */\n\tpublic setOnLogMessagesChangedCallback(callback: (message: LogMessage) => void): void {\n\t\tthis.onLogMessagesChangedCallback = callback;\n\t}\n}\n"]}