@nordicsemiconductor/pc-nrfconnect-shared 122.0.0 → 124.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.
- package/Changelog.md +58 -0
- package/coverage/cobertura-coverage.xml +1343 -978
- package/ipc/launcherConfig.ts +25 -0
- package/ipc/openWindow.ts +17 -1
- package/ipc/schema/packageJson.ts +26 -22
- package/main/index.ts +11 -5
- package/mocks/packageJsonMock.ts +1 -1
- package/nrfutil/device/batch.ts +1 -7
- package/nrfutil/device/common.ts +15 -8
- package/nrfutil/device/list.ts +1 -1
- package/nrfutil/moduleVersion.ts +2 -2
- package/nrfutil/sandbox.ts +52 -32
- package/nrfutil/sandboxTypes.ts +1 -1
- package/package.json +3 -2
- package/scripts/check-app-properties.ts +6 -6
- package/scripts/esbuild.ts +3 -3
- package/scripts/nordic-publish.js +23 -23
- package/scripts/nordic-publish.ts +3 -3
- package/scripts/release-shared.ts +2 -2
- package/src/About/ApplicationCard.tsx +3 -5
- package/src/App/App.test.tsx +7 -0
- package/src/App/App.tsx +14 -27
- package/src/Device/DeviceSelector/DeviceList/MoreDeviceInfo.tsx +1 -1
- package/src/Device/DeviceSelector/DeviceSelector.tsx +27 -9
- package/src/Device/deviceLister.ts +66 -23
- package/src/Device/deviceSetup.ts +4 -4
- package/src/Device/deviceSlice.ts +12 -3
- package/src/ErrorBoundary/ErrorBoundary.tsx +7 -13
- package/src/Feedback/sendFeedback.ts +2 -4
- package/src/Link/FileLink.tsx +4 -1
- package/src/index.ts +3 -0
- package/src/logging/sendInitialLogMessages.ts +2 -4
- package/src/utils/appDetails.ts +22 -0
- package/src/utils/appDirs.ts +4 -4
- package/src/utils/launcherConfig.ts +17 -0
- package/src/utils/packageJson.ts +52 -10
- package/src/utils/persistentStore.ts +21 -14
- package/src/utils/systemReport.ts +1 -3
- package/src/utils/usageData.ts +75 -167
- package/src/utils/usageDataCommon.ts +59 -0
- package/src/utils/usageDataMain.ts +117 -0
- package/src/utils/usageDataRenderer.ts +126 -0
- package/src/utils/useHotKey.ts +2 -2
- package/typings/generated/ipc/launcherConfig.d.ts +14 -0
- package/typings/generated/ipc/launcherConfig.d.ts.map +1 -0
- package/typings/generated/ipc/openWindow.d.ts +10 -4
- package/typings/generated/ipc/openWindow.d.ts.map +1 -1
- package/typings/generated/ipc/schema/packageJson.d.ts +34 -52
- package/typings/generated/ipc/schema/packageJson.d.ts.map +1 -1
- package/typings/generated/main/index.d.ts +8 -2
- package/typings/generated/main/index.d.ts.map +1 -1
- package/typings/generated/nrfutil/device/batch.d.ts.map +1 -1
- package/typings/generated/nrfutil/device/common.d.ts +1 -1
- package/typings/generated/nrfutil/device/common.d.ts.map +1 -1
- package/typings/generated/nrfutil/device/device.d.ts +2 -2
- package/typings/generated/nrfutil/device/list.d.ts +1 -1
- package/typings/generated/nrfutil/device/list.d.ts.map +1 -1
- package/typings/generated/nrfutil/sandbox.d.ts +2 -2
- package/typings/generated/nrfutil/sandbox.d.ts.map +1 -1
- package/typings/generated/nrfutil/sandboxTypes.d.ts +1 -1
- package/typings/generated/nrfutil/sandboxTypes.d.ts.map +1 -1
- package/typings/generated/src/About/ApplicationCard.d.ts.map +1 -1
- package/typings/generated/src/App/App.d.ts +0 -1
- package/typings/generated/src/App/App.d.ts.map +1 -1
- package/typings/generated/src/Device/DeviceSelector/DeviceSelector.d.ts.map +1 -1
- package/typings/generated/src/Device/deviceLister.d.ts.map +1 -1
- package/typings/generated/src/Device/deviceSetup.d.ts +2 -2
- package/typings/generated/src/Device/deviceSetup.d.ts.map +1 -1
- package/typings/generated/src/Device/deviceSlice.d.ts +5 -1
- package/typings/generated/src/Device/deviceSlice.d.ts.map +1 -1
- package/typings/generated/src/ErrorBoundary/ErrorBoundary.d.ts.map +1 -1
- package/typings/generated/src/Feedback/sendFeedback.d.ts.map +1 -1
- package/typings/generated/src/Link/FileLink.d.ts +2 -1
- package/typings/generated/src/Link/FileLink.d.ts.map +1 -1
- package/typings/generated/src/index.d.ts +2 -0
- package/typings/generated/src/index.d.ts.map +1 -1
- package/typings/generated/src/logging/sendInitialLogMessages.d.ts.map +1 -1
- package/typings/generated/src/utils/appDetails.d.ts +4 -0
- package/typings/generated/src/utils/appDetails.d.ts.map +1 -0
- package/typings/generated/src/utils/appDirs.d.ts +1 -1
- package/typings/generated/src/utils/appDirs.d.ts.map +1 -1
- package/typings/generated/src/utils/launcherConfig.d.ts +4 -0
- package/typings/generated/src/utils/launcherConfig.d.ts.map +1 -0
- package/typings/generated/src/utils/packageJson.d.ts +30 -7
- package/typings/generated/src/utils/packageJson.d.ts.map +1 -1
- package/typings/generated/src/utils/persistentStore.d.ts +3 -2
- package/typings/generated/src/utils/persistentStore.d.ts.map +1 -1
- package/typings/generated/src/utils/systemReport.d.ts.map +1 -1
- package/typings/generated/src/utils/usageData.d.ts +8 -65
- package/typings/generated/src/utils/usageData.d.ts.map +1 -1
- package/typings/generated/src/utils/usageDataCommon.d.ts +27 -0
- package/typings/generated/src/utils/usageDataCommon.d.ts.map +1 -0
- package/typings/generated/src/utils/usageDataMain.d.ts +10 -0
- package/typings/generated/src/utils/usageDataMain.d.ts.map +1 -0
- package/typings/generated/src/utils/usageDataRenderer.d.ts +10 -0
- package/typings/generated/src/utils/usageDataRenderer.d.ts.map +1 -0
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2023 Nordic Semiconductor ASA
|
|
3
|
+
*
|
|
4
|
+
* SPDX-License-Identifier: LicenseRef-Nordic-4-Clause
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import { type Configuration, inMain } from '../../ipc/launcherConfig';
|
|
8
|
+
|
|
9
|
+
let cachedConfig: Configuration;
|
|
10
|
+
|
|
11
|
+
export default () => {
|
|
12
|
+
if (cachedConfig == null) {
|
|
13
|
+
cachedConfig = inMain.getConfig();
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
return cachedConfig;
|
|
17
|
+
};
|
package/src/utils/packageJson.ts
CHANGED
|
@@ -6,26 +6,68 @@
|
|
|
6
6
|
|
|
7
7
|
import {
|
|
8
8
|
type PackageJson,
|
|
9
|
+
type PackageJsonApp,
|
|
9
10
|
parsePackageJson,
|
|
11
|
+
parsePackageJsonApp,
|
|
10
12
|
} from '../../ipc/schema/packageJson';
|
|
11
13
|
|
|
12
|
-
let cache:
|
|
14
|
+
let cache:
|
|
15
|
+
| undefined
|
|
16
|
+
| { type: 'launcher'; data: PackageJson }
|
|
17
|
+
| { type: 'app'; data: PackageJsonApp };
|
|
13
18
|
|
|
14
|
-
const
|
|
19
|
+
export const isLauncher = (packageJson = parsedPackageJson()) =>
|
|
20
|
+
packageJson.name === 'nrfconnect';
|
|
21
|
+
|
|
22
|
+
const parsedPackageJson = (): PackageJson | PackageJsonApp => {
|
|
15
23
|
if (cache != null) {
|
|
16
|
-
return cache;
|
|
24
|
+
return cache.data;
|
|
17
25
|
}
|
|
18
26
|
|
|
19
|
-
const
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
27
|
+
const unparsed = process.env.PACKAGE_JSON ?? 'null';
|
|
28
|
+
|
|
29
|
+
const parsed = parsePackageJson(unparsed);
|
|
30
|
+
|
|
31
|
+
if (!parsed.success) {
|
|
23
32
|
throw new Error(
|
|
24
|
-
`The env variable
|
|
33
|
+
`The env variable PACKAGE_JSON must be defined during bundling (through the bundler settings) with a valid package.json but wasn't. Error: ${parsed.error.message}`
|
|
25
34
|
);
|
|
26
35
|
}
|
|
27
36
|
|
|
28
|
-
|
|
37
|
+
if (isLauncher(parsed.data)) {
|
|
38
|
+
cache = {
|
|
39
|
+
type: 'launcher',
|
|
40
|
+
data: parsed.data,
|
|
41
|
+
};
|
|
42
|
+
} else {
|
|
43
|
+
const parsedAppPackageJson = parsePackageJsonApp(unparsed);
|
|
44
|
+
if (!parsedAppPackageJson.success) {
|
|
45
|
+
throw new Error(
|
|
46
|
+
`The package.json must contain all values required for an app. Error: ${parsedAppPackageJson.error.message}`
|
|
47
|
+
);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
cache = {
|
|
51
|
+
type: 'app',
|
|
52
|
+
data: parsedAppPackageJson.data,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return cache.data;
|
|
29
57
|
};
|
|
30
58
|
|
|
31
|
-
export
|
|
59
|
+
export const packageJson = parsedPackageJson;
|
|
60
|
+
|
|
61
|
+
export const packageJsonApp = () => {
|
|
62
|
+
parsedPackageJson();
|
|
63
|
+
|
|
64
|
+
if (cache?.type !== 'app') {
|
|
65
|
+
throw new Error(
|
|
66
|
+
`Required the package.json of an app. Actual content: ${JSON.stringify(
|
|
67
|
+
cache
|
|
68
|
+
)}`
|
|
69
|
+
);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
return cache.data;
|
|
73
|
+
};
|
|
@@ -10,8 +10,9 @@ import { SerialPortOpenOptions } from 'serialport';
|
|
|
10
10
|
import { v4 as uuid } from 'uuid';
|
|
11
11
|
|
|
12
12
|
import { inMain as safeStorage } from '../../ipc/safeStorage';
|
|
13
|
+
import { type Device } from '../Device/deviceSlice';
|
|
13
14
|
import logger from '../logging';
|
|
14
|
-
import packageJson from './packageJson';
|
|
15
|
+
import { packageJson } from './packageJson';
|
|
15
16
|
|
|
16
17
|
export interface SerialSettings {
|
|
17
18
|
serialPortOptions: Omit<SerialPortOpenOptions<AutoDetectTypes>, 'path'>;
|
|
@@ -89,24 +90,30 @@ export const getPersistedSerialPortSettings = (
|
|
|
89
90
|
return sharedStore.get(`${serialNumber}.${appName}`);
|
|
90
91
|
};
|
|
91
92
|
export const persistTerminalSettings = (
|
|
92
|
-
|
|
93
|
+
device: Device,
|
|
93
94
|
vComIndex: number,
|
|
94
95
|
terminalSettings: TerminalSettings
|
|
95
|
-
) =>
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
96
|
+
) => {
|
|
97
|
+
if (device.serialNumber) {
|
|
98
|
+
sharedStore.set(
|
|
99
|
+
`${device.serialNumber}.vCom-${vComIndex}.TerminalSettings`,
|
|
100
|
+
terminalSettings
|
|
101
|
+
);
|
|
102
|
+
}
|
|
103
|
+
};
|
|
100
104
|
export const getPersistedTerminalSettings = (
|
|
101
|
-
|
|
105
|
+
device: Device,
|
|
102
106
|
vComIndex: number
|
|
103
107
|
): TerminalSettings | undefined => {
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
108
|
+
if (device.serialNumber) {
|
|
109
|
+
logger.info(
|
|
110
|
+
`Get terminal settings from persistent store ${device.serialNumber}.vCom-${vComIndex}.TerminalSettings`
|
|
111
|
+
);
|
|
112
|
+
return sharedStore.get(
|
|
113
|
+
`${device.serialNumber}.vCom-${vComIndex}.TerminalSettings`
|
|
114
|
+
);
|
|
115
|
+
}
|
|
116
|
+
return undefined;
|
|
110
117
|
};
|
|
111
118
|
|
|
112
119
|
export const persistIsSendingUsageData = (value: boolean) =>
|
|
@@ -8,7 +8,7 @@ import fs from 'fs';
|
|
|
8
8
|
import { EOL } from 'os';
|
|
9
9
|
import path from 'path';
|
|
10
10
|
import pretty from 'prettysize';
|
|
11
|
-
import
|
|
11
|
+
import si from 'systeminformation';
|
|
12
12
|
|
|
13
13
|
import NrfutilDeviceLib from '../../nrfutil/device/device';
|
|
14
14
|
import {
|
|
@@ -25,8 +25,6 @@ import { getAppDataDir } from './appDirs';
|
|
|
25
25
|
import { openFile } from './open';
|
|
26
26
|
|
|
27
27
|
const generalInfoReport = async () => {
|
|
28
|
-
// eslint-disable-next-line global-require
|
|
29
|
-
const si = require('systeminformation') as typeof Systeminformation;
|
|
30
28
|
const [
|
|
31
29
|
{ manufacturer, model },
|
|
32
30
|
{ vendor, version },
|
package/src/utils/usageData.ts
CHANGED
|
@@ -4,206 +4,114 @@
|
|
|
4
4
|
* SPDX-License-Identifier: LicenseRef-Nordic-4-Clause
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
import
|
|
8
|
-
import type Systeminformation from 'systeminformation';
|
|
9
|
-
import winston from 'winston';
|
|
7
|
+
import si from 'systeminformation';
|
|
10
8
|
|
|
11
|
-
import {
|
|
9
|
+
import { packageJson } from './packageJson';
|
|
12
10
|
import {
|
|
13
11
|
deleteIsSendingUsageData,
|
|
14
|
-
getIsSendingUsageData,
|
|
15
|
-
getUsageDataClientId,
|
|
16
12
|
persistIsSendingUsageData,
|
|
17
13
|
} from './persistentStore';
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
if (!getIsSendingUsageData()) return;
|
|
42
|
-
|
|
43
|
-
const accountId = getUsageDataClientId();
|
|
44
|
-
|
|
45
|
-
insights = new ApplicationInsights({
|
|
46
|
-
config: {
|
|
47
|
-
instrumentationKey,
|
|
48
|
-
accountId,
|
|
49
|
-
},
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
insights.loadAppInsights();
|
|
53
|
-
insights.trackPageView({ name: applicationName });
|
|
54
|
-
|
|
55
|
-
// Add app name and version to every event
|
|
56
|
-
insights.addTelemetryInitializer(envelope => {
|
|
57
|
-
const trace = {
|
|
58
|
-
...(envelope.ext?.trace ?? {}),
|
|
59
|
-
name: applicationName,
|
|
60
|
-
};
|
|
61
|
-
envelope.ext = { ...envelope.ext, trace };
|
|
62
|
-
envelope.data = {
|
|
63
|
-
...envelope.data,
|
|
64
|
-
applicationName,
|
|
65
|
-
applicationVersion,
|
|
66
|
-
};
|
|
14
|
+
import usageDataCommon, { Metadata } from './usageDataCommon';
|
|
15
|
+
import usageDataMain from './usageDataMain';
|
|
16
|
+
import usageDataRenderer from './usageDataRenderer';
|
|
17
|
+
|
|
18
|
+
const getFriendlyAppName = () =>
|
|
19
|
+
packageJson().name.replace('pc-nrfconnect-', '');
|
|
20
|
+
|
|
21
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
22
|
+
const flattenObject = (obj?: any, parentKey?: string) => {
|
|
23
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
24
|
+
let result: any = {};
|
|
25
|
+
|
|
26
|
+
if (!obj) return result;
|
|
27
|
+
|
|
28
|
+
Object.keys(obj).forEach(key => {
|
|
29
|
+
const value = obj[key];
|
|
30
|
+
const newKey = parentKey ? `${parentKey}.${key}` : key;
|
|
31
|
+
if (typeof value === 'object') {
|
|
32
|
+
result = { ...result, ...flattenObject(value, newKey) };
|
|
33
|
+
} else {
|
|
34
|
+
result[newKey] = value;
|
|
35
|
+
}
|
|
67
36
|
});
|
|
68
37
|
|
|
69
|
-
|
|
70
|
-
`Application Insights for category ${applicationName} has initialized`
|
|
71
|
-
);
|
|
72
|
-
|
|
73
|
-
// Add 5 second delay to prevent inital rendering from beeing frozen.
|
|
74
|
-
setTimeout(async () => {
|
|
75
|
-
// eslint-disable-next-line global-require
|
|
76
|
-
const si = require('systeminformation') as typeof Systeminformation;
|
|
77
|
-
sendUsageData('architecture', (await si.osInfo()).arch);
|
|
78
|
-
}, 5_000);
|
|
79
|
-
};
|
|
80
|
-
|
|
81
|
-
/**
|
|
82
|
-
* Checks if usage report instance is initialized and ready to be sent
|
|
83
|
-
*
|
|
84
|
-
* @returns {Boolean} returns whether the setting is on, off or undefined
|
|
85
|
-
*/
|
|
86
|
-
export const isInitialized = () => {
|
|
87
|
-
logger?.debug(
|
|
88
|
-
`Usage report instance is${
|
|
89
|
-
insights !== undefined ? '' : ' not'
|
|
90
|
-
} initialized`
|
|
91
|
-
);
|
|
92
|
-
return insights !== undefined;
|
|
93
|
-
};
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* Check the status of usage data
|
|
97
|
-
*
|
|
98
|
-
* @returns {Boolean | undefined} returns whether the setting is on, off or undefined
|
|
99
|
-
*/
|
|
100
|
-
export const isEnabled = () => {
|
|
101
|
-
const isSendingUsageData = getIsSendingUsageData();
|
|
102
|
-
logger?.debug(`Usage data is ${isSendingUsageData}`);
|
|
103
|
-
return isSendingUsageData;
|
|
38
|
+
return result;
|
|
104
39
|
};
|
|
105
40
|
|
|
106
|
-
|
|
107
|
-
* Enable sending usage data
|
|
108
|
-
*
|
|
109
|
-
* @returns {void}
|
|
110
|
-
*/
|
|
111
|
-
export const enable = () => {
|
|
41
|
+
const enable = () => {
|
|
112
42
|
persistIsSendingUsageData(true);
|
|
113
|
-
|
|
43
|
+
si.osInfo().then(({ platform, arch }) =>
|
|
44
|
+
getUsageData().sendUsageData('Report OS info', { platform, arch })
|
|
45
|
+
);
|
|
46
|
+
getUsageData().sendUsageData('Data Usage Opt-In', undefined);
|
|
47
|
+
usageDataCommon.getLogger()?.debug('Usage data has been enabled');
|
|
114
48
|
};
|
|
115
49
|
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
*
|
|
119
|
-
* @returns {void}
|
|
120
|
-
*/
|
|
121
|
-
export const disable = () => {
|
|
50
|
+
const disable = () => {
|
|
51
|
+
getUsageData().sendUsageData('Data Usage Opt-Out', undefined, true);
|
|
122
52
|
persistIsSendingUsageData(false);
|
|
123
|
-
|
|
53
|
+
usageDataCommon.getLogger()?.debug('Usage data has been disabled');
|
|
124
54
|
};
|
|
125
55
|
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
* ask the user to enable or disable sending usage data
|
|
129
|
-
*
|
|
130
|
-
* @returns {void}
|
|
131
|
-
*/
|
|
132
|
-
export const reset = () => {
|
|
56
|
+
const reset = () => {
|
|
57
|
+
getUsageData().sendUsageData('Data Usage Opt-Reset', undefined, true);
|
|
133
58
|
deleteIsSendingUsageData();
|
|
134
|
-
|
|
59
|
+
usageDataCommon.getLogger()?.debug('Usage data setting has been reset');
|
|
135
60
|
};
|
|
136
61
|
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
*/
|
|
143
|
-
const sendEvent = ({ action, label }: EventAction) => {
|
|
144
|
-
const isSendingUsageData = getIsSendingUsageData();
|
|
145
|
-
|
|
146
|
-
if (isSendingUsageData && insights !== undefined) {
|
|
147
|
-
logger?.debug(`Sending usage data ${action} ${label}`);
|
|
148
|
-
insights.trackEvent({
|
|
149
|
-
name: action,
|
|
150
|
-
properties: label ? { label } : undefined,
|
|
151
|
-
});
|
|
62
|
+
const isRenderer = process && process.type === 'renderer';
|
|
63
|
+
|
|
64
|
+
const getUsageData = () => {
|
|
65
|
+
if (isRenderer) {
|
|
66
|
+
return usageDataRenderer;
|
|
152
67
|
}
|
|
68
|
+
|
|
69
|
+
return usageDataMain;
|
|
153
70
|
};
|
|
154
71
|
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
72
|
+
const sendUsageData = async (
|
|
73
|
+
action: string,
|
|
74
|
+
metadata?: Metadata,
|
|
75
|
+
forceSend?: boolean
|
|
76
|
+
) => {
|
|
77
|
+
if (
|
|
78
|
+
await getUsageData().sendUsageData(
|
|
79
|
+
`${getFriendlyAppName()}: ${action}`,
|
|
80
|
+
flattenObject(metadata),
|
|
81
|
+
forceSend
|
|
82
|
+
)
|
|
83
|
+
) {
|
|
84
|
+
usageDataCommon
|
|
85
|
+
.getLogger()
|
|
86
|
+
?.debug(`Sending usage data ${JSON.stringify(action)}`);
|
|
165
87
|
}
|
|
166
|
-
eventQueue.forEach(sendEvent);
|
|
167
|
-
eventQueue = [];
|
|
168
88
|
};
|
|
169
89
|
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
name,
|
|
173
|
-
average,
|
|
174
|
-
});
|
|
175
|
-
};
|
|
90
|
+
const sendPageView = (pageName: string) =>
|
|
91
|
+
getUsageData().sendPageView(`${getFriendlyAppName()} - ${pageName}`);
|
|
176
92
|
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
message,
|
|
180
|
-
});
|
|
181
|
-
};
|
|
93
|
+
const sendMetric = (name: string, average: number) =>
|
|
94
|
+
getUsageData().sendMetric(name, average);
|
|
182
95
|
|
|
183
|
-
|
|
184
|
-
* Send error usage data event to Application Insights and also show it in the logger view
|
|
185
|
-
* @param {string} error The event action
|
|
186
|
-
* @returns {void}
|
|
187
|
-
*/
|
|
188
|
-
export const sendErrorReport = (error: string) => {
|
|
189
|
-
logger?.error(error);
|
|
190
|
-
insights?.trackException({
|
|
191
|
-
exception: new Error(error),
|
|
192
|
-
});
|
|
193
|
-
};
|
|
96
|
+
const sendTrace = (message: string) => getUsageData().sendTrace(message);
|
|
194
97
|
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
98
|
+
const sendErrorReport = (error: string | Error) => {
|
|
99
|
+
usageDataCommon.getLogger()?.error(error);
|
|
100
|
+
return getUsageData().sendErrorReport(
|
|
101
|
+
typeof error === 'string' ? new Error(error) : error
|
|
102
|
+
);
|
|
198
103
|
};
|
|
199
104
|
|
|
200
105
|
export default {
|
|
106
|
+
setLogger: usageDataCommon.setLogger,
|
|
201
107
|
disable,
|
|
202
108
|
enable,
|
|
203
|
-
|
|
204
|
-
isEnabled,
|
|
205
|
-
isInitialized,
|
|
109
|
+
isEnabled: usageDataCommon.isEnabled,
|
|
206
110
|
reset,
|
|
207
111
|
sendErrorReport,
|
|
208
112
|
sendUsageData,
|
|
113
|
+
sendPageView,
|
|
114
|
+
sendMetric,
|
|
115
|
+
sendTrace,
|
|
116
|
+
enableTelemetry: usageDataCommon.enableTelemetry,
|
|
209
117
|
};
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2105 Nordic Semiconductor ASA
|
|
3
|
+
*
|
|
4
|
+
* SPDX-License-Identifier: LicenseRef-Nordic-4-Clause
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import winston from 'winston';
|
|
8
|
+
|
|
9
|
+
import { type Device } from '../Device/deviceSlice';
|
|
10
|
+
import { getIsSendingUsageData } from './persistentStore';
|
|
11
|
+
|
|
12
|
+
export const INSTRUMENTATION_KEY = '4b8b1a39-37c7-479e-a684-d4763c7c647c';
|
|
13
|
+
|
|
14
|
+
let telemetryEnabled = false;
|
|
15
|
+
|
|
16
|
+
const enableTelemetry = () => {
|
|
17
|
+
telemetryEnabled = true;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
let logger: winston.Logger | undefined;
|
|
21
|
+
const setLogger = (log: winston.Logger) => {
|
|
22
|
+
logger = log;
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
const getLogger = () => logger;
|
|
26
|
+
|
|
27
|
+
export interface Metadata {
|
|
28
|
+
[key: string]: unknown;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export const simplifyDeviceForLogging = (device: Device) => ({
|
|
32
|
+
devkit: device.devkit,
|
|
33
|
+
serialPorts: device.serialPorts,
|
|
34
|
+
traits: device.traits,
|
|
35
|
+
serialNumber: device.serialNumber,
|
|
36
|
+
enumerationID: device.id,
|
|
37
|
+
usb: {
|
|
38
|
+
product: device.usb?.product,
|
|
39
|
+
manufacturer: device.usb?.manufacturer,
|
|
40
|
+
deviceDescriptor: device.usb?.device.descriptor,
|
|
41
|
+
},
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
const isEnabled = () => {
|
|
45
|
+
const isSendingUsageData = getShouldSendTelemetry();
|
|
46
|
+
logger?.debug(`Usage data is ${isSendingUsageData}`);
|
|
47
|
+
return isSendingUsageData;
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
const getShouldSendTelemetry = (forceSend?: boolean) =>
|
|
51
|
+
(forceSend || getIsSendingUsageData()) && telemetryEnabled;
|
|
52
|
+
|
|
53
|
+
export default {
|
|
54
|
+
setLogger,
|
|
55
|
+
getLogger,
|
|
56
|
+
isEnabled,
|
|
57
|
+
getShouldSendTelemetry,
|
|
58
|
+
enableTelemetry,
|
|
59
|
+
};
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2105 Nordic Semiconductor ASA
|
|
3
|
+
*
|
|
4
|
+
* SPDX-License-Identifier: LicenseRef-Nordic-4-Clause
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import { TelemetryClient } from 'applicationinsights';
|
|
8
|
+
|
|
9
|
+
import { isDevelopment } from './environment';
|
|
10
|
+
import { packageJson } from './packageJson';
|
|
11
|
+
import usageDataCommon, {
|
|
12
|
+
INSTRUMENTATION_KEY,
|
|
13
|
+
Metadata,
|
|
14
|
+
} from './usageDataCommon';
|
|
15
|
+
|
|
16
|
+
let cachedInsights: TelemetryClient | undefined;
|
|
17
|
+
|
|
18
|
+
const getInsights = (forceSend?: boolean) => {
|
|
19
|
+
if (!usageDataCommon.getShouldSendTelemetry(forceSend)) return;
|
|
20
|
+
|
|
21
|
+
if (cachedInsights) {
|
|
22
|
+
return cachedInsights;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
if (!cachedInsights) {
|
|
26
|
+
cachedInsights = init();
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
return cachedInsights;
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
const init = () => {
|
|
33
|
+
const appPackageJson = packageJson();
|
|
34
|
+
const applicationName = appPackageJson.name;
|
|
35
|
+
const applicationVersion = appPackageJson.version;
|
|
36
|
+
|
|
37
|
+
const out = new TelemetryClient(INSTRUMENTATION_KEY);
|
|
38
|
+
out.config.enableAutoCollectConsole = false;
|
|
39
|
+
out.config.enableAutoCollectDependencies = false;
|
|
40
|
+
out.config.enableAutoCollectExceptions = false;
|
|
41
|
+
out.config.enableAutoCollectIncomingRequestAzureFunctions = false;
|
|
42
|
+
out.config.enableAutoCollectHeartbeat = false;
|
|
43
|
+
out.config.enableAutoCollectPerformance = false;
|
|
44
|
+
out.config.enableAutoCollectPreAggregatedMetrics = false;
|
|
45
|
+
out.config.enableAutoCollectRequests = false;
|
|
46
|
+
out.config.enableAutoDependencyCorrelation = false;
|
|
47
|
+
|
|
48
|
+
// Add app name and version to every event
|
|
49
|
+
out.addTelemetryProcessor(envelope => {
|
|
50
|
+
if (envelope.data.baseData?.removeAllMetadata) {
|
|
51
|
+
envelope.tags = [];
|
|
52
|
+
envelope.data.baseData = { name: envelope.data?.baseData };
|
|
53
|
+
} else {
|
|
54
|
+
envelope.tags['ai.cloud.roleInstance'] = undefined; // remove PC name
|
|
55
|
+
envelope.data.baseData = {
|
|
56
|
+
applicationName,
|
|
57
|
+
applicationVersion,
|
|
58
|
+
isDevelopment,
|
|
59
|
+
...envelope.data.baseData,
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
return true;
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
return out;
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
const sendUsageData = (
|
|
70
|
+
action: string,
|
|
71
|
+
metadata?: Metadata,
|
|
72
|
+
forceSend?: boolean
|
|
73
|
+
) => {
|
|
74
|
+
const result = getInsights(forceSend);
|
|
75
|
+
if (result !== undefined) {
|
|
76
|
+
result.trackEvent({
|
|
77
|
+
name: action,
|
|
78
|
+
properties: forceSend ? { removeAllMetadata: true } : metadata,
|
|
79
|
+
});
|
|
80
|
+
return true;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
return false;
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
const sendPageView = (pageName: string) => {
|
|
87
|
+
getInsights()?.trackPageView({
|
|
88
|
+
name: pageName,
|
|
89
|
+
});
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
const sendMetric = (name: string, value: number) => {
|
|
93
|
+
getInsights()?.trackMetric({
|
|
94
|
+
name,
|
|
95
|
+
value,
|
|
96
|
+
});
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
const sendTrace = (message: string) => {
|
|
100
|
+
getInsights()?.trackTrace({
|
|
101
|
+
message,
|
|
102
|
+
});
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
const sendErrorReport = (error: Error) => {
|
|
106
|
+
getInsights()?.trackException({
|
|
107
|
+
exception: error,
|
|
108
|
+
});
|
|
109
|
+
};
|
|
110
|
+
|
|
111
|
+
export default {
|
|
112
|
+
sendErrorReport,
|
|
113
|
+
sendUsageData,
|
|
114
|
+
sendPageView,
|
|
115
|
+
sendMetric,
|
|
116
|
+
sendTrace,
|
|
117
|
+
};
|