pinme 2.0.2-beta.6 → 2.0.2-beta.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/dist/index.js +56 -4
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -1523,7 +1523,7 @@ var import_chalk25 = __toESM(require("chalk"));
1523
1523
  var import_figlet5 = __toESM(require("figlet"));
1524
1524
 
1525
1525
  // package.json
1526
- var version = "2.0.2-beta.6";
1526
+ var version = "2.0.2-beta.7";
1527
1527
 
1528
1528
  // bin/upload.ts
1529
1529
  var import_path6 = __toESM(require("path"));
@@ -5439,6 +5439,47 @@ var POLL_INTERVAL = APP_CONFIG.upload.pollIntervalMs;
5439
5439
  var PROGRESS_UPDATE_INTERVAL = 200;
5440
5440
  var EXPECTED_UPLOAD_TIME = 6e4;
5441
5441
  var MAX_PROGRESS = 0.9;
5442
+ function extractAxiosErrorMessage(error) {
5443
+ var _a2, _b, _c, _d;
5444
+ const responseData = (_a2 = error == null ? void 0 : error.response) == null ? void 0 : _a2.data;
5445
+ if (typeof responseData === "string" && responseData.trim()) {
5446
+ return responseData.trim();
5447
+ }
5448
+ const message = (responseData == null ? void 0 : responseData.msg) || (responseData == null ? void 0 : responseData.message) || (responseData == null ? void 0 : responseData.error) || ((_b = responseData == null ? void 0 : responseData.data) == null ? void 0 : _b.msg) || ((_c = responseData == null ? void 0 : responseData.data) == null ? void 0 : _c.message) || ((_d = responseData == null ? void 0 : responseData.data) == null ? void 0 : _d.error);
5449
+ if (typeof message === "string" && message.trim()) {
5450
+ return message.trim();
5451
+ }
5452
+ return (error == null ? void 0 : error.message) || "Unknown network error";
5453
+ }
5454
+ function formatAxiosError(prefix, error) {
5455
+ var _a2;
5456
+ const status = (_a2 = error == null ? void 0 : error.response) == null ? void 0 : _a2.status;
5457
+ const message = extractAxiosErrorMessage(error);
5458
+ if (status) {
5459
+ return new Error(`${prefix}: ${message} (status: ${status})`);
5460
+ }
5461
+ return new Error(`${prefix}: ${message}`);
5462
+ }
5463
+ function logAxiosErrorDetails(prefix, error) {
5464
+ var _a2, _b;
5465
+ const status = (_a2 = error == null ? void 0 : error.response) == null ? void 0 : _a2.status;
5466
+ const responseData = (_b = error == null ? void 0 : error.response) == null ? void 0 : _b.data;
5467
+ console.error(`[pinme upload] ${prefix}`);
5468
+ console.error(`[pinme upload] status: ${status ?? "unknown"}`);
5469
+ if (responseData === void 0) {
5470
+ console.error("[pinme upload] response: <empty>");
5471
+ return;
5472
+ }
5473
+ try {
5474
+ console.error(`[pinme upload] response: ${JSON.stringify(responseData)}`);
5475
+ } catch {
5476
+ console.error(`[pinme upload] response: ${String(responseData)}`);
5477
+ }
5478
+ }
5479
+ function isStorageLimitError(error) {
5480
+ const message = extractAxiosErrorMessage(error).toLowerCase();
5481
+ return message.includes("storage space limit") || message.includes("space limit reached") || message.includes("storage limit reached") || message.includes("quota exceeded") || message.includes("insufficient storage");
5482
+ }
5442
5483
  var StepProgressBar = class {
5443
5484
  spinner;
5444
5485
  fileName;
@@ -5615,7 +5656,8 @@ async function initChunkSession(filePath, deviceId, options = {}, isDirectory =
5615
5656
  throw new Error(`Session initialization failed: ${msg} (code: ${code})`);
5616
5657
  } catch (error) {
5617
5658
  if (axios_default.isAxiosError(error)) {
5618
- throw new Error(`Network error: ${error.message}`);
5659
+ logAxiosErrorDetails("chunk/init failed", error);
5660
+ throw formatAxiosError("Session initialization failed", error);
5619
5661
  }
5620
5662
  throw error;
5621
5663
  }
@@ -5651,6 +5693,10 @@ async function uploadChunkWithAbort(sessionId, chunkIndex, chunkData, deviceId,
5651
5693
  if (error.name === "CanceledError" || signal.aborted) {
5652
5694
  throw new Error("Request cancelled");
5653
5695
  }
5696
+ if (axios_default.isAxiosError(error) && isStorageLimitError(error)) {
5697
+ logAxiosErrorDetails("chunk/upload failed", error);
5698
+ throw formatAxiosError("Chunk upload failed", error);
5699
+ }
5654
5700
  if (retryCount < MAX_RETRIES) {
5655
5701
  await delayWithAbortCheck(RETRY_DELAY, signal);
5656
5702
  return uploadChunkWithAbort(
@@ -5662,6 +5708,10 @@ async function uploadChunkWithAbort(sessionId, chunkIndex, chunkData, deviceId,
5662
5708
  retryCount + 1
5663
5709
  );
5664
5710
  }
5711
+ if (axios_default.isAxiosError(error)) {
5712
+ logAxiosErrorDetails("chunk/upload failed", error);
5713
+ throw formatAxiosError("Chunk upload failed", error);
5714
+ }
5665
5715
  throw new Error(
5666
5716
  `Chunk ${chunkIndex + 1} upload failed after ${MAX_RETRIES} retries: ${error.message}`
5667
5717
  );
@@ -5773,7 +5823,8 @@ async function completeChunkUpload(sessionId, deviceId, options = {}) {
5773
5823
  throw new Error(`Complete upload failed: ${msg} (code: ${code})`);
5774
5824
  } catch (error) {
5775
5825
  if (axios_default.isAxiosError(error)) {
5776
- throw new Error(`Network error: ${error.message}`);
5826
+ logAxiosErrorDetails("chunk/complete failed", error);
5827
+ throw formatAxiosError("Complete upload failed", error);
5777
5828
  }
5778
5829
  throw error;
5779
5830
  }
@@ -5803,7 +5854,8 @@ async function getChunkStatus(sessionId, deviceId, options = {}) {
5803
5854
  throw new Error(`Server returned error: ${msg} (code: ${code})`);
5804
5855
  } catch (error) {
5805
5856
  if (axios_default.isAxiosError(error)) {
5806
- throw new Error(`Network error: ${error.message}`);
5857
+ logAxiosErrorDetails("up_status failed", error);
5858
+ throw formatAxiosError("Upload status check failed", error);
5807
5859
  }
5808
5860
  throw error;
5809
5861
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "pinme",
3
- "version": "2.0.2-beta.6",
3
+ "version": "2.0.2-beta.7",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },