test_auth.ts 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. import { SpApiClient } from './src/client.ts';
  2. import { SpApiConfig } from './src/types.ts';
  3. // 从环境变量读取配置,或者使用占位符
  4. const config: SpApiConfig = {
  5. clientId:'amzn1.application-oa2-client.afc01e883d4143bcae466247ac5fe692',
  6. clientSecret:'amzn1.oa2-cs.v1.eb3330dce4b5c835b0d22e855c8db1082632b99ed7226db7114557b3c562d038',
  7. refreshToken:'Atzr|IwEBIC8ubYHG1E9Li2-_madN1smv4tKNgv9-SZTkW-OxlyeiXVQMbRon_7-ON9s2spa-fBsi6G1KXdk8eSO2SlyM-5BxMUufTTclXDCmDZWHg6wmi6HPwRceGDbWhqjIuPWseNj4uyBBjUcd9F6O_RYzEsu1yss67RcZikPI7t_i-tUhF5W8l2Ufj2Sl9JXGycxNoJKbZzApPVVLwja_JaiAlqhZX4JYM1gfK9dgynJNgcPhnVZRJ0vNOkurQPtSp6_Yix6itvMhN5QeXZwJdd5xW1T7C6TJXsHJLiEPfTeJIEj7m7UwgdDS7YvdryIL8cMl5Gc',
  8. region: 'us-east-1'
  9. };
  10. console.log('Initializing SP-API Client with config:', {
  11. ...config
  12. });
  13. const client = new SpApiClient(config);
  14. async function testAuth() {
  15. try {
  16. console.log('Attempting to fetch Access Token...');
  17. // 通过访问私有方法或者触发请求来测试
  18. // 由于 getAccessToken 是私有的,我们通过 request 方法触发它
  19. // 我们故意请求一个不存在的端点,如果能走到 404,说明 Auth 成功了
  20. // 如果是 400/401 且来自 Amazon Auth Server,说明 Auth 失败
  21. await client.request({
  22. method: 'GET',
  23. path: '/orders/v0/orders',
  24. query: {
  25. MarketplaceIds: ['ATVPDKIKX0DER'], // getOrders expects MarketplaceIds as a list
  26. CreatedAfter: '2023-10-01T00:00:00Z'
  27. }
  28. });
  29. console.log('Request executed successfully.');
  30. } catch (error: any) {
  31. console.log('Test finished with error.');
  32. if (error.response) {
  33. console.log('HTTP Status:', error.response.status);
  34. console.log('Response Data:', JSON.stringify(error.response.data, null, 2));
  35. // 分析错误来源
  36. if (error.config && error.config.url && error.config.url.includes('api.amazon.com/auth/o2/token')) {
  37. console.error('❌ LWA Authentication Failed: Unable to get Access Token.');
  38. } else if (error.response.status === 403) {
  39. console.log('✅ Access Token acquired successfully! (But API request forbidden/invalid as expected with dummy creds)');
  40. } else if (error.response.status === 404) {
  41. console.log('✅ Access Token acquired successfully! (API endpoint not found)');
  42. } else if (error.response.status === 401) {
  43. console.log('❌ API Unauthorized: Access Token might be invalid or expired immediately.');
  44. } else {
  45. // 如果是我们预期的 token 请求错误
  46. if (error.message.includes('refresh_token')) {
  47. console.error('❌ LWA Token Error:', error.message);
  48. }
  49. }
  50. } else {
  51. console.error('Error Message:', error.message);
  52. }
  53. }
  54. }
  55. testAuth();