From d7aca7129842de1bcb5849867d031d2267061dd0 Mon Sep 17 00:00:00 2001 From: AdrianP <38519157+panaaj@users.noreply.github.com> Date: Mon, 2 Dec 2024 15:34:24 +1030 Subject: [PATCH] update test for valid destination point (#1840) --- src/api/course/index.ts | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/src/api/course/index.ts b/src/api/course/index.ts index 037f2c35d..cb3297907 100644 --- a/src/api/course/index.ts +++ b/src/api/course/index.ts @@ -208,6 +208,18 @@ export class CourseApi { }) } + /** Test for valid Signal K position */ + private isValidPosition(position: Position): boolean { + return ( + typeof position?.latitude === 'number' && + typeof position?.latitude === 'number' && + position?.latitude >= -90 && + position?.latitude <= 90 && + position?.longitude >= -180 && + position?.longitude <= 180 + ) + } + /** Process stream value and take action * @param cmdSource Object describing the source of the update * @param pos Destination location value in the update @@ -215,7 +227,7 @@ export class CourseApi { private async parseStreamValue(cmdSource: CommandSource, pos: Position) { if (!this.cmdSource) { // New source - if (!pos) { + if (!this.isValidPosition(pos)) { return } debug('parseStreamValue:', 'Setting Destination...') @@ -805,7 +817,7 @@ export class CourseApi { throw new Error(`Invalid href! (${dest.href})`) } } else if ('position' in dest) { - if (isValidCoordinate(dest.position)) { + if (this.isValidPosition(dest.position)) { newCourse.nextPoint = { position: dest.position, type: Location