summaryrefslogtreecommitdiffstats
path: root/dom/base/LocationHelper.sys.mjs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
commit6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch)
treea68f146d7fa01f0134297619fbe7e33db084e0aa /dom/base/LocationHelper.sys.mjs
parentInitial commit. (diff)
downloadthunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz
thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.zip
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/base/LocationHelper.sys.mjs')
-rw-r--r--dom/base/LocationHelper.sys.mjs51
1 files changed, 51 insertions, 0 deletions
diff --git a/dom/base/LocationHelper.sys.mjs b/dom/base/LocationHelper.sys.mjs
new file mode 100644
index 0000000000..671dd414d6
--- /dev/null
+++ b/dom/base/LocationHelper.sys.mjs
@@ -0,0 +1,51 @@
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this file,
+ * You can obtain one at http://mozilla.org/MPL/2.0/. */
+
+function isPublic(ap) {
+ let mask = "_nomap";
+ let result = ap.ssid.indexOf(mask, ap.ssid.length - mask.length);
+ return result == -1;
+}
+
+function sort(a, b) {
+ return b.signal - a.signal;
+}
+
+function encode(ap) {
+ return { macAddress: ap.mac, signalStrength: ap.signal };
+}
+
+/**
+ * Shared utility functions for modules dealing with
+ * Location Services.
+ */
+
+export class LocationHelper {
+ static formatWifiAccessPoints(accessPoints) {
+ return accessPoints.filter(isPublic).sort(sort).map(encode);
+ }
+
+ /**
+ * Calculate the distance between 2 points using the Haversine formula.
+ * https://en.wikipedia.org/wiki/Haversine_formula
+ */
+ static distance(p1, p2) {
+ let rad = x => (x * Math.PI) / 180;
+ // Radius of the earth.
+ let R = 6371e3;
+ let lat = rad(p2.lat - p1.lat);
+ let lng = rad(p2.lng - p1.lng);
+
+ let a =
+ Math.sin(lat / 2) * Math.sin(lat / 2) +
+ Math.cos(rad(p1.lat)) *
+ Math.cos(rad(p2.lat)) *
+ Math.sin(lng / 2) *
+ Math.sin(lng / 2);
+
+ let c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
+
+ return R * c;
+ }
+}