@proveanything/smartlinks 1.0.12 → 1.0.14

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 (47) hide show
  1. package/dist/api/auth.d.ts +11 -0
  2. package/dist/api/auth.js +9 -1
  3. package/dist/http.d.ts +1 -0
  4. package/dist/http.js +62 -0
  5. package/docs/assets/navigation.js +1 -1
  6. package/docs/assets/search.js +1 -1
  7. package/docs/documentation.json +615 -427
  8. package/docs/functions/appConfiguration.get.html +1 -1
  9. package/docs/functions/asset.getForCollection.html +1 -1
  10. package/docs/functions/asset.getForProduct.html +1 -1
  11. package/docs/functions/asset.getForProof.html +1 -1
  12. package/docs/functions/asset.listForCollection.html +1 -1
  13. package/docs/functions/asset.listForProduct.html +1 -1
  14. package/docs/functions/asset.listForProof.html +1 -1
  15. package/docs/functions/asset.uploadAsset.html +1 -1
  16. package/docs/functions/attestation.create.html +1 -1
  17. package/docs/functions/attestation.get.html +1 -1
  18. package/docs/functions/attestation.list.html +1 -1
  19. package/docs/functions/attestation.remove.html +1 -1
  20. package/docs/functions/attestation.update.html +1 -1
  21. package/docs/functions/auth.getAccount.html +3 -0
  22. package/docs/functions/auth.login.html +1 -1
  23. package/docs/functions/auth.logout.html +1 -1
  24. package/docs/functions/auth.verifyToken.html +3 -0
  25. package/docs/functions/collection.get.html +1 -1
  26. package/docs/functions/initializeApi.html +2 -2
  27. package/docs/functions/product.get.html +1 -1
  28. package/docs/functions/product.list.html +1 -1
  29. package/docs/functions/proof.get.html +1 -1
  30. package/docs/functions/proof.list.html +1 -1
  31. package/docs/functions/request.html +1 -1
  32. package/docs/interfaces/AppConfigurationResponse.html +4 -4
  33. package/docs/interfaces/AssetResponse.html +2 -2
  34. package/docs/interfaces/CollectionResponse.html +5 -5
  35. package/docs/interfaces/ErrorResponse.html +3 -3
  36. package/docs/interfaces/ProductResponse.html +5 -5
  37. package/docs/interfaces/ProofResponse.html +8 -8
  38. package/docs/modules/appConfiguration.html +1 -1
  39. package/docs/modules/asset.html +1 -1
  40. package/docs/modules/attestation.html +1 -1
  41. package/docs/modules/auth.html +3 -1
  42. package/docs/modules/collection.html +1 -1
  43. package/docs/modules/product.html +1 -1
  44. package/docs/modules/proof.html +1 -1
  45. package/package.json +1 -1
  46. package/src/api/auth.ts +16 -1
  47. package/src/http.ts +75 -0
@@ -12,6 +12,12 @@ type VerifyTokenResponse = {
12
12
  email?: string;
13
13
  account?: Record<string, any>;
14
14
  };
15
+ type AccountInfoResponse = {
16
+ user: Record<string, any>;
17
+ owner: Record<string, any>;
18
+ account: Record<string, any>;
19
+ location: Record<string, any>;
20
+ };
15
21
  export declare namespace auth {
16
22
  /**
17
23
  * Login with email and password.
@@ -27,5 +33,10 @@ export declare namespace auth {
27
33
  * Returns user/account info if valid.
28
34
  */
29
35
  function verifyToken(token?: string): Promise<VerifyTokenResponse>;
36
+ /**
37
+ * Gets current account information for the logged in user.
38
+ * Returns user, owner, account, and location objects.
39
+ */
40
+ function getAccount(): Promise<AccountInfoResponse>;
30
41
  }
31
42
  export {};
package/dist/api/auth.js CHANGED
@@ -1,4 +1,4 @@
1
- import { post, setBearerToken, getApiHeaders } from "../http";
1
+ import { post, request, setBearerToken, getApiHeaders } from "../http";
2
2
  export var auth;
3
3
  (function (auth) {
4
4
  /**
@@ -35,4 +35,12 @@ export var auth;
35
35
  return result;
36
36
  }
37
37
  auth.verifyToken = verifyToken;
38
+ /**
39
+ * Gets current account information for the logged in user.
40
+ * Returns user, owner, account, and location objects.
41
+ */
42
+ async function getAccount() {
43
+ return request("/public/auth/account");
44
+ }
45
+ auth.getAccount = getAccount;
38
46
  })(auth || (auth = {}));
package/dist/http.d.ts CHANGED
@@ -9,6 +9,7 @@ export declare function initializeApi(options: {
9
9
  baseURL: string;
10
10
  apiKey?: string;
11
11
  bearerToken?: string;
12
+ proxyMode?: boolean;
12
13
  }): void;
13
14
  /**
14
15
  * Allows setting the bearerToken at runtime (e.g. after login/logout).
package/dist/http.js CHANGED
@@ -5,6 +5,7 @@
5
5
  let baseURL = null;
6
6
  let apiKey = undefined;
7
7
  let bearerToken = undefined;
8
+ let proxyMode = false;
8
9
  /**
9
10
  * Call this once (e.g. at app startup) to configure baseURL/auth.
10
11
  *
@@ -16,6 +17,7 @@ export function initializeApi(options) {
16
17
  baseURL = options.baseURL.replace(/\/+\$/, ""); // trim trailing slash
17
18
  apiKey = options.apiKey;
18
19
  bearerToken = options.bearerToken;
20
+ proxyMode = !!options.proxyMode;
19
21
  }
20
22
  /**
21
23
  * Allows setting the bearerToken at runtime (e.g. after login/logout).
@@ -23,12 +25,60 @@ export function initializeApi(options) {
23
25
  export function setBearerToken(token) {
24
26
  bearerToken = token;
25
27
  }
28
+ // Map of pending proxy requests: id -> {resolve, reject}
29
+ const proxyPending = {};
30
+ function generateProxyId() {
31
+ return "proxy_" + Math.random().toString(36).slice(2) + Date.now();
32
+ }
33
+ // Shared listener for proxy responses
34
+ function ensureProxyListener() {
35
+ if (window._smartlinksProxyListener)
36
+ return;
37
+ window.addEventListener("message", (event) => {
38
+ const msg = event.data;
39
+ if (!msg || !msg._smartlinksProxyResponse || !msg.id)
40
+ return;
41
+ const pending = proxyPending[msg.id];
42
+ if (pending) {
43
+ if (msg.error) {
44
+ pending.reject(new Error(msg.error));
45
+ }
46
+ else {
47
+ pending.resolve(msg.data);
48
+ }
49
+ delete proxyPending[msg.id];
50
+ }
51
+ });
52
+ window._smartlinksProxyListener = true;
53
+ }
54
+ // Proxy request implementation
55
+ async function proxyRequest(method, path, body, headers, options) {
56
+ ensureProxyListener();
57
+ const id = generateProxyId();
58
+ const msg = {
59
+ _smartlinksProxyRequest: true,
60
+ id,
61
+ method,
62
+ path,
63
+ body,
64
+ headers,
65
+ options,
66
+ };
67
+ return new Promise((resolve, reject) => {
68
+ proxyPending[id] = { resolve, reject };
69
+ window.parent.postMessage(msg, "*");
70
+ // Optionally: add a timeout here to reject if no response
71
+ });
72
+ }
26
73
  /**
27
74
  * Internal helper that performs a GET request to \`\${baseURL}\${path}\`,
28
75
  * injecting headers for apiKey or bearerToken if present.
29
76
  * Returns the parsed JSON as T, or throws an Error.
30
77
  */
31
78
  export async function request(path) {
79
+ if (proxyMode) {
80
+ return proxyRequest("GET", path);
81
+ }
32
82
  if (!baseURL) {
33
83
  throw new Error("HTTP client is not initialized. Call initializeApi(...) first.");
34
84
  }
@@ -65,6 +115,9 @@ export async function request(path) {
65
115
  * Returns the parsed JSON as T, or throws an Error.
66
116
  */
67
117
  export async function post(path, body, extraHeaders) {
118
+ if (proxyMode) {
119
+ return proxyRequest("POST", path, body, extraHeaders);
120
+ }
68
121
  if (!baseURL) {
69
122
  throw new Error("HTTP client is not initialized. Call initializeApi(...) first.");
70
123
  }
@@ -101,6 +154,9 @@ export async function post(path, body, extraHeaders) {
101
154
  * Returns the parsed JSON as T, or throws an Error.
102
155
  */
103
156
  export async function put(path, body, extraHeaders) {
157
+ if (proxyMode) {
158
+ return proxyRequest("PUT", path, body, extraHeaders);
159
+ }
104
160
  if (!baseURL) {
105
161
  throw new Error("HTTP client is not initialized. Call initializeApi(...) first.");
106
162
  }
@@ -136,6 +192,9 @@ export async function put(path, body, extraHeaders) {
136
192
  * Returns the parsed JSON as T, or throws an Error.
137
193
  */
138
194
  export async function requestWithOptions(path, options) {
195
+ if (proxyMode) {
196
+ return proxyRequest(options.method || "GET", path, options.body, options.headers, options);
197
+ }
139
198
  if (!baseURL) {
140
199
  throw new Error("HTTP client is not initialized. Call initializeApi(...) first.");
141
200
  }
@@ -176,6 +235,9 @@ export async function requestWithOptions(path, options) {
176
235
  * Returns the parsed JSON as T, or throws an Error.
177
236
  */
178
237
  export async function del(path, extraHeaders) {
238
+ if (proxyMode) {
239
+ return proxyRequest("DELETE", path, undefined, extraHeaders);
240
+ }
179
241
  if (!baseURL) {
180
242
  throw new Error("HTTP client is not initialized. Call initializeApi(...) first.");
181
243
  }
@@ -1 +1 @@
1
- window.navigationData = "data:application/octet-stream;base64,H4sIAAAAAAAACp2VzW7DIBCE34Wz1UhVmoNvUdSeq16jHiwMNiphXX6qqlXevXJix0DIQno1w+dZmF32v8Syb0tq0gzDDhQXndONFaBIRYbG9qQmB2idZGYVKx56e5CkIh9CtaReV4T2QraaKVLvL9iO2YXEnaLjzgSrYzbkbdbH92O12DPGJ108jZ9LjbyA3oGUjIb1ea5OtFh55auKoK8aWkfTdXrESVaCA14AA46gpDCl9V5J89hsxaGuCIjV7KsQmBskNO02jErM8kR44qxlxt7qhWWxKH1Us8aypCmPdFbhAckxUo0UHneOMGoQhGYH+MqWclahd9UWnMhZhd+Ts33igpzti25GQifSzTESTqvYeUIHLn2i03ZweMxookPnIuiNlrxv1nqU3JQd4r6enQypRr7Pxoz4X0Dn3clwRiX4k8QrIB4dd9sH/n/zwPPWt9Gj+MbMAMp4TSKUZZo3lJnVLXH4h8enjf+DcejhVF+BoZbXAuVdyzDos9agUV6gwFDTy4PCIk0GBzwHWxQYSihhRSPFD9sOIpWWQIAO4k/H0oGblq7T9gdUEHbA8AkAAA=="
1
+ window.navigationData = "data:application/octet-stream;base64,H4sIAAAAAAAACp2VTW+DMAyG/0vOaJWmrgduqNrO07RbtQMKDkSlMQtJtQ/1v0+UUkIaHLoref3w2rGd3S8z8GVYyvKm2aISsrQ6NxIVS1iTm4ql7ICFraFd+YqHyhxqlrC9VAVL1wnjlawLDYqluyu2BDOShFW8iwywSjBT3mZ9+jglo722dUlXT93npUZeUG+xroFP83NcnWm+8sZX4kFfNRaWh/N0iBfZEhyKBTAUBKqW7dJ8b6RxbDTjqW4RkMrZVREw29SYF9m0VXyWI6I7zhhozdwsjIeLuo9ryA0ETTmkXkU3SIwRGqRpuWOETkMgNBzwGE2lV5F3VSyoSK+i78maKnBB1lRL90LGOVoVrkuHGSVUZbGU4SHrEOdTOhrtvIP+mIg/gpbi+x33MO/B0ZAF5YGdMZSVzyyJ+7a/Q4nt/cbfNIOTJrRa7rMxIP43MkN0cFy8FNzd5iTgL7O77aP4v3kUceuZ90y/Qdugap2xlcqAFjmHdjUnnv7h8Wnj/qBbwzTVVVCo8f0iebcyCvqsNWqSN1FQqMtbSMI8TQSHIgYbFRRKKmlkXssfyBoZ6paJgHwaPi2EG+5ydNttf5suZV+CCgAA"
@@ -1 +1 @@
1
- window.searchData = "data:application/octet-stream;base64,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";
1
+ window.searchData = "data:application/octet-stream;base64,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";