feat: Implement error management for get user tweets
This commit is contained in:
@@ -28,7 +28,14 @@ const getUserTweets = async (
|
|||||||
const user = await getUserByUsername($, username);
|
const user = await getUserByUsername($, username);
|
||||||
|
|
||||||
let response;
|
let response;
|
||||||
const tweets: IJSONObject[] = [];
|
|
||||||
|
const tweets: {
|
||||||
|
data: IJSONObject[];
|
||||||
|
error: IJSONObject | null;
|
||||||
|
} = {
|
||||||
|
data: [],
|
||||||
|
error: null,
|
||||||
|
};
|
||||||
|
|
||||||
do {
|
do {
|
||||||
const params: IJSONObject = {
|
const params: IJSONObject = {
|
||||||
@@ -47,13 +54,18 @@ const getUserTweets = async (
|
|||||||
method: 'GET',
|
method: 'GET',
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (response.integrationError) {
|
||||||
|
tweets.error = response.integrationError;
|
||||||
|
return tweets;
|
||||||
|
}
|
||||||
|
|
||||||
if (response.data.meta.result_count > 0) {
|
if (response.data.meta.result_count > 0) {
|
||||||
response.data.data.forEach((tweet: IJSONObject) => {
|
response.data.data.forEach((tweet: IJSONObject) => {
|
||||||
if (
|
if (
|
||||||
!options.lastInternalId ||
|
!options.lastInternalId ||
|
||||||
Number(tweet.id) > Number(options.lastInternalId)
|
Number(tweet.id) > Number(options.lastInternalId)
|
||||||
) {
|
) {
|
||||||
tweets.push(tweet);
|
tweets.data.push(tweet);
|
||||||
} else {
|
} else {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -61,14 +73,6 @@ const getUserTweets = async (
|
|||||||
}
|
}
|
||||||
} while (response.data.meta.next_token && options.lastInternalId);
|
} 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;
|
return tweets;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -45,6 +45,11 @@ const searchTweets = async (
|
|||||||
return tweets;
|
return tweets;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (response.data.errors) {
|
||||||
|
tweets.error = response.data.errors;
|
||||||
|
return tweets;
|
||||||
|
}
|
||||||
|
|
||||||
if (response.data.meta.result_count > 0) {
|
if (response.data.meta.result_count > 0) {
|
||||||
response.data.data.forEach((tweet: IJSONObject) => {
|
response.data.data.forEach((tweet: IJSONObject) => {
|
||||||
if (
|
if (
|
||||||
|
Reference in New Issue
Block a user