Fix: Enhance error handling and timeout management across various modules; improve validation and documentation

This commit is contained in:
2025-11-08 18:52:31 +01:00
parent ca356075fa
commit 5e322af2c0
13 changed files with 341 additions and 86 deletions

View File

@@ -2,18 +2,18 @@ import { Page } from 'rebrowser-playwright'
import { MicrosoftRewardsBot } from '../index'
import { Search } from './activities/Search'
import { ABC } from './activities/ABC'
import { DailyCheckIn } from './activities/DailyCheckIn'
import { Poll } from './activities/Poll'
import { Quiz } from './activities/Quiz'
import { ReadToEarn } from './activities/ReadToEarn'
import { Search } from './activities/Search'
import { SearchOnBing } from './activities/SearchOnBing'
import { ThisOrThat } from './activities/ThisOrThat'
import { UrlReward } from './activities/UrlReward'
import { SearchOnBing } from './activities/SearchOnBing'
import { ReadToEarn } from './activities/ReadToEarn'
import { DailyCheckIn } from './activities/DailyCheckIn'
import { DashboardData, MorePromotion, PromotionalItem } from '../interface/DashboardData'
import type { ActivityHandler } from '../interface/ActivityHandler'
import { DashboardData, MorePromotion, PromotionalItem } from '../interface/DashboardData'
type ActivityKind =
| { type: 'poll' }
@@ -73,9 +73,14 @@ export class Activities {
case 'urlReward':
await this.doUrlReward(page)
break
default:
case 'unsupported':
// FIXED: Added explicit default case
this.bot.log(this.bot.isMobile, 'ACTIVITY', `Skipped activity "${activity.title}" | Reason: Unsupported type: "${String((activity as { promotionType?: string }).promotionType)}"!`, 'warn')
break
default:
// Exhaustiveness check - should never reach here due to ActivityKind type
this.bot.log(this.bot.isMobile, 'ACTIVITY', `Unexpected activity kind for "${activity.title}"`, 'error')
break
}
} catch (e) {
this.bot.log(this.bot.isMobile, 'ACTIVITY', `Dispatcher error for "${activity.title}": ${e instanceof Error ? e.message : e}`, 'error')