feat: Implement error management for get user tweets

This commit is contained in:
Faruk AYDIN
2022-10-07 12:26:21 +03:00
parent e462d1f7ea
commit 80b25694b5
2 changed files with 19 additions and 10 deletions

View File

@@ -28,7 +28,14 @@ const getUserTweets = async (
const user = await getUserByUsername($, username);
let response;
const tweets: IJSONObject[] = [];
const tweets: {
data: IJSONObject[];
error: IJSONObject | null;
} = {
data: [],
error: null,
};
do {
const params: IJSONObject = {
@@ -47,13 +54,18 @@ const getUserTweets = async (
method: 'GET',
});
if (response.integrationError) {
tweets.error = response.integrationError;
return tweets;
}
if (response.data.meta.result_count > 0) {
response.data.data.forEach((tweet: IJSONObject) => {
if (
!options.lastInternalId ||
Number(tweet.id) > Number(options.lastInternalId)
) {
tweets.push(tweet);
tweets.data.push(tweet);
} else {
return;
}
@@ -61,14 +73,6 @@ const getUserTweets = async (
}
} while (response.data.meta.next_token && options.lastInternalId);
if (response.data.errors) {
const errorMessages = response.data.errors
.map((error: IJSONObject) => error.detail)
.join(' ');
throw new Error(`Error occured while fetching user data: ${errorMessages}`);
}
return tweets;
};

View File

@@ -45,6 +45,11 @@ const searchTweets = async (
return tweets;
}
if (response.data.errors) {
tweets.error = response.data.errors;
return tweets;
}
if (response.data.meta.result_count > 0) {
response.data.data.forEach((tweet: IJSONObject) => {
if (