steelseries-sonar-sdk 0.1.1

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 (118) hide show
  1. package/.gitattributes +8 -0
  2. package/.github/workflows/tests.yml +18 -0
  3. package/.vscode/extensions.json +8 -0
  4. package/.vscode/settings.json +33 -0
  5. package/LICENSE +21 -0
  6. package/README.md +121 -0
  7. package/_.todo +4 -0
  8. package/biome.json +62 -0
  9. package/http/sonar.http +104 -0
  10. package/package.json +31 -0
  11. package/src/consts/fetch-options-put.ts +3 -0
  12. package/src/enums.ts +88 -0
  13. package/src/exceptions.ts +45 -0
  14. package/src/functions/audio/get-audio-data-classic.ts +31 -0
  15. package/src/functions/audio/get-audio-data-stream.ts +37 -0
  16. package/src/functions/audio/get-audio-mode.ts +11 -0
  17. package/src/functions/audio/set-audio-mode.ts +12 -0
  18. package/src/functions/audio/set-channel-mute-classic.ts +35 -0
  19. package/src/functions/audio/set-channel-mute-streamer.ts +41 -0
  20. package/src/functions/audio/set-channel-volume-classic.ts +37 -0
  21. package/src/functions/audio/set-channel-volume-streamer.ts +43 -0
  22. package/src/functions/chatmix/get-chat-mix-state.ts +20 -0
  23. package/src/functions/chatmix/set-chat-mix-balance.ts +22 -0
  24. package/src/functions/converters/convert-channel-to-api.ts +19 -0
  25. package/src/functions/converters/convert-chat-mix-balance-to-api.ts +6 -0
  26. package/src/functions/converters/convert-chat-mix-balance-to-user.ts +7 -0
  27. package/src/functions/converters/convert-profile-channel-to-api.ts +19 -0
  28. package/src/functions/converters/convert-profile-channel-to-user.ts +19 -0
  29. package/src/functions/converters/convert-volume-to-api.ts +5 -0
  30. package/src/functions/converters/convert-volume-to-user.ts +6 -0
  31. package/src/functions/devices/get-audio-devices.ts +40 -0
  32. package/src/functions/devices/set-audio-device.ts +19 -0
  33. package/src/functions/endpoint/get-app-endpoint.ts +73 -0
  34. package/src/functions/endpoint/get-sonar-endpoint-cached.ts +28 -0
  35. package/src/functions/endpoint/get-sonar-endpoint.ts +88 -0
  36. package/src/functions/profile/get-channel-profiles.ts +26 -0
  37. package/src/functions/profile/get-selected-profiles.ts +17 -0
  38. package/src/functions/profile/set-selected-profile.ts +17 -0
  39. package/src/index.ts +41 -0
  40. package/src/sonar/models/audio-settings/chatmix-data.ts +6 -0
  41. package/src/sonar/models/audio-settings/enums/audio-mode.ts +4 -0
  42. package/src/sonar/models/audio-settings/enums/chat-mix-state.ts +6 -0
  43. package/src/sonar/models/audio-settings/enums/device-data-flow.ts +5 -0
  44. package/src/sonar/models/audio-settings/enums/device-default-roles.ts +6 -0
  45. package/src/sonar/models/audio-settings/enums/device-role.ts +9 -0
  46. package/src/sonar/models/audio-settings/enums/device-state.ts +8 -0
  47. package/src/sonar/models/audio-settings/enums/sonar-channel.ts +8 -0
  48. package/src/sonar/models/audio-settings/enums/streaming-path.ts +4 -0
  49. package/src/sonar/models/audio-settings/volume-info-classic.ts +4 -0
  50. package/src/sonar/models/audio-settings/volume-info-streamer.ts +10 -0
  51. package/src/sonar/models/audio-settings/volume-settings-classic.ts +13 -0
  52. package/src/sonar/models/audio-settings/volume-settings-streamer.ts +13 -0
  53. package/src/sonar/models/config/config.ts +9 -0
  54. package/src/sonar/models/config/enums/VirtualAudioDevice.ts +7 -0
  55. package/src/sonar/models/devices/audio-device.ts +17 -0
  56. package/src/sonar/models/devices/changed-device.ts +7 -0
  57. package/src/sonar/requests/audio-devices/change-audio-device.ts +37 -0
  58. package/src/sonar/requests/audio-devices/request-audio-devices.ts +42 -0
  59. package/src/sonar/requests/chatmix/change-chat-mix-balance.ts +25 -0
  60. package/src/sonar/requests/chatmix/request-chat-mix-state.ts +24 -0
  61. package/src/sonar/requests/mode/change-audio-mode.ts +24 -0
  62. package/src/sonar/requests/mode/request-audio-mode.ts +24 -0
  63. package/src/sonar/requests/profiles/change-selected-config.ts +25 -0
  64. package/src/sonar/requests/profiles/request-configs.ts +24 -0
  65. package/src/sonar/requests/profiles/request-selected-configs.ts +22 -0
  66. package/src/sonar/requests/volume-settings/change-volume-level-classic.ts +27 -0
  67. package/src/sonar/requests/volume-settings/change-volume-level-streamer.ts +29 -0
  68. package/src/sonar/requests/volume-settings/change-volume-mute-classic.ts +27 -0
  69. package/src/sonar/requests/volume-settings/change-volume-mute-streamer.ts +29 -0
  70. package/src/sonar/requests/volume-settings/request-volume-settings-classic.ts +22 -0
  71. package/src/sonar/requests/volume-settings/request-volume-settings-streamer.ts +22 -0
  72. package/src/types/audio-device.ts +7 -0
  73. package/src/types/changed-device.ts +7 -0
  74. package/src/types/channel-volume-classic.ts +4 -0
  75. package/src/types/channel-volume-streamer-path.ts +4 -0
  76. package/src/types/channel-volume-streamer.ts +6 -0
  77. package/src/types/channel-volumes-classic.ts +8 -0
  78. package/src/types/channel-volumes-streamer.ts +8 -0
  79. package/src/types/chat-mix-data.ts +7 -0
  80. package/src/types/profile-option.ts +9 -0
  81. package/tests/e2e/audio/get-audio-data-classic.real.test.ts +11 -0
  82. package/tests/e2e/audio/get-audio-data-stream.real.test.ts +11 -0
  83. package/tests/e2e/audio/get-audio-mode.real.test.ts +12 -0
  84. package/tests/e2e/audio/set-audio-mode.real.test.ts +20 -0
  85. package/tests/e2e/audio/set-channel-mute-classic.real.test.ts +18 -0
  86. package/tests/e2e/audio/set-channel-mute-streamer.real.test.ts +18 -0
  87. package/tests/e2e/audio/set-channel-volume-classic.real.test.ts +17 -0
  88. package/tests/e2e/audio/set-channel-volume-streamer.real.test.ts +22 -0
  89. package/tests/e2e/chatmix/get-chat-mix-state.real.test.ts +25 -0
  90. package/tests/e2e/chatmix/set-chat-mix-balance.real.test.ts +25 -0
  91. package/tests/e2e/devices/get-audio-devices.real.test.ts +29 -0
  92. package/tests/e2e/devices/set-audio-device.real.test.ts +32 -0
  93. package/tests/e2e/enpoint/get-app-endpoint.real.test.ts +19 -0
  94. package/tests/e2e/enpoint/get-sonar-endpoint-cached.real.test.ts +32 -0
  95. package/tests/e2e/enpoint/get-sonar-endpoint.real.test.ts +21 -0
  96. package/tests/e2e/profiles/get-channel-profiles.real.test.ts +21 -0
  97. package/tests/e2e/profiles/get-selected-profiles.real.test.ts +11 -0
  98. package/tests/e2e/profiles/set-selected-profile.real.test.ts +17 -0
  99. package/tests/helpers/get-endpoint-e2e.ts +8 -0
  100. package/tests/unit/audio/get-audio-data-classic.test.ts +57 -0
  101. package/tests/unit/audio/get-audio-data-stream.test.ts +65 -0
  102. package/tests/unit/audio/get-audio-mode.test.ts +58 -0
  103. package/tests/unit/audio/set-audio-mode.test.ts +66 -0
  104. package/tests/unit/audio/set-channel-mute-classic.test.ts +58 -0
  105. package/tests/unit/audio/set-channel-mute-streamer.test.ts +64 -0
  106. package/tests/unit/audio/set-channel-volume-classic.test.ts +58 -0
  107. package/tests/unit/audio/set-channel-volume-streamer.test.ts +64 -0
  108. package/tests/unit/chatmix/get-chat-mix-state.test.ts +70 -0
  109. package/tests/unit/chatmix/set-chat-mix-balance.test.ts +58 -0
  110. package/tests/unit/devices/get-audio-devices.test.ts +59 -0
  111. package/tests/unit/devices/set-audio-devices.test.ts +62 -0
  112. package/tests/unit/endpoint/get-app-endpoint.test.ts +72 -0
  113. package/tests/unit/endpoint/get-sonar-endpoint-cached.test.ts +93 -0
  114. package/tests/unit/endpoint/get-sonar-endpoint.test.ts +140 -0
  115. package/tests/unit/profiles/get-channel-profiles.test.ts +91 -0
  116. package/tests/unit/profiles/get-selected-profiles.test.ts +64 -0
  117. package/tests/unit/profiles/set-selected-profile.test.ts +55 -0
  118. package/tsconfig.json +36 -0
@@ -0,0 +1,6 @@
1
+ export enum ChatMixState {
2
+ Enabled = 'enabled',
3
+ FiniteWheel = 'finiteWheel',
4
+ DifferentDeviceSelected = 'differentDeviceSelected',
5
+ NoDeviceSelected = 'noDeviceSelected'
6
+ }
@@ -0,0 +1,5 @@
1
+ export enum DeviceDataFlow {
2
+ Render = 'render',
3
+ Capture = 'capture',
4
+ All = 'all'
5
+ }
@@ -0,0 +1,6 @@
1
+ export enum DeviceDefaultRoles {
2
+ Console = 0,
3
+ Multimedia = 1,
4
+ Communications = 2,
5
+ All = Communications | Multimedia // 0x00000003
6
+ }
@@ -0,0 +1,9 @@
1
+ export enum DeviceRole {
2
+ None = 'none',
3
+ ChatRender = 'chatRender',
4
+ Game = 'game',
5
+ ChatCapture = 'chatCapture',
6
+ Stream = 'stream',
7
+ Media = 'media',
8
+ Aux = 'aux'
9
+ }
@@ -0,0 +1,8 @@
1
+ export enum DeviceState {
2
+ Active = 1,
3
+ Disabled = 2,
4
+ ActiveOrDisabled = 3,
5
+ Notpresent = 4,
6
+ Unplugged = 8,
7
+ All = 15 // 0x0000000F
8
+ }
@@ -0,0 +1,8 @@
1
+ export enum SonarChannel {
2
+ Master = 'master',
3
+ ChatRender = 'chatRender',
4
+ Game = 'game',
5
+ ChatCapture = 'chatCapture',
6
+ Media = 'media',
7
+ Aux = 'aux'
8
+ }
@@ -0,0 +1,4 @@
1
+ export enum StreamingPath {
2
+ Streaming = 'streaming',
3
+ Monitoring = 'monitoring'
4
+ }
@@ -0,0 +1,4 @@
1
+ export type VolumeInfoClassic = {
2
+ volume: number
3
+ muted: boolean
4
+ }
@@ -0,0 +1,10 @@
1
+ export type VolumeInfoStreamer = {
2
+ streaming: {
3
+ volume: number
4
+ muted: boolean
5
+ }
6
+ monitoring: {
7
+ volume: number
8
+ muted: boolean
9
+ }
10
+ }
@@ -0,0 +1,13 @@
1
+ import type { VolumeInfoClassic } from '@/sonar/models/audio-settings/volume-info-classic'
2
+
3
+ export type VolumeSettingsClassic = {
4
+ masters: {
5
+ classic: VolumeInfoClassic
6
+ }
7
+ devices: Record<
8
+ string,
9
+ {
10
+ classic: VolumeInfoClassic
11
+ }
12
+ >
13
+ }
@@ -0,0 +1,13 @@
1
+ import type { VolumeInfoStreamer } from '@/sonar/models/audio-settings/volume-info-streamer'
2
+
3
+ export type VolumeSettingsStreamer = {
4
+ masters: {
5
+ stream: VolumeInfoStreamer
6
+ }
7
+ devices: Record<
8
+ string,
9
+ {
10
+ stream: VolumeInfoStreamer
11
+ }
12
+ >
13
+ }
@@ -0,0 +1,9 @@
1
+ import type { VirtualAudioDevice } from '@/sonar/models/config/enums/VirtualAudioDevice'
2
+
3
+ export type Config = {
4
+ id: string
5
+ name: string
6
+ isFavorite: boolean
7
+ virtualAudioDevice: VirtualAudioDevice
8
+ image?: string
9
+ }
@@ -0,0 +1,7 @@
1
+ export enum VirtualAudioDevice {
2
+ Game = 'game',
3
+ ChatRender = 'chatRender',
4
+ ChatCapture = 'chatCapture',
5
+ Media = 'media',
6
+ Aux = 'aux'
7
+ }
@@ -0,0 +1,17 @@
1
+ import type { DeviceDataFlow } from '@/sonar/models/audio-settings/enums/device-data-flow'
2
+ import type { DeviceDefaultRoles } from '@/sonar/models/audio-settings/enums/device-default-roles'
3
+ import type { DeviceRole } from '@/sonar/models/audio-settings/enums/device-role'
4
+ import type { DeviceState } from '@/sonar/models/audio-settings/enums/device-state'
5
+
6
+ export type AudioDevice = {
7
+ id: string
8
+ friendlyName: string
9
+ dataFlow: DeviceDataFlow
10
+ role: DeviceRole
11
+ channels: number
12
+ defaultRole: DeviceDefaultRoles
13
+ fwUpdateRequired: boolean
14
+ state: DeviceState
15
+ /** `true` if {@link DeviceRole} ≠ {@link DeviceRole.None} */
16
+ isVad: boolean
17
+ }
@@ -0,0 +1,7 @@
1
+ import type { DeviceChannel } from '@/enums'
2
+
3
+ export type ChangedDevice = {
4
+ id: Exclude<DeviceChannel, DeviceChannel.Output>
5
+ deviceId: string
6
+ isRunning: boolean
7
+ }
@@ -0,0 +1,37 @@
1
+ import type { DeviceChannel } from '@/enums'
2
+ import { SonarRequestException } from '@/exceptions'
3
+ import type { ChangedDevice } from '@/sonar/models/devices/changed-device'
4
+
5
+ export async function changeAudioDevice(
6
+ sonarEndpoint: string,
7
+ deviceChannel: DeviceChannel,
8
+ deviceId: string
9
+ ): Promise<ChangedDevice[]> {
10
+ let response: Response
11
+ const url = new URL(`${sonarEndpoint}/classicRedirections/${deviceChannel}/deviceId/${deviceId}`)
12
+
13
+ try {
14
+ response = await fetch(url, { method: 'PUT' })
15
+ } catch (error) {
16
+ throw new SonarRequestException({
17
+ innerException: error as Error
18
+ })
19
+ }
20
+
21
+ if (!response.ok) {
22
+ const error = await response.text()
23
+ throw new SonarRequestException({ message: `Failed to get audio devices: ${error}` })
24
+ }
25
+
26
+ const unknownData = (await response.json()) as ChangedDevice[] | ChangedDevice
27
+
28
+ const data = Array.isArray(unknownData) ? unknownData : [unknownData]
29
+
30
+ const devices = data.filter((x) => x?.deviceId === deviceId)
31
+
32
+ if (devices.length === 0) {
33
+ throw new SonarRequestException({ message: 'The changed audio devices list is empty.' })
34
+ }
35
+
36
+ return devices
37
+ }
@@ -0,0 +1,42 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { DeviceDataFlow } from '@/sonar/models/audio-settings/enums/device-data-flow'
3
+ import type { AudioDevice as SonarAudioDevice } from '@/sonar/models/devices/audio-device'
4
+
5
+ type Params = {
6
+ deviceDataFlow?: DeviceDataFlow
7
+ onlySteelSeriesVAD?: boolean
8
+ removeSteelSeriesVAD?: boolean
9
+ }
10
+
11
+ export async function requestAudioDevices(sonarEndpoint: string, params: Params): Promise<SonarAudioDevice[]> {
12
+ const { deviceDataFlow, onlySteelSeriesVAD = false, removeSteelSeriesVAD = false } = params
13
+
14
+ const url = new URL(`${sonarEndpoint}/audioDevices`)
15
+ url.searchParams.append('onlySteelSeriesVAD', String(onlySteelSeriesVAD))
16
+ url.searchParams.append('removeSteelSeriesVAD', String(removeSteelSeriesVAD))
17
+ if (deviceDataFlow !== undefined) {
18
+ url.searchParams.append('deviceDataFlow', deviceDataFlow.toString())
19
+ }
20
+
21
+ let response: Response
22
+ try {
23
+ response = await fetch(url)
24
+ } catch (error) {
25
+ throw new SonarRequestException({
26
+ innerException: error as Error
27
+ })
28
+ }
29
+
30
+ if (!response.ok) {
31
+ const error = await response.text()
32
+ throw new SonarRequestException({ message: `Failed to get audio devices: ${error}` })
33
+ }
34
+
35
+ const data = (await response.json()) as SonarAudioDevice[]
36
+
37
+ if (!Array.isArray(data)) {
38
+ throw new SonarRequestException({ message: 'Invalid audio devices response format.' })
39
+ }
40
+
41
+ return data
42
+ }
@@ -0,0 +1,25 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { ChatMixData } from '@/sonar/models/audio-settings/chatmix-data'
3
+
4
+ export async function changeChatMixBalance(sonarEndpoint: string, chatBalance: number) {
5
+ const url = new URL(`${sonarEndpoint}/chatMix?balance=${chatBalance}`)
6
+ let response: Response
7
+ try {
8
+ response = await fetch(url, {
9
+ method: 'PUT'
10
+ })
11
+ } catch (error) {
12
+ throw new SonarRequestException({ innerException: error as Error })
13
+ }
14
+
15
+ if (response.ok) {
16
+ const data = (await response.json()) as ChatMixData
17
+ if (data?.balance == null || data?.state == null) {
18
+ throw new SonarRequestException({ message: 'Missing required data in response' })
19
+ }
20
+ return data
21
+ } else {
22
+ const data = (await response.json()) as { Message?: string }
23
+ throw new SonarRequestException({ message: data.Message })
24
+ }
25
+ }
@@ -0,0 +1,24 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { ChatMixData } from '@/sonar/models/audio-settings/chatmix-data'
3
+
4
+ export async function requestChatMixState(sonarEndpoint: string): Promise<ChatMixData> {
5
+ const url = new URL(`${sonarEndpoint}/chatMix`)
6
+ let response: Response
7
+
8
+ try {
9
+ response = await fetch(url)
10
+ } catch (error) {
11
+ throw new SonarRequestException({ innerException: error as Error })
12
+ }
13
+
14
+ if (response.ok) {
15
+ const data = (await response.json()) as ChatMixData
16
+ if (data?.balance == null || data?.state == null) {
17
+ throw new SonarRequestException({ message: 'Missing required data in response' })
18
+ }
19
+ return data
20
+ } else {
21
+ const data = await response.text()
22
+ throw new SonarRequestException({ innerException: new Error(data) })
23
+ }
24
+ }
@@ -0,0 +1,24 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { AudioMode } from '@/sonar/models/audio-settings/enums/audio-mode'
3
+
4
+ export async function changeAudioMode(sonarEndpoint: string, audioMode: AudioMode): Promise<AudioMode> {
5
+ let response: Response
6
+ const url = new URL(`${sonarEndpoint}/mode/${audioMode}`)
7
+ try {
8
+ response = await fetch(url, {
9
+ method: 'PUT'
10
+ })
11
+ } catch (error) {
12
+ throw new SonarRequestException({ innerException: error as Error })
13
+ }
14
+ if (response.ok) {
15
+ const data = await response.json()
16
+ if (data !== audioMode) {
17
+ throw new SonarRequestException({ message: 'Returned audio mode does not match requested mode' })
18
+ }
19
+ return data as AudioMode
20
+ } else {
21
+ const data = await response.text()
22
+ throw new SonarRequestException({ innerException: new Error(data) })
23
+ }
24
+ }
@@ -0,0 +1,24 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import { AudioMode } from '@/sonar/models/audio-settings/enums/audio-mode'
3
+
4
+ export async function requestAudioMode(sonarEndpoint: string): Promise<AudioMode> {
5
+ let response: Response
6
+ const url = new URL(`${sonarEndpoint}/mode`)
7
+
8
+ try {
9
+ response = await fetch(url)
10
+ } catch (error) {
11
+ throw new SonarRequestException({ innerException: error as Error })
12
+ }
13
+
14
+ if (response.ok) {
15
+ const data = (await response.json()) as AudioMode
16
+ if (Object.values(AudioMode).includes(data)) {
17
+ return data
18
+ }
19
+ throw new SonarRequestException({ message: 'Received unhandled audio mode from Sonar server' })
20
+ } else {
21
+ const data = await response.text()
22
+ throw new SonarRequestException({ innerException: new Error(data) })
23
+ }
24
+ }
@@ -0,0 +1,25 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { Config } from '@/sonar/models/config/config'
3
+
4
+ export async function changeSelectedConfig(sonarAddress: string, configId: string): Promise<Config> {
5
+ let response: Response
6
+
7
+ try {
8
+ response = await fetch(`${sonarAddress}/configs/${configId}/select`, {
9
+ method: 'PUT'
10
+ })
11
+ } catch (error) {
12
+ throw new SonarRequestException({ innerException: error as Error })
13
+ }
14
+
15
+ if (response.ok) {
16
+ const data = (await response.json()) as Config
17
+ if (!data?.id) {
18
+ throw new SonarRequestException({ message: 'Missing required data in response' })
19
+ }
20
+ return data
21
+ } else {
22
+ const data = (await response.json()) as { error: string }
23
+ throw new SonarRequestException({ innerException: new Error(data?.error ?? data) })
24
+ }
25
+ }
@@ -0,0 +1,24 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { Config } from '@/sonar/models/config/config'
3
+ import type { VirtualAudioDevice } from '@/sonar/models/config/enums/VirtualAudioDevice'
4
+
5
+ export async function requestConfigs(sonarAddress: string, channel: VirtualAudioDevice): Promise<Config[]> {
6
+ let response: Response
7
+
8
+ try {
9
+ response = await fetch(`${sonarAddress}/configs?vad=${channel}`)
10
+ } catch (error) {
11
+ throw new SonarRequestException({ innerException: error as Error })
12
+ }
13
+
14
+ if (response.ok) {
15
+ const data = (await response.json()) as Config[]
16
+ if (!Array.isArray(data)) {
17
+ throw new SonarRequestException({ message: 'Missing required data in response' })
18
+ }
19
+ return data
20
+ } else {
21
+ const data = (await response.json()) as { error: string }
22
+ throw new SonarRequestException({ innerException: new Error(data?.error ?? data) })
23
+ }
24
+ }
@@ -0,0 +1,22 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { Config } from '@/sonar/models/config/config'
3
+ export async function requestSelectedConfigs(sonarAddress: string): Promise<Config[]> {
4
+ let response: Response
5
+
6
+ try {
7
+ response = await fetch(`${sonarAddress}/configs/selected`)
8
+ } catch (error) {
9
+ throw new SonarRequestException({ innerException: error as Error })
10
+ }
11
+
12
+ if (response.ok) {
13
+ const data = (await response.json()) as Config[]
14
+ if (!Array.isArray(data)) {
15
+ throw new SonarRequestException({ message: 'Missing required data in response' })
16
+ }
17
+ return data
18
+ } else {
19
+ const data = (await response.json()) as { error: string }
20
+ throw new SonarRequestException({ innerException: new Error(data?.error ?? data) })
21
+ }
22
+ }
@@ -0,0 +1,27 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { SonarChannel } from '@/sonar/models/audio-settings/enums/sonar-channel'
3
+ import type { VolumeSettingsClassic } from '@/sonar/models/audio-settings/volume-settings-classic'
4
+
5
+ export async function changeVolumeLevelClassic(
6
+ sonarEndpoint: string,
7
+ volume: number,
8
+ deviceRole: SonarChannel
9
+ ): Promise<VolumeSettingsClassic> {
10
+ let response: Response
11
+ try {
12
+ const url = new URL(`${sonarEndpoint}/volumeSettings/classic/${deviceRole}/volume/${volume}`)
13
+ response = await fetch(url, { method: 'PUT' })
14
+ } catch (error) {
15
+ throw new SonarRequestException({ innerException: error as Error })
16
+ }
17
+ if (response.ok) {
18
+ const data = (await response.json()) as VolumeSettingsClassic
19
+ if (data?.masters?.classic == null) {
20
+ throw new SonarRequestException({ innerException: new Error('Missing required data in response.') })
21
+ }
22
+ return data
23
+ } else {
24
+ const data = (await response.json()) as { error: string }
25
+ throw new SonarRequestException({ innerException: new Error(data?.error ?? data) })
26
+ }
27
+ }
@@ -0,0 +1,29 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { SonarChannel } from '@/sonar/models/audio-settings/enums/sonar-channel'
3
+ import type { StreamingPath } from '@/sonar/models/audio-settings/enums/streaming-path'
4
+ import type { VolumeSettingsStreamer } from '@/sonar/models/audio-settings/volume-settings-streamer'
5
+
6
+ export async function changeVolumeLevelStreamer(
7
+ sonarEndpoint: string,
8
+ volume: number,
9
+ channel: SonarChannel,
10
+ path: StreamingPath
11
+ ): Promise<VolumeSettingsStreamer> {
12
+ let response: Response
13
+ try {
14
+ const url = new URL(`${sonarEndpoint}/volumeSettings/streamer/${path}/${channel}/volume/${volume}`)
15
+ response = await fetch(url, { method: 'PUT' })
16
+ } catch (error) {
17
+ throw new SonarRequestException({ innerException: error as Error })
18
+ }
19
+ if (response.ok) {
20
+ const data = (await response.json()) as VolumeSettingsStreamer
21
+ if (data?.masters?.stream == null) {
22
+ throw new SonarRequestException({ innerException: new Error('Missing required data in response.') })
23
+ }
24
+ return data
25
+ } else {
26
+ const data = (await response.json()) as { error: string }
27
+ throw new SonarRequestException({ innerException: new Error(data?.error ?? data) })
28
+ }
29
+ }
@@ -0,0 +1,27 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { SonarChannel } from '@/sonar/models/audio-settings/enums/sonar-channel'
3
+ import type { VolumeSettingsClassic } from '@/sonar/models/audio-settings/volume-settings-classic'
4
+
5
+ export async function changeVolumeMuteClassic(
6
+ sonarEndpoint: string,
7
+ isMuted: boolean,
8
+ deviceRole: SonarChannel
9
+ ): Promise<VolumeSettingsClassic> {
10
+ let response: Response
11
+ try {
12
+ const url = new URL(`${sonarEndpoint}/volumeSettings/classic/${deviceRole}/mute/${isMuted}`)
13
+ response = await fetch(url, { method: 'PUT' })
14
+ } catch (error) {
15
+ throw new SonarRequestException({ innerException: error as Error })
16
+ }
17
+ if (response.ok) {
18
+ const data = (await response.json()) as VolumeSettingsClassic
19
+ if (data?.masters?.classic == null) {
20
+ throw new SonarRequestException({ innerException: new Error('Missing required data in response.') })
21
+ }
22
+ return data
23
+ } else {
24
+ const data = (await response.json()) as { error: string }
25
+ throw new SonarRequestException({ innerException: new Error(data?.error ?? data) })
26
+ }
27
+ }
@@ -0,0 +1,29 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { SonarChannel } from '@/sonar/models/audio-settings/enums/sonar-channel'
3
+ import type { StreamingPath } from '@/sonar/models/audio-settings/enums/streaming-path'
4
+ import type { VolumeSettingsStreamer } from '@/sonar/models/audio-settings/volume-settings-streamer'
5
+
6
+ export async function changeVolumeMuteStreamer(
7
+ sonarEndpoint: string,
8
+ isMuted: boolean,
9
+ deviceRole: SonarChannel,
10
+ path: StreamingPath
11
+ ): Promise<VolumeSettingsStreamer> {
12
+ let response: Response
13
+ try {
14
+ const url = new URL(`${sonarEndpoint}/volumeSettings/streamer/${path}/${deviceRole}/isMuted/${isMuted}`)
15
+ response = await fetch(url, { method: 'PUT' })
16
+ } catch (error) {
17
+ throw new SonarRequestException({ innerException: error as Error })
18
+ }
19
+ if (response.ok) {
20
+ const data = (await response.json()) as VolumeSettingsStreamer
21
+ if (data?.masters?.stream == null) {
22
+ throw new SonarRequestException({ innerException: new Error('Missing required data in response.') })
23
+ }
24
+ return data
25
+ } else {
26
+ const data = (await response.json()) as { error: string }
27
+ throw new SonarRequestException({ innerException: new Error(data?.error ?? data) })
28
+ }
29
+ }
@@ -0,0 +1,22 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { VolumeSettingsClassic } from '@/sonar/models/audio-settings/volume-settings-classic'
3
+
4
+ export async function requestVolumeSettingsClassic(sonarEndpoint: string): Promise<VolumeSettingsClassic> {
5
+ let response: Response
6
+ try {
7
+ const url = new URL(`${sonarEndpoint}/volumeSettings/classic`)
8
+ response = await fetch(url)
9
+ } catch (error) {
10
+ throw new SonarRequestException({ innerException: error as Error })
11
+ }
12
+ if (response.ok) {
13
+ const data = (await response.json()) as VolumeSettingsClassic
14
+ if (data?.masters?.classic == null) {
15
+ throw new SonarRequestException({ innerException: new Error('Missing required data in response.') })
16
+ }
17
+ return data
18
+ } else {
19
+ const data = (await response.json()) as { error: string }
20
+ throw new SonarRequestException({ innerException: new Error(data?.error ?? data) })
21
+ }
22
+ }
@@ -0,0 +1,22 @@
1
+ import { SonarRequestException } from '@/exceptions'
2
+ import type { VolumeSettingsStreamer } from '@/sonar/models/audio-settings/volume-settings-streamer'
3
+
4
+ export async function requestVolumeSettingsStreamer(sonarEndpoint: string): Promise<VolumeSettingsStreamer> {
5
+ let response: Response
6
+ try {
7
+ const url = new URL(`${sonarEndpoint}/volumeSettings/streamer`)
8
+ response = await fetch(url)
9
+ } catch (error) {
10
+ throw new SonarRequestException({ innerException: error as Error })
11
+ }
12
+ if (response.ok) {
13
+ const data = (await response.json()) as VolumeSettingsStreamer
14
+ if (data?.masters?.stream == null) {
15
+ throw new SonarRequestException({ innerException: new Error('Missing required data in response.') })
16
+ }
17
+ return data
18
+ } else {
19
+ const data = (await response.json()) as { error: string }
20
+ throw new SonarRequestException({ innerException: new Error(data?.error ?? data) })
21
+ }
22
+ }
@@ -0,0 +1,7 @@
1
+ import type { DeviceFlow } from '@/enums'
2
+
3
+ export type AudioDevice = {
4
+ id: string
5
+ name: string
6
+ type: DeviceFlow
7
+ }
@@ -0,0 +1,7 @@
1
+ import type { DeviceChannel } from '@/enums'
2
+
3
+ export type ChangedDevice = {
4
+ deviceId: string
5
+ deviceChannel: Exclude<DeviceChannel, DeviceChannel.Output>
6
+ isRunning: boolean
7
+ }
@@ -0,0 +1,4 @@
1
+ export type ChannelVolumeClassic = {
2
+ volume: number
3
+ isMuted: boolean
4
+ }
@@ -0,0 +1,4 @@
1
+ export type ChannelVolumeStreamerPath = {
2
+ volume: number
3
+ isMuted: boolean
4
+ }
@@ -0,0 +1,6 @@
1
+ import type { StreamerPath } from '@/enums'
2
+ import type { ChannelVolumeStreamerPath } from '@/types/channel-volume-streamer-path'
3
+
4
+ export type ChannelVolumeStreamer = {
5
+ [K in StreamerPath]: ChannelVolumeStreamerPath
6
+ }
@@ -0,0 +1,8 @@
1
+ import type { AudioChannel } from '@/enums'
2
+ import type { ChannelVolumeClassic } from '@/types/channel-volume-classic'
3
+
4
+ export type ChannelVolumesClassic = {
5
+ [AudioChannel.Master]: ChannelVolumeClassic
6
+ } & {
7
+ [K in Exclude<AudioChannel, 'master'>]?: ChannelVolumeClassic
8
+ }
@@ -0,0 +1,8 @@
1
+ import type { AudioChannel } from '@/enums'
2
+ import type { ChannelVolumeStreamer } from '@/types/channel-volume-streamer'
3
+
4
+ export type ChannelVolumesStreamer = {
5
+ [AudioChannel.Master]: ChannelVolumeStreamer
6
+ } & {
7
+ [K in AudioChannel]?: ChannelVolumeStreamer
8
+ }
@@ -0,0 +1,7 @@
1
+ import type { ChatMixState } from '@/enums'
2
+
3
+ export type ChatMixData = {
4
+ chatBalance: number
5
+ state: ChatMixState
6
+ isEnabled: boolean
7
+ }
@@ -0,0 +1,9 @@
1
+ import type { ProfileChannel } from '@/enums'
2
+
3
+ export type ProfileOption = {
4
+ id: string
5
+ name: string
6
+ isFavorite: boolean
7
+ channel: ProfileChannel
8
+ image?: string
9
+ }