diff options
author | AlTech98 <altech123159@gmail.com> | 2021-08-30 21:12:13 +0200 |
---|---|---|
committer | AlTech98 <altech123159@gmail.com> | 2021-08-30 21:12:13 +0200 |
commit | b59cbdb081da601cb7c19cb6010474def1bdcffb (patch) | |
tree | 0acfe5d47cc277b3bac5e91056ed4db0ad6ec3f9 /api/src/util/Voice.ts | |
parent | added first unittests for api endpoints (diff) | |
download | server-b59cbdb081da601cb7c19cb6010474def1bdcffb.tar.xz |
Implemented voice apis #127 and #78
Diffstat (limited to 'api/src/util/Voice.ts')
-rw-r--r-- | api/src/util/Voice.ts | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/api/src/util/Voice.ts b/api/src/util/Voice.ts new file mode 100644 index 00000000..087bdfa8 --- /dev/null +++ b/api/src/util/Voice.ts @@ -0,0 +1,32 @@ +import {Config} from "@fosscord/util"; +import {distanceBetweenLocations, IPAnalysis} from "./ipAddress"; + +export async function getVoiceRegions(ipAddress: string, vip: boolean) { + const regions = Config.get().regions; + const availableRegions = regions.available.filter(ar => vip ? true : !ar.vip); + let optimalId = regions.default + + if(!regions.useDefaultAsOptimal) { + const clientIpAnalysis = await IPAnalysis(ipAddress) + + let min = Number.POSITIVE_INFINITY + + for (let ar of availableRegions) { + //TODO the endpoint location should be saved in the database if not already present to prevent IPAnalysis call + const dist = distanceBetweenLocations(clientIpAnalysis, ar.location || (await IPAnalysis(ar.endpoint))) + + if(dist < min) { + min = dist + optimalId = ar.id + } + } + } + + return availableRegions.map(ar => ({ + id: ar.id, + name: ar.name, + custom: ar.custom, + deprecated: ar.deprecated, + optimal: ar.id === optimalId + })) +} \ No newline at end of file |