@eka-care/ekascribe-ts-sdk 1.4.39 → 1.4.40
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/dist/api/config/get-voice-api-v2-config.d.ts +2 -0
- package/dist/api/config/get-voice-api-v2-config.js +26 -0
- package/dist/api/config/patch-voice-api-v2-config.d.ts +3 -0
- package/dist/api/config/patch-voice-api-v2-config.js +28 -0
- package/dist/api/post-cog-init.js +2 -1
- package/dist/api/template-sections/delete-v1-template-section.d.ts +3 -0
- package/dist/api/template-sections/delete-v1-template-section.js +28 -0
- package/dist/api/template-sections/get-v1-template-sections.d.ts +3 -0
- package/dist/api/template-sections/get-v1-template-sections.js +28 -0
- package/dist/api/template-sections/patch-v1-template-section.d.ts +3 -0
- package/dist/api/template-sections/patch-v1-template-section.js +37 -0
- package/dist/api/template-sections/post-v1-template-section.d.ts +3 -0
- package/dist/api/template-sections/post-v1-template-section.js +36 -0
- package/dist/api/templates/cook-v1-medai-ai-create-template.d.ts +3 -0
- package/dist/api/templates/cook-v1-medai-ai-create-template.js +26 -0
- package/dist/api/templates/delete-v1-template.d.ts +3 -0
- package/dist/api/templates/delete-v1-template.js +28 -0
- package/dist/api/templates/get-v1-templates.d.ts +3 -0
- package/dist/api/templates/get-v1-templates.js +28 -0
- package/dist/api/templates/patch-v1-template.d.ts +3 -0
- package/dist/api/templates/patch-v1-template.js +34 -0
- package/dist/api/templates/post-transaction-convert-to-template.d.ts +3 -0
- package/dist/api/templates/post-transaction-convert-to-template.js +29 -0
- package/dist/api/templates/post-v1-template.d.ts +3 -0
- package/dist/api/templates/post-v1-template.js +34 -0
- package/dist/api/transaction/get-transaction-history.d.ts +5 -0
- package/dist/api/transaction/get-transaction-history.js +28 -0
- package/dist/api/transaction/get-voice-api-v2-config.d.ts +2 -0
- package/dist/api/transaction/get-voice-api-v2-config.js +26 -0
- package/dist/api/transaction/get-voice-api-v3-status.d.ts +54 -0
- package/dist/api/transaction/get-voice-api-v3-status.js +26 -0
- package/dist/api/transaction/patch-transaction-status.d.ts +4 -0
- package/dist/api/transaction/patch-transaction-status.js +43 -0
- package/dist/api/transaction/post-transaction-commit.d.ts +3 -0
- package/dist/api/transaction/post-transaction-commit.js +32 -0
- package/dist/api/transaction/post-transaction-init.d.ts +3 -0
- package/dist/api/transaction/post-transaction-init.js +40 -0
- package/dist/api/transaction/post-transaction-stop.d.ts +3 -0
- package/dist/api/transaction/post-transaction-stop.js +32 -0
- package/dist/audio-chunker/vad-web.js +0 -3
- package/dist/constants/types.d.ts +116 -2
- package/dist/fetch-client/helper.d.ts +6 -4
- package/dist/fetch-client/helper.js +18 -10
- package/dist/fetch-client/index.js +7 -2
- package/dist/index.d.ts +13 -2
- package/dist/index.js +68 -12
- package/dist/main/end-recording.js +2 -2
- package/dist/main/init-transaction.js +1 -1
- package/dist/main/pause-recording.js +1 -0
- package/dist/main/resume-recording.js +1 -0
- package/dist/main/retry-upload-recording.js +1 -1
- package/dist/main/start-recording.js +4 -1
- package/package.json +1 -1
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V2 } from '../../fetch-client/helper';
|
|
4
|
+
export const getConfigV2 = async () => {
|
|
5
|
+
try {
|
|
6
|
+
const options = {
|
|
7
|
+
method: 'GET',
|
|
8
|
+
headers: {
|
|
9
|
+
'Content-Type': 'application/json',
|
|
10
|
+
},
|
|
11
|
+
};
|
|
12
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V2()}/config/`, options);
|
|
13
|
+
const res = await response.json();
|
|
14
|
+
return {
|
|
15
|
+
...res,
|
|
16
|
+
code: response.status,
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
catch (error) {
|
|
20
|
+
console.log('Error in getConfigV2 api: ', error);
|
|
21
|
+
return {
|
|
22
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
23
|
+
message: `Failed to fetch initial configurations, ${error}`,
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
};
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V2 } from '../../fetch-client/helper';
|
|
4
|
+
const patchVoiceApiV2Config = async (request) => {
|
|
5
|
+
try {
|
|
6
|
+
const options = {
|
|
7
|
+
method: 'PATCH',
|
|
8
|
+
headers: {
|
|
9
|
+
'Content-Type': 'application/json',
|
|
10
|
+
},
|
|
11
|
+
body: JSON.stringify(request),
|
|
12
|
+
};
|
|
13
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V2()}/config/`, options);
|
|
14
|
+
const res = await response.json();
|
|
15
|
+
return {
|
|
16
|
+
...res,
|
|
17
|
+
code: response.status,
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
console.log('Error in getConfigV2 api: ', error);
|
|
22
|
+
return {
|
|
23
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
24
|
+
msg: `Failed to fetch initial configurations, ${error}`,
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
export default patchVoiceApiV2Config;
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import fetchWrapper from '../fetch-client';
|
|
2
|
+
import { GET_COG_HOST } from '../fetch-client/helper';
|
|
2
3
|
async function postCogInit() {
|
|
3
4
|
try {
|
|
4
5
|
const options = {
|
|
5
6
|
method: 'GET',
|
|
6
7
|
};
|
|
7
|
-
const respJson = await fetchWrapper(
|
|
8
|
+
const respJson = await fetchWrapper(`${GET_COG_HOST()}/credentials`, options);
|
|
8
9
|
const resp = await respJson.json();
|
|
9
10
|
return resp;
|
|
10
11
|
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V1 } from '../../fetch-client/helper';
|
|
4
|
+
async function deleteV1TemplateSection(section_id) {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const options = {
|
|
9
|
+
method: 'DELETE',
|
|
10
|
+
headers,
|
|
11
|
+
};
|
|
12
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V1()}/template/section/${section_id}`, options);
|
|
13
|
+
let res = await response.json();
|
|
14
|
+
res = {
|
|
15
|
+
...res,
|
|
16
|
+
code: response.status,
|
|
17
|
+
};
|
|
18
|
+
return res;
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
console.log('%c deleteV1TemplateSection -> error', 'color:#f5ce50', error);
|
|
22
|
+
return {
|
|
23
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
24
|
+
msg: `Something went wrong! ${error}`,
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
export default deleteV1TemplateSection;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V1 } from '../../fetch-client/helper';
|
|
4
|
+
async function getV1TemplateSections() {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const options = {
|
|
9
|
+
method: 'GET',
|
|
10
|
+
headers,
|
|
11
|
+
};
|
|
12
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V1()}/template/section`, options);
|
|
13
|
+
let res = await response.json();
|
|
14
|
+
res = {
|
|
15
|
+
...res,
|
|
16
|
+
code: response.status,
|
|
17
|
+
};
|
|
18
|
+
return res;
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
console.log('%c getV1TemplateSections -> error', 'color:#f5ce50', error);
|
|
22
|
+
return {
|
|
23
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
24
|
+
items: [],
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
export default getV1TemplateSections;
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { TPostV1TemplateSectionRequest, TPostV1TemplateSectionResponse } from '../../constants/types';
|
|
2
|
+
declare function patchV1TemplateSection({ section_id, title, desc, format, example, }: TPostV1TemplateSectionRequest): Promise<TPostV1TemplateSectionResponse>;
|
|
3
|
+
export default patchV1TemplateSection;
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V1 } from '../../fetch-client/helper';
|
|
4
|
+
async function patchV1TemplateSection({ section_id, title, desc, format, example, }) {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const raw = {
|
|
9
|
+
title,
|
|
10
|
+
desc,
|
|
11
|
+
format,
|
|
12
|
+
example,
|
|
13
|
+
};
|
|
14
|
+
const options = {
|
|
15
|
+
method: 'PATCH',
|
|
16
|
+
headers,
|
|
17
|
+
body: JSON.stringify(raw),
|
|
18
|
+
};
|
|
19
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V1()}/template/section/${section_id}`, options);
|
|
20
|
+
let res = await response.json();
|
|
21
|
+
res = {
|
|
22
|
+
...res,
|
|
23
|
+
code: response.status,
|
|
24
|
+
};
|
|
25
|
+
return res;
|
|
26
|
+
}
|
|
27
|
+
catch (error) {
|
|
28
|
+
console.log('%c patchV1TemplateSection -> error', 'color:#f5ce50', error);
|
|
29
|
+
return {
|
|
30
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
31
|
+
msg: `Something went wrong! ${error}`,
|
|
32
|
+
section_id: '',
|
|
33
|
+
action: 'updated',
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
export default patchV1TemplateSection;
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { TPostV1TemplateSectionRequest, TPostV1TemplateSectionResponse } from '../../constants/types';
|
|
2
|
+
declare function postV1TemplateSection({ title, desc, format, example, }: TPostV1TemplateSectionRequest): Promise<TPostV1TemplateSectionResponse>;
|
|
3
|
+
export default postV1TemplateSection;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V1 } from '../../fetch-client/helper';
|
|
4
|
+
async function postV1TemplateSection({ title, desc, format, example, }) {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const raw = {
|
|
9
|
+
title,
|
|
10
|
+
desc,
|
|
11
|
+
format,
|
|
12
|
+
example,
|
|
13
|
+
};
|
|
14
|
+
const options = {
|
|
15
|
+
method: 'POST',
|
|
16
|
+
headers,
|
|
17
|
+
body: JSON.stringify(raw),
|
|
18
|
+
};
|
|
19
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V1()}/template/section`, options);
|
|
20
|
+
let res = await response.json();
|
|
21
|
+
res = {
|
|
22
|
+
...res,
|
|
23
|
+
code: response.status,
|
|
24
|
+
};
|
|
25
|
+
return res;
|
|
26
|
+
}
|
|
27
|
+
catch (error) {
|
|
28
|
+
console.log('%c postV1TemplateSection -> error', 'color:#f5ce50', error);
|
|
29
|
+
return {
|
|
30
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
31
|
+
msg: `Something went wrong! ${error}`,
|
|
32
|
+
section_id: '',
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
export default postV1TemplateSection;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_COOK_HOST_V1 } from '../../fetch-client/helper';
|
|
4
|
+
async function cookV1MediaAiCreateTemplate(formData) {
|
|
5
|
+
try {
|
|
6
|
+
const options = {
|
|
7
|
+
method: 'POST',
|
|
8
|
+
body: formData,
|
|
9
|
+
};
|
|
10
|
+
const response = await fetchWrapper(`${GET_COOK_HOST_V1()}/medai/ai-create-template`, options, 60000);
|
|
11
|
+
let res = await response.json();
|
|
12
|
+
res = {
|
|
13
|
+
...res,
|
|
14
|
+
code: response.status,
|
|
15
|
+
};
|
|
16
|
+
return res;
|
|
17
|
+
}
|
|
18
|
+
catch (error) {
|
|
19
|
+
console.log('%c postV1Template -> error', 'color:#f5ce50', error);
|
|
20
|
+
return {
|
|
21
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
22
|
+
message: `Something went wrong! ${error}`,
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export default cookV1MediaAiCreateTemplate;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V1 } from '../../fetch-client/helper';
|
|
4
|
+
async function deleteV1Template(template_id) {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const options = {
|
|
9
|
+
method: 'DELETE',
|
|
10
|
+
headers,
|
|
11
|
+
};
|
|
12
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V1()}/template/${template_id}`, options);
|
|
13
|
+
let res = await response.json();
|
|
14
|
+
res = {
|
|
15
|
+
...res,
|
|
16
|
+
code: response.status,
|
|
17
|
+
};
|
|
18
|
+
return res;
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
console.log('%c deleteV1Template -> error', 'color:#f5ce50', error);
|
|
22
|
+
return {
|
|
23
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
24
|
+
msg: `Something went wrong! ${error}`,
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
export default deleteV1Template;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V1 } from '../../fetch-client/helper';
|
|
4
|
+
async function getV1Templates() {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const options = {
|
|
9
|
+
method: 'GET',
|
|
10
|
+
headers,
|
|
11
|
+
};
|
|
12
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V1()}/template`, options);
|
|
13
|
+
let res = await response.json();
|
|
14
|
+
res = {
|
|
15
|
+
...res,
|
|
16
|
+
code: response.status,
|
|
17
|
+
};
|
|
18
|
+
return res;
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
console.log('%c getV1Templates -> error', 'color:#f5ce50', error);
|
|
22
|
+
return {
|
|
23
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
24
|
+
items: [],
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
export default getV1Templates;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V1 } from '../../fetch-client/helper';
|
|
4
|
+
export async function patchV1Template({ template_id, title, desc, section_ids, }) {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const raw = {
|
|
9
|
+
title,
|
|
10
|
+
desc,
|
|
11
|
+
section_ids,
|
|
12
|
+
};
|
|
13
|
+
const options = {
|
|
14
|
+
method: 'PATCH',
|
|
15
|
+
headers,
|
|
16
|
+
body: JSON.stringify(raw),
|
|
17
|
+
};
|
|
18
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V1()}/template/${template_id}`, options);
|
|
19
|
+
let res = await response.json();
|
|
20
|
+
res = {
|
|
21
|
+
...res,
|
|
22
|
+
code: response.status,
|
|
23
|
+
};
|
|
24
|
+
return res;
|
|
25
|
+
}
|
|
26
|
+
catch (error) {
|
|
27
|
+
console.log('%c patchV1Template -> error', 'color:#f5ce50', error);
|
|
28
|
+
return {
|
|
29
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
30
|
+
msg: `Something went wrong! ${error}`,
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
export default patchV1Template;
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { TPostV1ConvertToTemplateRequest, TPostV1ConvertToTemplateResponse } from '../../constants/types';
|
|
2
|
+
declare function postV1ConvertToTemplate({ txn_id, template_id, }: TPostV1ConvertToTemplateRequest): Promise<TPostV1ConvertToTemplateResponse>;
|
|
3
|
+
export default postV1ConvertToTemplate;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V1 } from '../../fetch-client/helper';
|
|
4
|
+
async function postV1ConvertToTemplate({ txn_id, template_id, }) {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const options = {
|
|
9
|
+
method: 'POST',
|
|
10
|
+
headers,
|
|
11
|
+
body: JSON.stringify({}),
|
|
12
|
+
};
|
|
13
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V1()}/transaction/${txn_id}/convert-to-template/${template_id}`, options, 60000);
|
|
14
|
+
let res = await response.json();
|
|
15
|
+
res = {
|
|
16
|
+
...res,
|
|
17
|
+
code: response.status,
|
|
18
|
+
};
|
|
19
|
+
return res;
|
|
20
|
+
}
|
|
21
|
+
catch (error) {
|
|
22
|
+
console.log('%c postV1ConvertToTemplate -> error', 'color:#f5ce50', error);
|
|
23
|
+
return {
|
|
24
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
25
|
+
message: `Something went wrong! ${error}`,
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
export default postV1ConvertToTemplate;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V1 } from '../../fetch-client/helper';
|
|
4
|
+
async function postV1Template({ title, desc, section_ids, }) {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const raw = {
|
|
9
|
+
title,
|
|
10
|
+
desc,
|
|
11
|
+
section_ids,
|
|
12
|
+
};
|
|
13
|
+
const options = {
|
|
14
|
+
method: 'POST',
|
|
15
|
+
headers,
|
|
16
|
+
body: JSON.stringify(raw),
|
|
17
|
+
};
|
|
18
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V1()}/template`, options);
|
|
19
|
+
let res = await response.json();
|
|
20
|
+
res = {
|
|
21
|
+
...res,
|
|
22
|
+
code: response.status,
|
|
23
|
+
};
|
|
24
|
+
return res;
|
|
25
|
+
}
|
|
26
|
+
catch (error) {
|
|
27
|
+
console.log('%c postV1Template -> error', 'color:#f5ce50', error);
|
|
28
|
+
return {
|
|
29
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
30
|
+
message: `Something went wrong! ${error}`,
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
export default postV1Template;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V2 } from '../../fetch-client/helper';
|
|
4
|
+
// TODO: pagination changes
|
|
5
|
+
const getTransactionHistory = async ({ txn_count, }) => {
|
|
6
|
+
try {
|
|
7
|
+
const headers = new Headers();
|
|
8
|
+
headers.append('Content-Type', 'application/json');
|
|
9
|
+
const options = {
|
|
10
|
+
method: 'GET',
|
|
11
|
+
headers,
|
|
12
|
+
};
|
|
13
|
+
const responseJson = await fetchWrapper(`${GET_EKA_VOICE_HOST_V2()}/transaction/history?count=${txn_count}`, options);
|
|
14
|
+
const response = await responseJson.json();
|
|
15
|
+
return {
|
|
16
|
+
data: response.data,
|
|
17
|
+
status_code: responseJson.status,
|
|
18
|
+
message: `Past ${txn_count} transactions fetched successfully.`,
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
catch (error) {
|
|
22
|
+
return {
|
|
23
|
+
status_code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
24
|
+
message: `Something went wrong in fetching transactions. ${error}`,
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
export default getTransactionHistory;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V2 } from '../../fetch-client/helper';
|
|
4
|
+
export const getConfigV2 = async () => {
|
|
5
|
+
try {
|
|
6
|
+
const options = {
|
|
7
|
+
method: 'GET',
|
|
8
|
+
headers: {
|
|
9
|
+
'Content-Type': 'application/json',
|
|
10
|
+
},
|
|
11
|
+
};
|
|
12
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V2()}/config/`, options);
|
|
13
|
+
const res = await response.json();
|
|
14
|
+
return {
|
|
15
|
+
...res,
|
|
16
|
+
code: response.status,
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
catch (error) {
|
|
20
|
+
console.log('Error in getConfigV2 api: ', error);
|
|
21
|
+
return {
|
|
22
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
23
|
+
message: `Failed to fetch initial configurations, ${error}`,
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
};
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
export type TTemplateMessage = {
|
|
2
|
+
type: 'warning' | 'error';
|
|
3
|
+
code?: string;
|
|
4
|
+
msg: string;
|
|
5
|
+
};
|
|
6
|
+
export type TOutputSummary = {
|
|
7
|
+
template_id: string;
|
|
8
|
+
value?: string | null;
|
|
9
|
+
type: string;
|
|
10
|
+
name: string;
|
|
11
|
+
status: TTemplateStatus;
|
|
12
|
+
errors?: TTemplateMessage[];
|
|
13
|
+
warnings?: TTemplateMessage[];
|
|
14
|
+
};
|
|
15
|
+
export type TTemplateStatus = 'success' | 'partial_success' | 'failure';
|
|
16
|
+
type TAdditionalData = {
|
|
17
|
+
doctor: {
|
|
18
|
+
_id: string;
|
|
19
|
+
profile: {
|
|
20
|
+
personal: {
|
|
21
|
+
name: {
|
|
22
|
+
l: string;
|
|
23
|
+
f: string;
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
type TApiResponse = {
|
|
30
|
+
data: {
|
|
31
|
+
output?: TOutputSummary[];
|
|
32
|
+
audio_matrix?: {
|
|
33
|
+
quality: string;
|
|
34
|
+
};
|
|
35
|
+
additional_data?: TAdditionalData;
|
|
36
|
+
meta_data?: {
|
|
37
|
+
total_resources?: number;
|
|
38
|
+
total_parsed_resources?: number;
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
error?: {
|
|
42
|
+
code: string;
|
|
43
|
+
msg: string;
|
|
44
|
+
};
|
|
45
|
+
};
|
|
46
|
+
export type TGetStatusResponse = {
|
|
47
|
+
response?: TApiResponse | null;
|
|
48
|
+
status_code: number;
|
|
49
|
+
message?: string;
|
|
50
|
+
};
|
|
51
|
+
export declare const getVoiceApiV3Status: ({ txnId, }: {
|
|
52
|
+
txnId: string;
|
|
53
|
+
}) => Promise<TGetStatusResponse>;
|
|
54
|
+
export {};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V3 } from '../../fetch-client/helper';
|
|
4
|
+
export const getVoiceApiV3Status = async ({ txnId, }) => {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const options = {
|
|
9
|
+
method: 'GET',
|
|
10
|
+
headers,
|
|
11
|
+
};
|
|
12
|
+
// Use custom timeout for this API (16 seconds instead of default 5 seconds)
|
|
13
|
+
const getResponse = await fetchWrapper(`${GET_EKA_VOICE_HOST_V3()}/status/${txnId}`, options, 16000);
|
|
14
|
+
const response = await getResponse.json();
|
|
15
|
+
return {
|
|
16
|
+
response,
|
|
17
|
+
status_code: getResponse.status,
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
return {
|
|
22
|
+
status_code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
23
|
+
message: `Something went wrong! ${error}`,
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
};
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { TPatchTransactionError, TPatchTransactionRequest, TPostTransactionResponse } from '../../constants/types';
|
|
2
|
+
export declare const processingError: TPatchTransactionError;
|
|
3
|
+
declare const patchTransactionStatus: ({ sessionId, processing_status, processing_error, }: TPatchTransactionRequest) => Promise<TPostTransactionResponse>;
|
|
4
|
+
export default patchTransactionStatus;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V2 } from '../../fetch-client/helper';
|
|
4
|
+
export const processingError = {
|
|
5
|
+
error: {
|
|
6
|
+
type: '',
|
|
7
|
+
code: 'cancelled_by_user',
|
|
8
|
+
msg: 'Cancelled_by_user',
|
|
9
|
+
},
|
|
10
|
+
};
|
|
11
|
+
const patchTransactionStatus = async ({ sessionId, processing_status, processing_error, }) => {
|
|
12
|
+
try {
|
|
13
|
+
const headers = new Headers();
|
|
14
|
+
headers.append('Content-Type', 'application/json');
|
|
15
|
+
const raw = {
|
|
16
|
+
processing_status,
|
|
17
|
+
processing_error,
|
|
18
|
+
};
|
|
19
|
+
const options = {
|
|
20
|
+
method: 'PATCH',
|
|
21
|
+
headers,
|
|
22
|
+
body: JSON.stringify(raw),
|
|
23
|
+
};
|
|
24
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V2()}/transaction/${sessionId}`, options);
|
|
25
|
+
if (!response.ok) {
|
|
26
|
+
throw new Error(`Error: ${response.statusText}`);
|
|
27
|
+
}
|
|
28
|
+
let res = await response.json();
|
|
29
|
+
res = {
|
|
30
|
+
...res,
|
|
31
|
+
code: response.status,
|
|
32
|
+
};
|
|
33
|
+
return res;
|
|
34
|
+
}
|
|
35
|
+
catch (error) {
|
|
36
|
+
console.error('Patch transaction status api failed', error);
|
|
37
|
+
return {
|
|
38
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
39
|
+
message: `Something went wrong! ${error}`,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
export default patchTransactionStatus;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V2 } from '../../fetch-client/helper';
|
|
4
|
+
async function postTransactionCommit({ audioFiles, txnId, }) {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const raw = {
|
|
9
|
+
audio_files: audioFiles,
|
|
10
|
+
};
|
|
11
|
+
const options = {
|
|
12
|
+
method: 'POST',
|
|
13
|
+
headers,
|
|
14
|
+
body: JSON.stringify(raw),
|
|
15
|
+
};
|
|
16
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V2()}/transaction/commit/${txnId}`, options);
|
|
17
|
+
let res = await response.json();
|
|
18
|
+
res = {
|
|
19
|
+
...res,
|
|
20
|
+
code: response.status,
|
|
21
|
+
};
|
|
22
|
+
return res;
|
|
23
|
+
}
|
|
24
|
+
catch (error) {
|
|
25
|
+
console.log('%c Line:52 🥖 postTransactionInit -> error', 'color:#f5ce50', error);
|
|
26
|
+
return {
|
|
27
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
28
|
+
message: `Something went wrong! ${error}`,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
export default postTransactionCommit;
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { TPostTransactionInitRequest, TPostTransactionResponse } from '../../constants/types';
|
|
2
|
+
declare function postTransactionInit({ mode, txnId, s3Url, input_language, output_format_template, model_training_consent, auto_download, transfer, system_info, patient_details, }: TPostTransactionInitRequest): Promise<TPostTransactionResponse>;
|
|
3
|
+
export default postTransactionInit;
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V2 } from '../../fetch-client/helper';
|
|
4
|
+
async function postTransactionInit({ mode, txnId, s3Url, input_language, output_format_template, model_training_consent, auto_download, transfer, system_info, patient_details, }) {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const raw = {
|
|
9
|
+
mode,
|
|
10
|
+
s3_url: s3Url,
|
|
11
|
+
input_language,
|
|
12
|
+
output_format_template,
|
|
13
|
+
model_training_consent,
|
|
14
|
+
auto_download,
|
|
15
|
+
transfer,
|
|
16
|
+
system_info,
|
|
17
|
+
patient_details,
|
|
18
|
+
};
|
|
19
|
+
const options = {
|
|
20
|
+
method: 'POST',
|
|
21
|
+
headers,
|
|
22
|
+
body: JSON.stringify(raw),
|
|
23
|
+
};
|
|
24
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V2()}/transaction/init/${txnId}`, options);
|
|
25
|
+
let res = await response.json();
|
|
26
|
+
res = {
|
|
27
|
+
...res,
|
|
28
|
+
code: response.status,
|
|
29
|
+
};
|
|
30
|
+
return res;
|
|
31
|
+
}
|
|
32
|
+
catch (error) {
|
|
33
|
+
console.log('%c Line:52 🥖 postTransactionInit -> error', 'color:#f5ce50', error);
|
|
34
|
+
return {
|
|
35
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
36
|
+
message: `Something went wrong! ${error}`,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
export default postTransactionInit;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { SDK_STATUS_CODE } from '../../constants/constant';
|
|
2
|
+
import fetchWrapper from '../../fetch-client';
|
|
3
|
+
import { GET_EKA_VOICE_HOST_V2 } from '../../fetch-client/helper';
|
|
4
|
+
async function postTransactionStop({ txnId, audioFiles, }) {
|
|
5
|
+
try {
|
|
6
|
+
const headers = new Headers();
|
|
7
|
+
headers.append('Content-Type', 'application/json');
|
|
8
|
+
const raw = {
|
|
9
|
+
audio_files: audioFiles,
|
|
10
|
+
};
|
|
11
|
+
const options = {
|
|
12
|
+
method: 'POST',
|
|
13
|
+
headers,
|
|
14
|
+
body: JSON.stringify(raw),
|
|
15
|
+
};
|
|
16
|
+
const response = await fetchWrapper(`${GET_EKA_VOICE_HOST_V2()}/transaction/stop/${txnId}`, options);
|
|
17
|
+
let res = await response.json();
|
|
18
|
+
res = {
|
|
19
|
+
...res,
|
|
20
|
+
code: response.status,
|
|
21
|
+
};
|
|
22
|
+
return res;
|
|
23
|
+
}
|
|
24
|
+
catch (error) {
|
|
25
|
+
console.log('%c Line:52 🥖 postTransactionInit -> error', 'color:#f5ce50', error);
|
|
26
|
+
return {
|
|
27
|
+
code: SDK_STATUS_CODE.INTERNAL_SERVER_ERROR,
|
|
28
|
+
message: `Something went wrong! ${error}`,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
export default postTransactionStop;
|
|
@@ -125,9 +125,6 @@ class VadWebClient {
|
|
|
125
125
|
this.frame_size = FRAME_SIZE;
|
|
126
126
|
this.speech_pad_frames = PRE_SPEECH_PAD_FRAMES;
|
|
127
127
|
this.micVad = {};
|
|
128
|
-
// instantiate MicVad
|
|
129
|
-
// TODO: initialise this in start recording
|
|
130
|
-
// this.initVad();
|
|
131
128
|
}
|
|
132
129
|
/**
|
|
133
130
|
* Check for continuous silence and trigger periodic warnings
|
|
@@ -12,6 +12,16 @@ export type TGetConfigV2Response = {
|
|
|
12
12
|
selected_preferences?: TSelectedPreferences;
|
|
13
13
|
settings?: TConfigSettings;
|
|
14
14
|
model?: string;
|
|
15
|
+
my_templates?: string[];
|
|
16
|
+
user_details: {
|
|
17
|
+
fn: string;
|
|
18
|
+
mn: string;
|
|
19
|
+
ln: string;
|
|
20
|
+
dob: string;
|
|
21
|
+
gen: 'F' | 'M' | 'O';
|
|
22
|
+
s: string;
|
|
23
|
+
};
|
|
24
|
+
wid: string;
|
|
15
25
|
};
|
|
16
26
|
message?: string;
|
|
17
27
|
code?: number;
|
|
@@ -45,7 +55,7 @@ export type TStartRecordingRequest = {
|
|
|
45
55
|
model_training_consent: boolean;
|
|
46
56
|
transfer: string;
|
|
47
57
|
system_info: TSystemInfo;
|
|
48
|
-
patient_details
|
|
58
|
+
patient_details?: TPatientDetails;
|
|
49
59
|
};
|
|
50
60
|
export type TPatientDetails = {
|
|
51
61
|
username: string;
|
|
@@ -103,7 +113,7 @@ export type TPostTransactionInitRequest = {
|
|
|
103
113
|
auto_download: boolean;
|
|
104
114
|
model_training_consent: boolean;
|
|
105
115
|
system_info: TSystemInfo;
|
|
106
|
-
patient_details
|
|
116
|
+
patient_details?: TPatientDetails;
|
|
107
117
|
};
|
|
108
118
|
export type TPostTransactionCommitRequest = {
|
|
109
119
|
audioFiles: string[];
|
|
@@ -222,3 +232,107 @@ export type TFileUploadProgressCallback = (args: {
|
|
|
222
232
|
msg: string;
|
|
223
233
|
};
|
|
224
234
|
}) => void;
|
|
235
|
+
export interface TPostV1TemplateRequest {
|
|
236
|
+
title: string;
|
|
237
|
+
desc?: string;
|
|
238
|
+
section_ids: string[];
|
|
239
|
+
template_id?: string;
|
|
240
|
+
}
|
|
241
|
+
export interface TPostV1TemplateResponse {
|
|
242
|
+
code: number;
|
|
243
|
+
msg: string;
|
|
244
|
+
template_id?: string;
|
|
245
|
+
message?: string;
|
|
246
|
+
error?: {
|
|
247
|
+
code: string;
|
|
248
|
+
message: string;
|
|
249
|
+
};
|
|
250
|
+
}
|
|
251
|
+
export interface TTemplate {
|
|
252
|
+
id: string;
|
|
253
|
+
title: string;
|
|
254
|
+
desc: string;
|
|
255
|
+
section_ids: string[];
|
|
256
|
+
is_editable: boolean;
|
|
257
|
+
}
|
|
258
|
+
export interface TGetV1TemplatesResponse {
|
|
259
|
+
items: TTemplate[];
|
|
260
|
+
code: number;
|
|
261
|
+
error?: {
|
|
262
|
+
code: string;
|
|
263
|
+
message: string;
|
|
264
|
+
};
|
|
265
|
+
}
|
|
266
|
+
export type TPostCookV1MediaAiCreateTemplateResponse = {
|
|
267
|
+
title: string;
|
|
268
|
+
desc: string;
|
|
269
|
+
sections: TSection[];
|
|
270
|
+
code: number;
|
|
271
|
+
message: string;
|
|
272
|
+
};
|
|
273
|
+
export interface TPostV1TemplateSectionRequest {
|
|
274
|
+
title: string;
|
|
275
|
+
desc?: string;
|
|
276
|
+
format?: 'P' | 'B';
|
|
277
|
+
example?: string;
|
|
278
|
+
section_id?: string;
|
|
279
|
+
}
|
|
280
|
+
export interface TPostV1TemplateSectionResponse {
|
|
281
|
+
msg: string;
|
|
282
|
+
section_id: string;
|
|
283
|
+
code: number;
|
|
284
|
+
action: 'updated' | 'created_custom';
|
|
285
|
+
error?: {
|
|
286
|
+
code: string;
|
|
287
|
+
message: string;
|
|
288
|
+
};
|
|
289
|
+
}
|
|
290
|
+
export interface TSection {
|
|
291
|
+
id: string;
|
|
292
|
+
title: string;
|
|
293
|
+
desc: string;
|
|
294
|
+
format: 'P' | 'B';
|
|
295
|
+
example: string;
|
|
296
|
+
default?: boolean;
|
|
297
|
+
parent_section_id?: string;
|
|
298
|
+
}
|
|
299
|
+
export interface TGetV1TemplateSectionsResponse {
|
|
300
|
+
items: TSection[];
|
|
301
|
+
code: number;
|
|
302
|
+
error?: {
|
|
303
|
+
code: string;
|
|
304
|
+
message: string;
|
|
305
|
+
};
|
|
306
|
+
}
|
|
307
|
+
export type TPatchVoiceApiV2ConfigRequest = {
|
|
308
|
+
auto_download?: boolean;
|
|
309
|
+
default_languages?: string[];
|
|
310
|
+
my_templates?: string[];
|
|
311
|
+
scribe_enabled?: boolean;
|
|
312
|
+
};
|
|
313
|
+
export interface TPatchVoiceApiV2ConfigResponse extends TPatchVoiceApiV2ConfigRequest {
|
|
314
|
+
msg: string;
|
|
315
|
+
code: number;
|
|
316
|
+
error?: {
|
|
317
|
+
code: string;
|
|
318
|
+
message: string;
|
|
319
|
+
};
|
|
320
|
+
}
|
|
321
|
+
export type TPostV1ConvertToTemplateRequest = {
|
|
322
|
+
txn_id: string;
|
|
323
|
+
template_id: string;
|
|
324
|
+
};
|
|
325
|
+
export type TPostV1ConvertToTemplateResponse = {
|
|
326
|
+
status: 'success' | 'failed';
|
|
327
|
+
message: string;
|
|
328
|
+
txn_id: string;
|
|
329
|
+
template_id: string;
|
|
330
|
+
b_id: string;
|
|
331
|
+
code: number;
|
|
332
|
+
msg: string;
|
|
333
|
+
error?: {
|
|
334
|
+
code: string;
|
|
335
|
+
message: string;
|
|
336
|
+
display_message: string;
|
|
337
|
+
};
|
|
338
|
+
};
|
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
declare const setEnv: ({ env, clientId, auth_token, }: {
|
|
2
2
|
env?: "PROD" | "DEV";
|
|
3
3
|
clientId?: string;
|
|
4
|
-
auth_token
|
|
4
|
+
auth_token?: string;
|
|
5
5
|
}) => void;
|
|
6
|
-
export declare const GET_EKA_HOST: () => string;
|
|
7
6
|
export declare const GET_CLIENT_ID: () => string;
|
|
8
7
|
export declare const GET_AUTH_TOKEN: () => string;
|
|
9
|
-
export declare const
|
|
10
|
-
export declare const
|
|
8
|
+
export declare const GET_EKA_VOICE_HOST_V1: () => string;
|
|
9
|
+
export declare const GET_EKA_VOICE_HOST_V2: () => string;
|
|
10
|
+
export declare const GET_EKA_VOICE_HOST_V3: () => string;
|
|
11
|
+
export declare const GET_COOK_HOST_V1: () => string;
|
|
12
|
+
export declare const GET_COG_HOST: () => string;
|
|
11
13
|
export default setEnv;
|
|
@@ -1,12 +1,16 @@
|
|
|
1
1
|
const DEV = {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
2
|
+
COG_HOST: 'https://cog.dev.eka.care',
|
|
3
|
+
EKA_VOICE_HOST_V1: 'https://v2rxbe.dev.eka.care/voice/api/v1',
|
|
4
|
+
EKA_VOICE_HOST_V2: 'https://v2rxbe.dev.eka.care/voice/api/v2',
|
|
5
|
+
EKA_VOICE_HOST_V3: 'https://v2rxbe.dev.eka.care/voice/api/v3',
|
|
6
|
+
COOK_V1: ' https://deepthought-genai.dev.eka.care/api/v1',
|
|
5
7
|
};
|
|
6
8
|
const PROD = {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
9
|
+
COG_HOST: 'https://cog.eka.care',
|
|
10
|
+
EKA_VOICE_HOST_V1: 'https://api.eka.care/voice/api/v1',
|
|
11
|
+
EKA_VOICE_HOST_V2: 'https://api.eka.care/voice/api/v2',
|
|
12
|
+
EKA_VOICE_HOST_V3: 'https://api.eka.care/voice/api/v3',
|
|
13
|
+
COOK_V1: ' https://cook.eka.care/api/v1',
|
|
10
14
|
};
|
|
11
15
|
let envVar = PROD;
|
|
12
16
|
let client_id = 'doc-web';
|
|
@@ -18,11 +22,15 @@ const setEnv = ({ env, clientId, auth_token, }) => {
|
|
|
18
22
|
if (clientId) {
|
|
19
23
|
client_id = clientId;
|
|
20
24
|
}
|
|
21
|
-
|
|
25
|
+
if (auth_token) {
|
|
26
|
+
auth = auth_token;
|
|
27
|
+
}
|
|
22
28
|
};
|
|
23
|
-
export const GET_EKA_HOST = () => envVar.EKA_HOST;
|
|
24
29
|
export const GET_CLIENT_ID = () => client_id;
|
|
25
30
|
export const GET_AUTH_TOKEN = () => auth;
|
|
26
|
-
export const
|
|
27
|
-
export const
|
|
31
|
+
export const GET_EKA_VOICE_HOST_V1 = () => envVar.EKA_VOICE_HOST_V1;
|
|
32
|
+
export const GET_EKA_VOICE_HOST_V2 = () => envVar.EKA_VOICE_HOST_V2;
|
|
33
|
+
export const GET_EKA_VOICE_HOST_V3 = () => envVar.EKA_VOICE_HOST_V3;
|
|
34
|
+
export const GET_COOK_HOST_V1 = () => envVar.COOK_V1;
|
|
35
|
+
export const GET_COG_HOST = () => envVar.COG_HOST;
|
|
28
36
|
export default setEnv;
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import { GET_CLIENT_ID, GET_AUTH_TOKEN } from './helper';
|
|
2
|
-
const API_TIMEOUT_MS =
|
|
2
|
+
const API_TIMEOUT_MS = 10000;
|
|
3
3
|
export default async function fetchWrapper(url, options = {}, timeoutMs = API_TIMEOUT_MS) {
|
|
4
4
|
const controller = new AbortController();
|
|
5
5
|
let timeoutId = null;
|
|
6
6
|
try {
|
|
7
7
|
// Set up timeout
|
|
8
8
|
timeoutId = setTimeout(() => {
|
|
9
|
+
console.log('request aborted due to timeout');
|
|
9
10
|
controller.abort();
|
|
10
11
|
}, timeoutMs);
|
|
11
12
|
const newHeaders = new Headers(options.headers);
|
|
@@ -21,10 +22,14 @@ export default async function fetchWrapper(url, options = {}, timeoutMs = API_TI
|
|
|
21
22
|
signal: controller.signal,
|
|
22
23
|
credentials: 'include',
|
|
23
24
|
});
|
|
25
|
+
console.log(response, response.status, 'response in fetch wrapper - SDK');
|
|
26
|
+
if (response.status === 401 || response.status === 403) {
|
|
27
|
+
console.log('unauthorized - fetch wrapper - SDK', response.status);
|
|
28
|
+
}
|
|
24
29
|
return response;
|
|
25
30
|
}
|
|
26
31
|
catch (error) {
|
|
27
|
-
console.error(error);
|
|
32
|
+
console.error(error, 'error in fetch wrapper - SDK');
|
|
28
33
|
throw error;
|
|
29
34
|
}
|
|
30
35
|
finally {
|
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { TGetStatusResponse } from './api/get-voice-api-v3-status';
|
|
2
|
-
import { TEndRecordingResponse, TErrorCallback, TFileUploadProgressCallback, TGetTransactionHistoryResponse, TPatchTransactionRequest, TPostTransactionResponse, TStartRecordingRequest } from './constants/types';
|
|
1
|
+
import { TGetStatusResponse } from './api/transaction/get-voice-api-v3-status';
|
|
2
|
+
import { TEndRecordingResponse, TErrorCallback, TFileUploadProgressCallback, TGetTransactionHistoryResponse, TPatchTransactionRequest, TPatchVoiceApiV2ConfigRequest, TPostTransactionResponse, TPostV1ConvertToTemplateRequest, TPostV1TemplateRequest, TPostV1TemplateSectionRequest, TStartRecordingRequest } from './constants/types';
|
|
3
3
|
declare class EkaScribe {
|
|
4
4
|
private static instance;
|
|
5
5
|
private vadInstance;
|
|
@@ -51,6 +51,17 @@ declare class EkaScribe {
|
|
|
51
51
|
short_thsld: number;
|
|
52
52
|
long_thsld: number;
|
|
53
53
|
}): void;
|
|
54
|
+
getAllTemplates(): Promise<import("./constants/types").TGetV1TemplatesResponse>;
|
|
55
|
+
createTemplate(template: TPostV1TemplateRequest): Promise<import("./constants/types").TPostV1TemplateResponse>;
|
|
56
|
+
updateTemplate(template: TPostV1TemplateRequest): Promise<import("./constants/types").TPostV1TemplateResponse>;
|
|
57
|
+
deleteTemplate(template_id: string): Promise<import("./constants/types").TPostV1TemplateResponse>;
|
|
58
|
+
aiGenerateTemplate(formData: FormData): Promise<import("./constants/types").TPostCookV1MediaAiCreateTemplateResponse>;
|
|
59
|
+
updateConfig(request: TPatchVoiceApiV2ConfigRequest): Promise<any>;
|
|
60
|
+
getAllTemplateSections(): Promise<import("./constants/types").TGetV1TemplateSectionsResponse>;
|
|
61
|
+
createTemplateSection(templateSection: TPostV1TemplateSectionRequest): Promise<import("./constants/types").TPostV1TemplateSectionResponse>;
|
|
62
|
+
updateTemplateSection(templateSection: TPostV1TemplateSectionRequest): Promise<import("./constants/types").TPostV1TemplateSectionResponse>;
|
|
63
|
+
deleteTemplateSection(section_id: string): Promise<import("./constants/types").TPostV1TemplateSectionResponse>;
|
|
64
|
+
postTransactionConvertToTemplate({ txn_id, template_id }: TPostV1ConvertToTemplateRequest): Promise<import("./constants/types").TPostV1ConvertToTemplateResponse>;
|
|
54
65
|
}
|
|
55
66
|
export declare const getEkaScribeInstance: ({ access_token, env, clientId, }: {
|
|
56
67
|
access_token?: string;
|
package/dist/index.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
// ekascribe main Class having all the methods - Entry point
|
|
2
|
-
import { getConfigV2 } from './api/get-voice-api-v2-config';
|
|
3
|
-
import { getVoiceApiV3Status } from './api/get-voice-api-v3-status';
|
|
4
|
-
import patchTransactionStatus from './api/patch-transaction-status';
|
|
5
|
-
import postTransactionCommit from './api/post-transaction-commit';
|
|
2
|
+
import { getConfigV2 } from './api/config/get-voice-api-v2-config';
|
|
3
|
+
import { getVoiceApiV3Status } from './api/transaction/get-voice-api-v3-status';
|
|
4
|
+
import patchTransactionStatus from './api/transaction/patch-transaction-status';
|
|
5
|
+
import postTransactionCommit from './api/transaction/post-transaction-commit';
|
|
6
6
|
import AudioBufferManager from './audio-chunker/audio-buffer-manager';
|
|
7
7
|
import AudioFileManager from './audio-chunker/audio-file-manager';
|
|
8
8
|
import VadWebClient from './audio-chunker/vad-web';
|
|
@@ -16,7 +16,18 @@ import retryUploadFailedFiles from './main/retry-upload-recording';
|
|
|
16
16
|
import startVoiceRecording from './main/start-recording';
|
|
17
17
|
import EkaScribeStore from './store/store';
|
|
18
18
|
import initialiseTransaction from './main/init-transaction';
|
|
19
|
-
import getTransactionHistory from './api/get-transaction-history';
|
|
19
|
+
import getTransactionHistory from './api/transaction/get-transaction-history';
|
|
20
|
+
import getV1Templates from './api/templates/get-v1-templates';
|
|
21
|
+
import postV1Template from './api/templates/post-v1-template';
|
|
22
|
+
import patchV1Template from './api/templates/patch-v1-template';
|
|
23
|
+
import deleteV1Template from './api/templates/delete-v1-template';
|
|
24
|
+
import getV1TemplateSections from './api/template-sections/get-v1-template-sections';
|
|
25
|
+
import postV1TemplateSection from './api/template-sections/post-v1-template-section';
|
|
26
|
+
import patchV1TemplateSection from './api/template-sections/patch-v1-template-section';
|
|
27
|
+
import deleteV1TemplateSection from './api/template-sections/delete-v1-template-section';
|
|
28
|
+
import patchVoiceApiV2Config from './api/config/patch-voice-api-v2-config';
|
|
29
|
+
import cookV1MediaAiCreateTemplate from './api/templates/cook-v1-medai-ai-create-template';
|
|
30
|
+
import postV1ConvertToTemplate from './api/templates/post-transaction-convert-to-template';
|
|
20
31
|
class EkaScribe {
|
|
21
32
|
// Private constructor to prevent direct instantiation
|
|
22
33
|
constructor() {
|
|
@@ -50,16 +61,15 @@ class EkaScribe {
|
|
|
50
61
|
}
|
|
51
62
|
// Static method to get the singleton instance with optional initialization
|
|
52
63
|
static getInstance({ access_token, env, clientId, }) {
|
|
64
|
+
setEnv({
|
|
65
|
+
...(access_token ? { auth_token: access_token } : {}),
|
|
66
|
+
...(env ? { env } : {}),
|
|
67
|
+
...(clientId ? { clientId } : {}),
|
|
68
|
+
});
|
|
53
69
|
if (!EkaScribe.instance) {
|
|
54
70
|
EkaScribe.instance = new EkaScribe();
|
|
71
|
+
console.log('EkaScribe.instance', EkaScribe.instance);
|
|
55
72
|
// Initialize if params are provided
|
|
56
|
-
if (access_token) {
|
|
57
|
-
setEnv({
|
|
58
|
-
auth_token: access_token,
|
|
59
|
-
env,
|
|
60
|
-
clientId,
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
73
|
}
|
|
64
74
|
return EkaScribe.instance;
|
|
65
75
|
}
|
|
@@ -256,6 +266,52 @@ class EkaScribe {
|
|
|
256
266
|
long_thsld,
|
|
257
267
|
});
|
|
258
268
|
}
|
|
269
|
+
// Template SDK methods
|
|
270
|
+
async getAllTemplates() {
|
|
271
|
+
const templatesResponse = await getV1Templates();
|
|
272
|
+
return templatesResponse;
|
|
273
|
+
}
|
|
274
|
+
async createTemplate(template) {
|
|
275
|
+
const templatesResponse = await postV1Template(template);
|
|
276
|
+
return templatesResponse;
|
|
277
|
+
}
|
|
278
|
+
async updateTemplate(template) {
|
|
279
|
+
const templatesResponse = await patchV1Template(template);
|
|
280
|
+
return templatesResponse;
|
|
281
|
+
}
|
|
282
|
+
async deleteTemplate(template_id) {
|
|
283
|
+
const templatesResponse = await deleteV1Template(template_id);
|
|
284
|
+
return templatesResponse;
|
|
285
|
+
}
|
|
286
|
+
async aiGenerateTemplate(formData) {
|
|
287
|
+
const templatesResponse = await cookV1MediaAiCreateTemplate(formData);
|
|
288
|
+
return templatesResponse;
|
|
289
|
+
}
|
|
290
|
+
async updateConfig(request) {
|
|
291
|
+
const configResponse = await patchVoiceApiV2Config(request);
|
|
292
|
+
return configResponse;
|
|
293
|
+
}
|
|
294
|
+
// Template Section SDK methods
|
|
295
|
+
async getAllTemplateSections() {
|
|
296
|
+
const templateSectionsResponse = await getV1TemplateSections();
|
|
297
|
+
return templateSectionsResponse;
|
|
298
|
+
}
|
|
299
|
+
async createTemplateSection(templateSection) {
|
|
300
|
+
const templateSectionsResponse = await postV1TemplateSection(templateSection);
|
|
301
|
+
return templateSectionsResponse;
|
|
302
|
+
}
|
|
303
|
+
async updateTemplateSection(templateSection) {
|
|
304
|
+
const templateSectionsResponse = await patchV1TemplateSection(templateSection);
|
|
305
|
+
return templateSectionsResponse;
|
|
306
|
+
}
|
|
307
|
+
async deleteTemplateSection(section_id) {
|
|
308
|
+
const templateSectionsResponse = await deleteV1TemplateSection(section_id);
|
|
309
|
+
return templateSectionsResponse;
|
|
310
|
+
}
|
|
311
|
+
async postTransactionConvertToTemplate({ txn_id, template_id }) {
|
|
312
|
+
const convertToTemplateResponse = await postV1ConvertToTemplate({ txn_id, template_id });
|
|
313
|
+
return convertToTemplateResponse;
|
|
314
|
+
}
|
|
259
315
|
}
|
|
260
316
|
Object.defineProperty(EkaScribe, "instance", {
|
|
261
317
|
enumerable: true,
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import postTransactionCommit from '../api/post-transaction-commit';
|
|
2
|
-
import postTransactionStop from '../api/post-transaction-stop';
|
|
1
|
+
import postTransactionCommit from '../api/transaction/post-transaction-commit';
|
|
2
|
+
import postTransactionStop from '../api/transaction/post-transaction-stop';
|
|
3
3
|
import { OUTPUT_FORMAT, SDK_STATUS_CODE } from '../constants/constant';
|
|
4
4
|
import { ERROR_CODE } from '../constants/enums';
|
|
5
5
|
import EkaScribeStore from '../store/store';
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import postTransactionInit from '../api/post-transaction-init';
|
|
1
|
+
import postTransactionInit from '../api/transaction/post-transaction-init';
|
|
2
2
|
import { S3_BUCKET_NAME, SDK_STATUS_CODE } from '../constants/constant';
|
|
3
3
|
import { ERROR_CODE } from '../constants/enums';
|
|
4
4
|
import EkaScribeStore from '../store/store';
|
|
@@ -9,6 +9,7 @@ const pauseVoiceRecording = () => {
|
|
|
9
9
|
if (!fileManagerInstance || !audioBufferInstance || !vadInstance) {
|
|
10
10
|
throw new Error('Class instances are not initialized');
|
|
11
11
|
}
|
|
12
|
+
console.log(vadInstance, 'vad in pause recording');
|
|
12
13
|
vadInstance.pauseVad();
|
|
13
14
|
const txn_id = EkaScribeStore.txnID;
|
|
14
15
|
EkaScribeStore.sessionStatus[txn_id] = {
|
|
@@ -7,6 +7,7 @@ const resumeVoiceRecording = () => {
|
|
|
7
7
|
if (!vadInstance) {
|
|
8
8
|
throw new Error('VAD instance is not initialized');
|
|
9
9
|
}
|
|
10
|
+
console.log(vadInstance, 'vad in resume recording');
|
|
10
11
|
vadInstance.startVad();
|
|
11
12
|
const txn_id = EkaScribeStore.txnID;
|
|
12
13
|
EkaScribeStore.sessionStatus[txn_id] = {
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import postTransactionCommit from '../api/post-transaction-commit';
|
|
1
|
+
import postTransactionCommit from '../api/transaction/post-transaction-commit';
|
|
2
2
|
import { SDK_STATUS_CODE } from '../constants/constant';
|
|
3
3
|
import { ERROR_CODE } from '../constants/enums';
|
|
4
4
|
import EkaScribeStore from '../store/store';
|
|
@@ -14,9 +14,12 @@ const startVoiceRecording = async () => {
|
|
|
14
14
|
message: 'Microphone access is required to start recording. Please recheck access.',
|
|
15
15
|
};
|
|
16
16
|
}
|
|
17
|
-
|
|
17
|
+
await vadInstance?.initVad();
|
|
18
|
+
console.log(vadInstance, 'vad in start recording');
|
|
18
19
|
const micVad = vadInstance?.getMicVad();
|
|
20
|
+
console.log(micVad, 'mic vad in start recording');
|
|
19
21
|
const isVadLoading = vadInstance?.isVadLoading();
|
|
22
|
+
console.log(isVadLoading, 'is vad loading in start recording');
|
|
20
23
|
if (isVadLoading || !micVad || Object.keys(micVad).length === 0) {
|
|
21
24
|
// retry initiating vad once and if still is in loading return error
|
|
22
25
|
const reinitializeVadResponse = await vadInstance?.reinitializeVad();
|