Skip to content

Commit

Permalink
feat(issue): go back to classic way of doing jira requests as it is m…
Browse files Browse the repository at this point in the history
…ore reliable
  • Loading branch information
johannesjo committed Dec 19, 2024
1 parent a33de8c commit 264ced7
Showing 1 changed file with 50 additions and 50 deletions.
100 changes: 50 additions & 50 deletions src/app/features/issue/providers/jira/jira-api.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -467,27 +467,27 @@ export class JiraApiService {
transform: any,
jiraCfg: JiraCfg,
): Observable<any> {
if (!this._isExtension) {
return fromPromise(
fetch(url, requestInit)
.then((response) => response.body)
.then(streamToJsonIfPossible as any)
.then((res) => {
if ((res as any)?.errorMessages?.length) {
throw new Error((res as any).errorMessages.join(', '));
}
return transform ? transform({ response: res }, jiraCfg) : { response: res };
}),
).pipe(
catchError((err) => {
console.log(err);
console.log(getErrorTxt(err));
const errTxt = `Jira: ${getErrorTxt(err)}`;
this._snackService.open({ type: 'ERROR', msg: errTxt });
return throwError({ [HANDLED_ERROR_PROP_STR]: errTxt });
}),
);
}
// if (!this._isExtension) {
// return fromPromise(
// fetch(url, requestInit)
// .then((response) => response.body)
// .then(streamToJsonIfPossible as any)
// .then((res) => {
// if ((res as any)?.errorMessages?.length) {
// throw new Error((res as any).errorMessages.join(', '));
// }
// return transform ? transform({ response: res }, jiraCfg) : { response: res };
// }),
// ).pipe(
// catchError((err) => {
// console.log(err);
// console.log(getErrorTxt(err));
// const errTxt = `Jira: ${getErrorTxt(err)}`;
// this._snackService.open({ type: 'ERROR', msg: errTxt });
// return throwError({ [HANDLED_ERROR_PROP_STR]: errTxt });
// }),
// );
// }

// TODO refactor to observable for request canceling etc
let promiseResolve;
Expand Down Expand Up @@ -703,32 +703,32 @@ export class JiraApiService {
}
}

// eslint-disable-next-line prefer-arrow/prefer-arrow-functions
async function streamToString(stream: ReadableStream): Promise<string> {
const reader = stream.getReader();
const decoder = new TextDecoder();
let result = '';
let done = false;

while (!done) {
const { value, done: doneReading } = await reader.read();
done = doneReading;
if (value) {
result += decoder.decode(value, { stream: true });
}
}

result += decoder.decode(); // flush the decoder
return result;
}

// eslint-disable-next-line prefer-arrow/prefer-arrow-functions
async function streamToJsonIfPossible(stream: ReadableStream): Promise<any> {
const text = await streamToString(stream);
try {
return JSON.parse(text);
} catch (e) {
console.error('Jira: Could not parse response', text);
return text;
}
}
// // eslint-disable-next-line prefer-arrow/prefer-arrow-functions
// async function streamToString(stream: ReadableStream): Promise<string> {
// const reader = stream.getReader();
// const decoder = new TextDecoder();
// let result = '';
// let done = false;
//
// while (!done) {
// const { value, done: doneReading } = await reader.read();
// done = doneReading;
// if (value) {
// result += decoder.decode(value, { stream: true });
// }
// }
//
// result += decoder.decode(); // flush the decoder
// return result;
// }
//
// // eslint-disable-next-line prefer-arrow/prefer-arrow-functions
// async function streamToJsonIfPossible(stream: ReadableStream): Promise<any> {
// const text = await streamToString(stream);
// try {
// return JSON.parse(text);
// } catch (e) {
// console.error('Jira: Could not parse response', text);
// return text;
// }
// }

0 comments on commit 264ced7

Please sign in to comment.