@seedprotocol/sdk 0.4.19 → 0.4.21

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 (181) hide show
  1. package/dist/{ArweaveClient-CAdWVQnJ.js → ArweaveClient-Cz9ZLiEV.js} +3 -3
  2. package/dist/{ArweaveClient-CAdWVQnJ.js.map → ArweaveClient-Cz9ZLiEV.js.map} +1 -1
  3. package/dist/{ArweaveClient-V62RJhsZ.js → ArweaveClient-DxpJnJXU.js} +3 -3
  4. package/dist/{ArweaveClient-V62RJhsZ.js.map → ArweaveClient-DxpJnJXU.js.map} +1 -1
  5. package/dist/{Db-DS2GBY6h.js → Db-CXwQVLZv.js} +41 -4
  6. package/dist/Db-CXwQVLZv.js.map +1 -0
  7. package/dist/{Db-8N3-le9a.js → Db-DkTBncAM.js} +4 -4
  8. package/dist/{Db-8N3-le9a.js.map → Db-DkTBncAM.js.map} +1 -1
  9. package/dist/{EasClient-D1eibg8b.js → EasClient-DjpbHjU9.js} +2 -2
  10. package/dist/{EasClient-D1eibg8b.js.map → EasClient-DjpbHjU9.js.map} +1 -1
  11. package/dist/{EasClient-nOmY5meW.js → EasClient-JYkmHxu1.js} +2 -2
  12. package/dist/{EasClient-nOmY5meW.js.map → EasClient-JYkmHxu1.js.map} +1 -1
  13. package/dist/{FileManager-DSTAwkqw.js → FileManager-CKyoLrBP.js} +2 -2
  14. package/dist/{FileManager-DSTAwkqw.js.map → FileManager-CKyoLrBP.js.map} +1 -1
  15. package/dist/{FileManager-Cze8qmS1.js → FileManager-DHnyb040.js} +34 -5
  16. package/dist/FileManager-DHnyb040.js.map +1 -0
  17. package/dist/{ModelProperty-ChevZoUy.js → ModelProperty-DWtv9fQr.js} +24 -24
  18. package/dist/{ModelProperty-ChevZoUy.js.map → ModelProperty-DWtv9fQr.js.map} +1 -1
  19. package/dist/{PathResolver-3TuYA9yv.js → PathResolver-Ce4K9acQ.js} +2 -2
  20. package/dist/{PathResolver-3TuYA9yv.js.map → PathResolver-Ce4K9acQ.js.map} +1 -1
  21. package/dist/{PathResolver-C5gj9EU2.js → PathResolver-pmw--Ea2.js} +2 -2
  22. package/dist/{PathResolver-C5gj9EU2.js.map → PathResolver-pmw--Ea2.js.map} +1 -1
  23. package/dist/{QueryClient-BGv6JOls.js → QueryClient-OUjfvY3g.js} +2 -2
  24. package/dist/{QueryClient-BGv6JOls.js.map → QueryClient-OUjfvY3g.js.map} +1 -1
  25. package/dist/{QueryClient-By2vdhIz.js → QueryClient-unspcsWa.js} +2 -2
  26. package/dist/{QueryClient-By2vdhIz.js.map → QueryClient-unspcsWa.js.map} +1 -1
  27. package/dist/{Schema-BQ5W3aOW.js → Schema-CqqcEexA.js} +38 -38
  28. package/dist/{Schema-BQ5W3aOW.js.map → Schema-CqqcEexA.js.map} +1 -1
  29. package/dist/{SchemaValidationService-DQx83Cte.js → SchemaValidationService-Cb-b4kpD.js} +2 -2
  30. package/dist/{SchemaValidationService-DQx83Cte.js.map → SchemaValidationService-Cb-b4kpD.js.map} +1 -1
  31. package/dist/{backfillMetadataPropertyIds-CMsU83q9.js → backfillMetadataPropertyIds-CRyRez3h.js} +2 -2
  32. package/dist/{backfillMetadataPropertyIds-CMsU83q9.js.map → backfillMetadataPropertyIds-CRyRez3h.js.map} +1 -1
  33. package/dist/cjs/{ModelProperty-Cuj839nX.js → ModelProperty-sNx_ZQZX.js} +17 -17
  34. package/dist/cjs/{ModelProperty-Cuj839nX.js.map → ModelProperty-sNx_ZQZX.js.map} +1 -1
  35. package/dist/cjs/{Schema-TFe24NNG.js → Schema-B4RRA-0g.js} +20 -20
  36. package/dist/cjs/{Schema-TFe24NNG.js.map → Schema-B4RRA-0g.js.map} +1 -1
  37. package/dist/cjs/{SchemaValidationService-DVQrRpse.js → SchemaValidationService-DCflhpcI.js} +2 -2
  38. package/dist/cjs/{SchemaValidationService-DVQrRpse.js.map → SchemaValidationService-DCflhpcI.js.map} +1 -1
  39. package/dist/cjs/{backfillMetadataPropertyIds-BiXK4hT1.js → backfillMetadataPropertyIds-DhAXAuSf.js} +2 -2
  40. package/dist/cjs/{backfillMetadataPropertyIds-BiXK4hT1.js.map → backfillMetadataPropertyIds-DhAXAuSf.js.map} +1 -1
  41. package/dist/cjs/{getItem-FgLv9abh.js → getItem-lyM2x5pT.js} +5 -3
  42. package/dist/cjs/getItem-lyM2x5pT.js.map +1 -0
  43. package/dist/cjs/{getPublishPayload-h_Rz8nVX.js → getPublishPayload-DP2fm4q8.js} +125 -26
  44. package/dist/cjs/getPublishPayload-DP2fm4q8.js.map +1 -0
  45. package/dist/cjs/{getPublishUploads-DdSwst2x.js → getPublishUploads-DdVy-5fK.js} +69 -23
  46. package/dist/cjs/getPublishUploads-DdVy-5fK.js.map +1 -0
  47. package/dist/cjs/{getSegmentedItemProperties-Bu4P_MG8.js → getSegmentedItemProperties-DtHofn5i.js} +3 -3
  48. package/dist/cjs/{getSegmentedItemProperties-Bu4P_MG8.js.map → getSegmentedItemProperties-DtHofn5i.js.map} +1 -1
  49. package/dist/cjs/{index-pyKmk9hA.js → index-D1qR8xnb.js} +1055 -388
  50. package/dist/cjs/index-D1qR8xnb.js.map +1 -0
  51. package/dist/cjs/{index-CKJeh6ic.js → index-DTkoTvcq.js} +5 -3
  52. package/dist/cjs/index-DTkoTvcq.js.map +1 -0
  53. package/dist/cjs/{ownership-gfm5thj7.js → ownership-DanM_n8E.js} +4 -4
  54. package/dist/cjs/ownership-DanM_n8E.js.map +1 -0
  55. package/dist/cjs/{property-Dw0b_Sf8.js → property-BQokoaRe.js} +6 -4
  56. package/dist/cjs/{property-Dw0b_Sf8.js.map → property-BQokoaRe.js.map} +1 -1
  57. package/dist/db/drizzle/drizzle/0011_normalize_placeholder_uids.sql +9 -0
  58. package/dist/db/drizzle/drizzle/0012_html_embedded_image_co_publish.sql +10 -0
  59. package/dist/db/drizzle/drizzle/meta/_journal.json +14 -0
  60. package/dist/{getItem-Bd9U9Yih.js → getItem-VI3QqdZH.js} +5 -3
  61. package/dist/getItem-VI3QqdZH.js.map +1 -0
  62. package/dist/{getPublishPayload-eJL7ktes.js → getPublishPayload-DpYwi-rd.js} +129 -30
  63. package/dist/getPublishPayload-DpYwi-rd.js.map +1 -0
  64. package/dist/{getPublishUploads-CKm5dsL6.js → getPublishUploads-DS2dQ4Ho.js} +69 -23
  65. package/dist/getPublishUploads-DS2dQ4Ho.js.map +1 -0
  66. package/dist/{getSegmentedItemProperties-B74LN_bz.js → getSegmentedItemProperties-Bz5B4DSA.js} +3 -3
  67. package/dist/{getSegmentedItemProperties-B74LN_bz.js.map → getSegmentedItemProperties-Bz5B4DSA.js.map} +1 -1
  68. package/dist/{index-BvZCYMxA.js → index-BrD_NNaX.js} +1056 -395
  69. package/dist/index-BrD_NNaX.js.map +1 -0
  70. package/dist/index-Cqf_DxkJ.js +19 -0
  71. package/dist/index-Cqf_DxkJ.js.map +1 -0
  72. package/dist/{index-BQv2k74p.js → index-DdzhrbkF.js} +3 -2
  73. package/dist/index-DdzhrbkF.js.map +1 -0
  74. package/dist/main.cjs +1 -1
  75. package/dist/main.js +528 -41
  76. package/dist/main.js.map +1 -1
  77. package/dist/node.js +10 -10
  78. package/dist/{ownership-tVhYQomL.js → ownership-BK6suksO.js} +4 -4
  79. package/dist/ownership-BK6suksO.js.map +1 -0
  80. package/dist/{property-BOdk-wW1.js → property-C63Ddzap.js} +6 -6
  81. package/dist/{property-BOdk-wW1.js.map → property-C63Ddzap.js.map} +1 -1
  82. package/dist/{queries-DBqVwEdv.js → queries-BGuWjEqt.js} +2 -2
  83. package/dist/{queries-DBqVwEdv.js.map → queries-BGuWjEqt.js.map} +1 -1
  84. package/dist/seedSchema/HtmlEmbeddedImageCoPublishSchema.ts +25 -0
  85. package/dist/seedSchema/index.ts +1 -0
  86. package/dist/src/Item/Item.d.ts +2 -2
  87. package/dist/src/Item/Item.d.ts.map +1 -1
  88. package/dist/src/Item/service/actors/loadOrCreateItem.d.ts.map +1 -1
  89. package/dist/src/Item/service/itemMachineSingle.d.ts +1 -1
  90. package/dist/src/ItemProperty/ItemProperty.d.ts +2 -2
  91. package/dist/src/ItemProperty/ItemProperty.d.ts.map +1 -1
  92. package/dist/src/ItemProperty/service/propertyMachine.d.ts +1 -1
  93. package/dist/src/Model/Model.d.ts +1 -1
  94. package/dist/src/Model/index.d.ts +1 -0
  95. package/dist/src/Model/index.d.ts.map +1 -1
  96. package/dist/src/Model/service/modelMachine.d.ts +3 -3
  97. package/dist/src/ModelProperty/service/modelPropertyMachine.d.ts +2 -2
  98. package/dist/src/Schema/Schema.d.ts +1 -1
  99. package/dist/src/Schema/service/schemaMachine.d.ts +3 -3
  100. package/dist/src/browser/db/drizzleFiles.d.ts +3 -1
  101. package/dist/src/browser/db/drizzleFiles.d.ts.map +1 -1
  102. package/dist/src/browser/helpers/FileManager.d.ts.map +1 -1
  103. package/dist/src/client/ClientManager.d.ts.map +1 -1
  104. package/dist/src/client/actors/platformClassesInit.d.ts.map +1 -1
  105. package/dist/src/client/clientManagerMachine.d.ts.map +1 -1
  106. package/dist/src/client/events.d.ts +8 -0
  107. package/dist/src/client/events.d.ts.map +1 -0
  108. package/dist/src/db/read/batchLatestPublishedVersionBySeedLocalIds.d.ts +10 -0
  109. package/dist/src/db/read/batchLatestPublishedVersionBySeedLocalIds.d.ts.map +1 -0
  110. package/dist/src/db/read/getItem.d.ts.map +1 -1
  111. package/dist/src/db/read/getItemData.d.ts.map +1 -1
  112. package/dist/src/db/read/getItems.d.ts +9 -0
  113. package/dist/src/db/read/getItems.d.ts.map +1 -1
  114. package/dist/src/db/read/getLatestPublishedVersionRow.d.ts +11 -0
  115. package/dist/src/db/read/getLatestPublishedVersionRow.d.ts.map +1 -0
  116. package/dist/src/db/read/getMetadataAttestationUidsForSeedUid.d.ts.map +1 -1
  117. package/dist/src/db/read/getPublishPayload.d.ts.map +1 -1
  118. package/dist/src/db/read/getPublishPendingDiff.d.ts +3 -3
  119. package/dist/src/db/read/getPublishPendingDiff.d.ts.map +1 -1
  120. package/dist/src/db/read/getPublishUploads.d.ts +17 -3
  121. package/dist/src/db/read/getPublishUploads.d.ts.map +1 -1
  122. package/dist/src/db/read/getSeedPublishState.d.ts +21 -0
  123. package/dist/src/db/read/getSeedPublishState.d.ts.map +1 -0
  124. package/dist/src/db/read/subqueries/versionData.d.ts +7 -0
  125. package/dist/src/db/read/subqueries/versionData.d.ts.map +1 -1
  126. package/dist/src/db/write/applyPropertyAttestationUidsFromPublish.d.ts +17 -0
  127. package/dist/src/db/write/applyPropertyAttestationUidsFromPublish.d.ts.map +1 -0
  128. package/dist/src/db/write/updateSeedUid.d.ts +3 -1
  129. package/dist/src/db/write/updateSeedUid.d.ts.map +1 -1
  130. package/dist/src/db/write/updateVersionUid.d.ts +3 -1
  131. package/dist/src/db/write/updateVersionUid.d.ts.map +1 -1
  132. package/dist/src/helpers/ArweaveClient/uploadApiVerification.d.ts +5 -1
  133. package/dist/src/helpers/ArweaveClient/uploadApiVerification.d.ts.map +1 -1
  134. package/dist/src/helpers/constants.d.ts +2 -0
  135. package/dist/src/helpers/constants.d.ts.map +1 -1
  136. package/dist/src/helpers/easUid.d.ts +13 -0
  137. package/dist/src/helpers/easUid.d.ts.map +1 -0
  138. package/dist/src/helpers/htmlEmbeddedDataUriPublish.d.ts +55 -0
  139. package/dist/src/helpers/htmlEmbeddedDataUriPublish.d.ts.map +1 -0
  140. package/dist/src/helpers/index.d.ts +2 -0
  141. package/dist/src/helpers/index.d.ts.map +1 -1
  142. package/dist/src/helpers/mediaRef.d.ts +72 -0
  143. package/dist/src/helpers/mediaRef.d.ts.map +1 -0
  144. package/dist/src/helpers/ownership.d.ts +2 -2
  145. package/dist/src/helpers/property/index.d.ts +30 -0
  146. package/dist/src/helpers/property/index.d.ts.map +1 -1
  147. package/dist/src/helpers/publishConfig.d.ts +3 -4
  148. package/dist/src/helpers/publishConfig.d.ts.map +1 -1
  149. package/dist/src/helpers/waitForEntityIdle.d.ts.map +1 -1
  150. package/dist/src/index.d.ts +14 -2
  151. package/dist/src/index.d.ts.map +1 -1
  152. package/dist/src/interfaces/IItem.d.ts +2 -2
  153. package/dist/src/interfaces/IItem.d.ts.map +1 -1
  154. package/dist/src/seedSchema/HtmlEmbeddedImageCoPublishSchema.d.ts +122 -0
  155. package/dist/src/seedSchema/HtmlEmbeddedImageCoPublishSchema.d.ts.map +1 -0
  156. package/dist/src/seedSchema/index.d.ts +1 -0
  157. package/dist/src/seedSchema/index.d.ts.map +1 -1
  158. package/dist/src/services/write/writeProcessMachine.d.ts +1 -1
  159. package/dist/src/types/index.d.ts +6 -0
  160. package/dist/src/types/index.d.ts.map +1 -1
  161. package/dist/src/types/item.d.ts +3 -0
  162. package/dist/src/types/item.d.ts.map +1 -1
  163. package/dist/src/types/machines.d.ts +2 -0
  164. package/dist/src/types/machines.d.ts.map +1 -1
  165. package/package.json +2 -1
  166. package/dist/Db-DS2GBY6h.js.map +0 -1
  167. package/dist/FileManager-Cze8qmS1.js.map +0 -1
  168. package/dist/cjs/getItem-FgLv9abh.js.map +0 -1
  169. package/dist/cjs/getPublishPayload-h_Rz8nVX.js.map +0 -1
  170. package/dist/cjs/getPublishUploads-DdSwst2x.js.map +0 -1
  171. package/dist/cjs/index-CKJeh6ic.js.map +0 -1
  172. package/dist/cjs/index-pyKmk9hA.js.map +0 -1
  173. package/dist/cjs/ownership-gfm5thj7.js.map +0 -1
  174. package/dist/getItem-Bd9U9Yih.js.map +0 -1
  175. package/dist/getPublishPayload-eJL7ktes.js.map +0 -1
  176. package/dist/getPublishUploads-CKm5dsL6.js.map +0 -1
  177. package/dist/index-BQv2k74p.js.map +0 -1
  178. package/dist/index-BvZCYMxA.js.map +0 -1
  179. package/dist/index-BxfqPvtu.js +0 -19
  180. package/dist/index-BxfqPvtu.js.map +0 -1
  181. package/dist/ownership-tVhYQomL.js.map +0 -1
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
3
  require('reflect-metadata');
4
- var main_cjs = require('./index-pyKmk9hA.js');
5
- var property = require('./property-Dw0b_Sf8.js');
4
+ var main_cjs = require('./index-D1qR8xnb.js');
5
+ var property = require('./property-BQokoaRe.js');
6
6
  require('immer');
7
7
  require('xstate');
8
8
  require('drizzle-orm/sqlite-core');
@@ -39,6 +39,7 @@ exports.Boolean = main_cjs.Boolean;
39
39
  exports.DEFAULT_TEXT_MAX_LENGTH = main_cjs.DEFAULT_TEXT_MAX_LENGTH;
40
40
  exports.Date = main_cjs.Date;
41
41
  exports.File = main_cjs.File;
42
+ exports.Html = main_cjs.Html;
42
43
  exports.Image = main_cjs.Image;
43
44
  exports.Json = main_cjs.Json;
44
45
  exports.List = main_cjs.List;
@@ -52,6 +53,7 @@ exports.Property = main_cjs.Property;
52
53
  exports.PropertyConstructor = main_cjs.PropertyConstructor;
53
54
  exports.PropertyMetadataKey = main_cjs.PropertyMetadataKey;
54
55
  exports.Relation = main_cjs.Relation;
56
+ exports.THtmlEmbeddedDataUriPolicy = main_cjs.THtmlEmbeddedDataUriPolicy;
55
57
  exports.TModelSchema = main_cjs.TModelSchema;
56
58
  exports.TModelValues = main_cjs.TModelValues;
57
59
  exports.TProperty = main_cjs.TProperty;
@@ -63,4 +65,4 @@ exports.TValidationRules = main_cjs.TValidationRules;
63
65
  exports.Text = main_cjs.Text;
64
66
  exports.normalizeDataType = main_cjs.normalizeDataType;
65
67
  exports.getPropertySchema = property.getPropertySchema;
66
- //# sourceMappingURL=index-CKJeh6ic.js.map
68
+ //# sourceMappingURL=index-DTkoTvcq.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-DTkoTvcq.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var main_cjs = require('./index-pyKmk9hA.js');
3
+ var main_cjs = require('./index-D1qR8xnb.js');
4
4
  var drizzleOrm = require('drizzle-orm');
5
5
  require('immer');
6
6
  require('reflect-metadata');
@@ -74,8 +74,8 @@ function getPublisherFromRow(row) {
74
74
  /**
75
75
  * Checks if the current user owns the item (publisher is in owned addresses).
76
76
  * Locally created items (no publisher, no attestationRaw) are considered owned.
77
- * Includes getAdditionalSyncAddresses (e.g. modular executor contract) so ownership
78
- * aligns with EAS sync - items attested by the executor are considered owned.
77
+ * Includes getAdditionalSyncAddresses (e.g. `modularAccountModuleContract` when configured)
78
+ * so ownership aligns with EAS sync when the publisher/attester matches those addresses.
79
79
  */
80
80
  async function isItemOwned(item) {
81
81
  const row = await getSeedRowForItem(item);
@@ -117,4 +117,4 @@ async function assertItemOwned(item) {
117
117
 
118
118
  exports.assertItemOwned = assertItemOwned;
119
119
  exports.isItemOwned = isItemOwned;
120
- //# sourceMappingURL=ownership-gfm5thj7.js.map
120
+ //# sourceMappingURL=ownership-DanM_n8E.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ownership-DanM_n8E.js","sources":["../../../src/helpers/ownership.ts"],"sourcesContent":["import type { IItem } from '@/interfaces/IItem'\nimport { BaseDb } from '@/db/Db/BaseDb'\nimport { seeds } from '@/seedSchema'\nimport { eq, or } from 'drizzle-orm'\nimport { getOwnedAddressesFromDb } from '@/helpers/db'\nimport { getGetAdditionalSyncAddresses } from '@/helpers/publishConfig'\n\nconst READ_ONLY_ERROR = 'Item is read-only: you do not own this item'\n\ntype ItemLike = { seedLocalId?: string; seedUid?: string }\n\ntype SeedRow = { publisher: string | null; attestationRaw: string | null; uid: string | null }\n\nasync function getSeedRowForItem(item: ItemLike): Promise<SeedRow | null> {\n const appDb = BaseDb.getAppDb()\n if (!appDb) return null\n\n const conditions = []\n if (item.seedLocalId) conditions.push(eq(seeds.localId, item.seedLocalId))\n if (item.seedUid) conditions.push(eq(seeds.uid, item.seedUid))\n if (conditions.length === 0) return null\n\n const seedRows = await appDb\n .select({\n publisher: seeds.publisher,\n attestationRaw: seeds.attestationRaw,\n uid: seeds.uid,\n })\n .from(seeds)\n .where(conditions.length === 1 ? conditions[0] : (or(...conditions) as any))\n .limit(1)\n\n if (!seedRows || seedRows.length === 0) return null\n return seedRows[0]\n}\n\nfunction getPublisherFromRow(row: SeedRow): string | null {\n if (row.publisher) return row.publisher\n if (row.attestationRaw) {\n try {\n const parsed = JSON.parse(row.attestationRaw) as { attester?: string }\n return parsed.attester ?? null\n } catch {\n return null\n }\n }\n return null\n}\n\n/**\n * Checks if the current user owns the item (publisher is in owned addresses).\n * Locally created items (no publisher, no attestationRaw) are considered owned.\n * Includes getAdditionalSyncAddresses (e.g. `modularAccountModuleContract` when configured)\n * so ownership aligns with EAS sync when the publisher/attester matches those addresses.\n */\nexport async function isItemOwned(item: ItemLike | IItem<any>): Promise<boolean> {\n const row = await getSeedRowForItem(item)\n if (!row) return false\n\n const publisher = getPublisherFromRow(row)\n if (!publisher) {\n if (!row.uid && !row.attestationRaw) {\n return true\n }\n return false\n }\n\n let addressesToCheck = await getOwnedAddressesFromDb()\n const additionalGetter = getGetAdditionalSyncAddresses()\n if (additionalGetter) {\n const additional = await additionalGetter()\n if (additional?.length) {\n const seen = new Set(addressesToCheck.map((a) => a.toLowerCase()))\n for (const addr of additional) {\n if (addr && !seen.has(addr.toLowerCase())) {\n seen.add(addr.toLowerCase())\n addressesToCheck = [...addressesToCheck, addr]\n }\n }\n }\n }\n\n const ownedSet = new Set(addressesToCheck.map((a) => a.toLowerCase()))\n return ownedSet.has(publisher.toLowerCase())\n}\n\n/**\n * Throws if the item is not owned. Use before write operations (publish, save, destroy).\n */\nexport async function assertItemOwned(item: ItemLike | IItem<any>): Promise<void> {\n const owned = await isItemOwned(item)\n if (!owned) {\n throw new Error(READ_ONLY_ERROR)\n }\n}\n"],"names":["BaseDb","eq","seeds","or","getOwnedAddressesFromDb","getGetAdditionalSyncAddresses"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var pluralize = require('pluralize');
4
- var main_cjs = require('./index-pyKmk9hA.js');
4
+ var main_cjs = require('./index-D1qR8xnb.js');
5
5
  var drizzleOrm = require('drizzle-orm');
6
6
  require('immer');
7
7
  require('reflect-metadata');
@@ -68,9 +68,9 @@ require('graphql-request');
68
68
  */
69
69
  const getPropertySchema = async (modelName, propertyName) => {
70
70
  // Dynamic import to break circular dependency
71
- const modelMod = await Promise.resolve().then(function () { return require('./index-pyKmk9hA.js'); }).then(function (n) { return n.Model$1; });
71
+ const modelMod = await Promise.resolve().then(function () { return require('./index-D1qR8xnb.js'); }).then(function (n) { return n.Model$1; });
72
72
  const { Model } = modelMod;
73
- const schemaMod = await Promise.resolve().then(function () { return require('./Schema-TFe24NNG.js'); });
73
+ const schemaMod = await Promise.resolve().then(function () { return require('./Schema-B4RRA-0g.js'); });
74
74
  const { Schema } = schemaMod;
75
75
  const model = await Model.getByNameAsync(modelName);
76
76
  if (!model) {
@@ -295,6 +295,7 @@ const getPropertySchema = async (modelName, propertyName) => {
295
295
  exports.Boolean = main_cjs.Boolean;
296
296
  exports.Date = main_cjs.Date;
297
297
  exports.File = main_cjs.File;
298
+ exports.Html = main_cjs.Html;
298
299
  exports.Image = main_cjs.Image;
299
300
  exports.Json = main_cjs.Json;
300
301
  exports.List = main_cjs.List;
@@ -307,6 +308,7 @@ exports.Property = main_cjs.Property;
307
308
  exports.PropertyConstructor = main_cjs.PropertyConstructor;
308
309
  exports.PropertyMetadataKey = main_cjs.PropertyMetadataKey;
309
310
  exports.Relation = main_cjs.Relation;
311
+ exports.THtmlEmbeddedDataUriPolicy = main_cjs.THtmlEmbeddedDataUriPolicy;
310
312
  exports.TProperty = main_cjs.TProperty;
311
313
  exports.TPropertyConstructor = main_cjs.TPropertyConstructor;
312
314
  exports.TPropertyDataType = main_cjs.TPropertyDataType;
@@ -315,4 +317,4 @@ exports.TStorageType = main_cjs.TStorageType;
315
317
  exports.Text = main_cjs.Text;
316
318
  exports.normalizeDataType = main_cjs.normalizeDataType;
317
319
  exports.getPropertySchema = getPropertySchema;
318
- //# sourceMappingURL=property-Dw0b_Sf8.js.map
320
+ //# sourceMappingURL=property-BQokoaRe.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"property-Dw0b_Sf8.js","sources":["../../../src/helpers/property.ts"],"sourcesContent":["import { Static } from '@sinclair/typebox'\nimport { TProperty } from '@/Schema'\n// Dynamic import to break circular dependency: Model -> ... -> helpers/property -> Model\n// import { Model } from '@/Model/Model'\nimport pluralize from 'pluralize'\nimport { resolveStorageNameToSchemaName } from '@/helpers/metadataPropertyNames'\nimport { BaseDb } from '@/db/Db/BaseDb'\nimport { models as modelsTable, properties, PropertyType } from '@/seedSchema'\nimport { eq, and } from 'drizzle-orm'\nimport { modelPropertiesToObject } from '@/helpers/model'\n\n// Re-export everything from property/index.ts to make it available when importing from helpers/property\nexport * from './property/index'\n\n/**\n * Gets the propertyRecordSchema object for a given model and property name.\n * \n * The propertyRecordSchema is the property definition object that contains\n * information about the property's data type, storage configuration, and\n * relationship details (for Relation and List types).\n * \n * This function first checks the database for property definitions (which may\n * have been edited), then falls back to schema files. This ensures that\n * edited properties persist across page reloads.\n * \n * This function handles property names that end with 'Id' or 'Ids' by automatically\n * looking up the base property name in the schema (e.g., 'authorId' -> 'author',\n * 'tagIds' -> 'tags').\n * \n * @param modelName - The name of the model (e.g., 'Article', 'Author')\n * @param propertyName - The name of the property (e.g., 'title', 'author', 'authorId', 'tags', 'tagIds')\n * @returns The propertyRecordSchema object (TProperty with optional _propertyFileId) or undefined if not found\n * \n * @example\n * ```typescript\n * const schema = await getPropertySchema('Article', 'title')\n * // Returns: { dataType: 'Text', ... }\n * \n * const relationSchema = await getPropertySchema('Article', 'author')\n * // Returns: { dataType: 'Relation', ref: 'Author', ... }\n * \n * // Also works with Id/Ids suffixes\n * const relationSchemaById = await getPropertySchema('Article', 'authorId')\n * // Returns: { dataType: 'Relation', ref: 'Author', ... }\n * ```\n */\nexport const getPropertySchema = async (\n modelName: string,\n propertyName: string,\n): Promise<(Static<typeof TProperty> & { _propertyFileId?: string }) | undefined> => {\n // Dynamic import to break circular dependency\n const modelMod = await import('../Model/Model')\n const { Model } = modelMod\n const schemaMod = await import('../Schema/Schema')\n const { Schema } = schemaMod\n const model = await Model.getByNameAsync(modelName)\n\n if (!model) {\n return undefined\n }\n \n // Get the original schema from Schema instance context (has ref fields from schema file)\n // This is more reliable than modelPropertiesToObject which depends on ModelProperty instances\n let schema: { [propertyName: string]: any } = {}\n try {\n const schemaName = model.schemaName\n if (schemaName) {\n const schemaInstance = Schema.create(schemaName, {\n waitForReady: false,\n }) as import('@/Schema/Schema').Schema\n const schemaContext = schemaInstance.getService().getSnapshot().context\n if (schemaContext.models && schemaContext.models[modelName]) {\n // Get properties from Schema context (original schema file data)\n const modelDef = schemaContext.models[modelName]\n schema = modelDef.properties || {}\n }\n }\n } catch (error) {\n // Fall through to modelPropertiesToObject\n }\n \n // Fallback to modelPropertiesToObject if Schema context doesn't have the data\n if (Object.keys(schema).length === 0) {\n const properties = model.properties || []\n if (properties.length === 0) {\n return undefined\n }\n schema = modelPropertiesToObject(properties)\n }\n \n // Helper to resolve property name (handles Id/Ids suffixes)\n const resolvePropertyName = (propName: string): string | undefined => {\n // First, try direct lookup\n if (schema[propName]) {\n return propName\n }\n\n // List-of-relation storage name (e.g. authorIdentityIds) -> schema key (authors)\n const listSchemaKey = resolveStorageNameToSchemaName(schema, propName)\n if (listSchemaKey && schema[listSchemaKey]) {\n return listSchemaKey\n }\n\n // Handle properties ending with 'Id' or 'Ids'\n let propertyNameWithoutId: string | undefined\n \n if (propName.endsWith('Id')) {\n propertyNameWithoutId = propName.slice(0, -2)\n } else if (propName.endsWith('Ids')) {\n propertyNameWithoutId = propName.slice(0, -3)\n propertyNameWithoutId = pluralize(propertyNameWithoutId)\n }\n \n if (propertyNameWithoutId && schema[propertyNameWithoutId]) {\n return propertyNameWithoutId\n }\n \n return undefined\n }\n \n const resolvedPropertyName = resolvePropertyName(propertyName)\n if (!resolvedPropertyName) {\n return undefined\n }\n \n // Try to get property from database first (may have edited values)\n try {\n const db = BaseDb.getAppDb()\n if (db) {\n // Find the model in the database\n const modelRecords = await db\n .select()\n .from(modelsTable)\n .where(eq(modelsTable.name, modelName))\n .limit(1)\n \n if (modelRecords.length > 0) {\n const modelRecord = modelRecords[0]\n \n // Find the property in the database by name\n let propertyRecords = await db\n .select()\n .from(properties)\n .where(\n and(\n eq(properties.name, resolvedPropertyName),\n eq(properties.modelId, modelRecord.id!),\n ),\n )\n .limit(1)\n \n // If not found by name, check for renamed properties (orphaned DB properties)\n if (propertyRecords.length === 0) {\n // Get all properties for this model\n const allDbProperties = await db\n .select()\n .from(properties)\n .where(eq(properties.modelId, modelRecord.id!))\n \n // Get all schema property names to identify orphaned properties\n const schemaPropertyNames = new Set(Object.keys(schema))\n \n // Get the schema property definition to match characteristics\n const schemaPropertyDef = schema[resolvedPropertyName]\n \n if (schemaPropertyDef) {\n // Find orphaned properties (don't match any schema property name) that match characteristics\n const orphanedProperties = allDbProperties.filter((p: PropertyType) => \n !schemaPropertyNames.has(p.name) && // Doesn't match any schema property name\n p.dataType === schemaPropertyDef.dataType // Same dataType\n )\n \n // If there's exactly one orphaned property with matching characteristics, it's likely the renamed property\n // We can also match by refModelId if it's a relation\n if (orphanedProperties.length > 0) {\n let matchedProperty = orphanedProperties[0]\n \n // If it's a relation, try to match by refModelId\n if (schemaPropertyDef.ref) {\n const refModelRecords = await db\n .select()\n .from(modelsTable)\n .where(eq(modelsTable.name, schemaPropertyDef.ref))\n .limit(1)\n \n if (refModelRecords.length > 0) {\n const expectedRefModelId = refModelRecords[0].id\n const matchingByRef = orphanedProperties.find((p: PropertyType) => p.refModelId === expectedRefModelId)\n if (matchingByRef) {\n matchedProperty = matchingByRef\n }\n }\n } else {\n // For non-relation properties, prefer ones without refModelId\n const withoutRef = orphanedProperties.find((p: PropertyType) => p.refModelId === null)\n if (withoutRef) {\n matchedProperty = withoutRef\n }\n }\n \n propertyRecords = [matchedProperty]\n }\n }\n }\n \n if (propertyRecords.length > 0) {\n const propertyRecord = propertyRecords[0]\n \n // Get the base schema from file to merge with database values\n // Use the schema object created earlier, not model.schema (which doesn't exist)\n const schemaFromFile = schema[resolvedPropertyName]\n \n // Build property schema from database, merging with file schema for fields not in DB\n // Use the schema property name (resolvedPropertyName) even if DB has different name (renamed)\n const propertySchema: Static<typeof TProperty> & { _propertyFileId?: string; _dbId?: number } = {\n ...schemaFromFile, // Start with file schema (has all fields like storageType, etc.)\n id: propertyRecord.schemaFileId || propertyRecord.id?.toString(), // id should be schemaFileId (string), not database ID\n _dbId: propertyRecord.id, // Store database integer ID separately\n name: resolvedPropertyName, // Use schema name, not DB name (for renamed properties)\n dataType: propertyRecord.dataType as any,\n modelId: propertyRecord.modelId,\n modelName,\n refModelId: propertyRecord.refModelId || undefined,\n refValueType: (propertyRecord.refValueType as any) || undefined,\n required: (propertyRecord as { required?: boolean }).required ?? undefined,\n // Include schemaFileId from database as _propertyFileId for ModelProperty.create()\n _propertyFileId: propertyRecord.schemaFileId || undefined,\n }\n \n // If refModelId is set, try to get the refModelName\n if (propertyRecord.refModelId) {\n const refModelRecords = await db\n .select()\n .from(modelsTable)\n .where(eq(modelsTable.id, propertyRecord.refModelId))\n .limit(1)\n \n if (refModelRecords.length > 0) {\n propertySchema.refModelName = refModelRecords[0].name\n propertySchema.ref = refModelRecords[0].name\n }\n } else if (schemaFromFile?.ref) {\n // If refModelId is not set but schema file has ref, resolve it from the database\n // This handles cases where the property was just created and refModelId hasn't been set yet\n propertySchema.ref = schemaFromFile.ref\n propertySchema.refModelName = schemaFromFile.ref\n \n // Try to resolve refModelId from the database using the model name\n try {\n const refModelRecords = await db\n .select()\n .from(modelsTable)\n .where(eq(modelsTable.name, schemaFromFile.ref))\n .limit(1)\n \n if (refModelRecords.length > 0 && refModelRecords[0].id) {\n propertySchema.refModelId = refModelRecords[0].id\n }\n } catch (error) {\n // Ignore errors - model might not exist yet\n }\n }\n \n return propertySchema\n }\n }\n }\n } catch (error) {\n // Database not available or error - fall through to schema file lookup\n }\n \n // Fall back to schema file lookup\n const schemaFromFile = schema[resolvedPropertyName]\n if (schemaFromFile) {\n const propertySchema: Static<typeof TProperty> & { _propertyFileId?: string } = { ...schemaFromFile, name: resolvedPropertyName }\n \n // If schema file has id as a string (propertyFileId), set it as _propertyFileId\n // This handles cases where the property hasn't been saved to the database yet\n if (typeof schemaFromFile.id === 'string') {\n propertySchema._propertyFileId = schemaFromFile.id\n }\n \n // If the schema file has ref but no refModelId, try to resolve it from the database\n if (schemaFromFile.ref && !propertySchema.refModelId) {\n try {\n const db = BaseDb.getAppDb()\n if (db) {\n const refModelRecords = await db\n .select()\n .from(modelsTable)\n .where(eq(modelsTable.name, schemaFromFile.ref))\n .limit(1)\n \n if (refModelRecords.length > 0 && refModelRecords[0].id) {\n propertySchema.refModelId = refModelRecords[0].id\n propertySchema.refModelName = schemaFromFile.ref\n }\n }\n } catch (error) {\n // Ignore errors - model might not exist yet or database not available\n }\n }\n \n return propertySchema\n }\n return undefined\n}\n"],"names":["modelPropertiesToObject","resolveStorageNameToSchemaName","BaseDb","modelsTable","eq","properties","and"],"mappings":"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"}
1
+ {"version":3,"file":"property-BQokoaRe.js","sources":["../../../src/helpers/property.ts"],"sourcesContent":["import { Static } from '@sinclair/typebox'\nimport { TProperty } from '@/Schema'\n// Dynamic import to break circular dependency: Model -> ... -> helpers/property -> Model\n// import { Model } from '@/Model/Model'\nimport pluralize from 'pluralize'\nimport { resolveStorageNameToSchemaName } from '@/helpers/metadataPropertyNames'\nimport { BaseDb } from '@/db/Db/BaseDb'\nimport { models as modelsTable, properties, PropertyType } from '@/seedSchema'\nimport { eq, and } from 'drizzle-orm'\nimport { modelPropertiesToObject } from '@/helpers/model'\n\n// Re-export everything from property/index.ts to make it available when importing from helpers/property\nexport * from './property/index'\n\n/**\n * Gets the propertyRecordSchema object for a given model and property name.\n * \n * The propertyRecordSchema is the property definition object that contains\n * information about the property's data type, storage configuration, and\n * relationship details (for Relation and List types).\n * \n * This function first checks the database for property definitions (which may\n * have been edited), then falls back to schema files. This ensures that\n * edited properties persist across page reloads.\n * \n * This function handles property names that end with 'Id' or 'Ids' by automatically\n * looking up the base property name in the schema (e.g., 'authorId' -> 'author',\n * 'tagIds' -> 'tags').\n * \n * @param modelName - The name of the model (e.g., 'Article', 'Author')\n * @param propertyName - The name of the property (e.g., 'title', 'author', 'authorId', 'tags', 'tagIds')\n * @returns The propertyRecordSchema object (TProperty with optional _propertyFileId) or undefined if not found\n * \n * @example\n * ```typescript\n * const schema = await getPropertySchema('Article', 'title')\n * // Returns: { dataType: 'Text', ... }\n * \n * const relationSchema = await getPropertySchema('Article', 'author')\n * // Returns: { dataType: 'Relation', ref: 'Author', ... }\n * \n * // Also works with Id/Ids suffixes\n * const relationSchemaById = await getPropertySchema('Article', 'authorId')\n * // Returns: { dataType: 'Relation', ref: 'Author', ... }\n * ```\n */\nexport const getPropertySchema = async (\n modelName: string,\n propertyName: string,\n): Promise<(Static<typeof TProperty> & { _propertyFileId?: string }) | undefined> => {\n // Dynamic import to break circular dependency\n const modelMod = await import('../Model/Model')\n const { Model } = modelMod\n const schemaMod = await import('../Schema/Schema')\n const { Schema } = schemaMod\n const model = await Model.getByNameAsync(modelName)\n\n if (!model) {\n return undefined\n }\n \n // Get the original schema from Schema instance context (has ref fields from schema file)\n // This is more reliable than modelPropertiesToObject which depends on ModelProperty instances\n let schema: { [propertyName: string]: any } = {}\n try {\n const schemaName = model.schemaName\n if (schemaName) {\n const schemaInstance = Schema.create(schemaName, {\n waitForReady: false,\n }) as import('@/Schema/Schema').Schema\n const schemaContext = schemaInstance.getService().getSnapshot().context\n if (schemaContext.models && schemaContext.models[modelName]) {\n // Get properties from Schema context (original schema file data)\n const modelDef = schemaContext.models[modelName]\n schema = modelDef.properties || {}\n }\n }\n } catch (error) {\n // Fall through to modelPropertiesToObject\n }\n \n // Fallback to modelPropertiesToObject if Schema context doesn't have the data\n if (Object.keys(schema).length === 0) {\n const properties = model.properties || []\n if (properties.length === 0) {\n return undefined\n }\n schema = modelPropertiesToObject(properties)\n }\n \n // Helper to resolve property name (handles Id/Ids suffixes)\n const resolvePropertyName = (propName: string): string | undefined => {\n // First, try direct lookup\n if (schema[propName]) {\n return propName\n }\n\n // List-of-relation storage name (e.g. authorIdentityIds) -> schema key (authors)\n const listSchemaKey = resolveStorageNameToSchemaName(schema, propName)\n if (listSchemaKey && schema[listSchemaKey]) {\n return listSchemaKey\n }\n\n // Handle properties ending with 'Id' or 'Ids'\n let propertyNameWithoutId: string | undefined\n \n if (propName.endsWith('Id')) {\n propertyNameWithoutId = propName.slice(0, -2)\n } else if (propName.endsWith('Ids')) {\n propertyNameWithoutId = propName.slice(0, -3)\n propertyNameWithoutId = pluralize(propertyNameWithoutId)\n }\n \n if (propertyNameWithoutId && schema[propertyNameWithoutId]) {\n return propertyNameWithoutId\n }\n \n return undefined\n }\n \n const resolvedPropertyName = resolvePropertyName(propertyName)\n if (!resolvedPropertyName) {\n return undefined\n }\n \n // Try to get property from database first (may have edited values)\n try {\n const db = BaseDb.getAppDb()\n if (db) {\n // Find the model in the database\n const modelRecords = await db\n .select()\n .from(modelsTable)\n .where(eq(modelsTable.name, modelName))\n .limit(1)\n \n if (modelRecords.length > 0) {\n const modelRecord = modelRecords[0]\n \n // Find the property in the database by name\n let propertyRecords = await db\n .select()\n .from(properties)\n .where(\n and(\n eq(properties.name, resolvedPropertyName),\n eq(properties.modelId, modelRecord.id!),\n ),\n )\n .limit(1)\n \n // If not found by name, check for renamed properties (orphaned DB properties)\n if (propertyRecords.length === 0) {\n // Get all properties for this model\n const allDbProperties = await db\n .select()\n .from(properties)\n .where(eq(properties.modelId, modelRecord.id!))\n \n // Get all schema property names to identify orphaned properties\n const schemaPropertyNames = new Set(Object.keys(schema))\n \n // Get the schema property definition to match characteristics\n const schemaPropertyDef = schema[resolvedPropertyName]\n \n if (schemaPropertyDef) {\n // Find orphaned properties (don't match any schema property name) that match characteristics\n const orphanedProperties = allDbProperties.filter((p: PropertyType) => \n !schemaPropertyNames.has(p.name) && // Doesn't match any schema property name\n p.dataType === schemaPropertyDef.dataType // Same dataType\n )\n \n // If there's exactly one orphaned property with matching characteristics, it's likely the renamed property\n // We can also match by refModelId if it's a relation\n if (orphanedProperties.length > 0) {\n let matchedProperty = orphanedProperties[0]\n \n // If it's a relation, try to match by refModelId\n if (schemaPropertyDef.ref) {\n const refModelRecords = await db\n .select()\n .from(modelsTable)\n .where(eq(modelsTable.name, schemaPropertyDef.ref))\n .limit(1)\n \n if (refModelRecords.length > 0) {\n const expectedRefModelId = refModelRecords[0].id\n const matchingByRef = orphanedProperties.find((p: PropertyType) => p.refModelId === expectedRefModelId)\n if (matchingByRef) {\n matchedProperty = matchingByRef\n }\n }\n } else {\n // For non-relation properties, prefer ones without refModelId\n const withoutRef = orphanedProperties.find((p: PropertyType) => p.refModelId === null)\n if (withoutRef) {\n matchedProperty = withoutRef\n }\n }\n \n propertyRecords = [matchedProperty]\n }\n }\n }\n \n if (propertyRecords.length > 0) {\n const propertyRecord = propertyRecords[0]\n \n // Get the base schema from file to merge with database values\n // Use the schema object created earlier, not model.schema (which doesn't exist)\n const schemaFromFile = schema[resolvedPropertyName]\n \n // Build property schema from database, merging with file schema for fields not in DB\n // Use the schema property name (resolvedPropertyName) even if DB has different name (renamed)\n const propertySchema: Static<typeof TProperty> & { _propertyFileId?: string; _dbId?: number } = {\n ...schemaFromFile, // Start with file schema (has all fields like storageType, etc.)\n id: propertyRecord.schemaFileId || propertyRecord.id?.toString(), // id should be schemaFileId (string), not database ID\n _dbId: propertyRecord.id, // Store database integer ID separately\n name: resolvedPropertyName, // Use schema name, not DB name (for renamed properties)\n dataType: propertyRecord.dataType as any,\n modelId: propertyRecord.modelId,\n modelName,\n refModelId: propertyRecord.refModelId || undefined,\n refValueType: (propertyRecord.refValueType as any) || undefined,\n required: (propertyRecord as { required?: boolean }).required ?? undefined,\n // Include schemaFileId from database as _propertyFileId for ModelProperty.create()\n _propertyFileId: propertyRecord.schemaFileId || undefined,\n }\n \n // If refModelId is set, try to get the refModelName\n if (propertyRecord.refModelId) {\n const refModelRecords = await db\n .select()\n .from(modelsTable)\n .where(eq(modelsTable.id, propertyRecord.refModelId))\n .limit(1)\n \n if (refModelRecords.length > 0) {\n propertySchema.refModelName = refModelRecords[0].name\n propertySchema.ref = refModelRecords[0].name\n }\n } else if (schemaFromFile?.ref) {\n // If refModelId is not set but schema file has ref, resolve it from the database\n // This handles cases where the property was just created and refModelId hasn't been set yet\n propertySchema.ref = schemaFromFile.ref\n propertySchema.refModelName = schemaFromFile.ref\n \n // Try to resolve refModelId from the database using the model name\n try {\n const refModelRecords = await db\n .select()\n .from(modelsTable)\n .where(eq(modelsTable.name, schemaFromFile.ref))\n .limit(1)\n \n if (refModelRecords.length > 0 && refModelRecords[0].id) {\n propertySchema.refModelId = refModelRecords[0].id\n }\n } catch (error) {\n // Ignore errors - model might not exist yet\n }\n }\n \n return propertySchema\n }\n }\n }\n } catch (error) {\n // Database not available or error - fall through to schema file lookup\n }\n \n // Fall back to schema file lookup\n const schemaFromFile = schema[resolvedPropertyName]\n if (schemaFromFile) {\n const propertySchema: Static<typeof TProperty> & { _propertyFileId?: string } = { ...schemaFromFile, name: resolvedPropertyName }\n \n // If schema file has id as a string (propertyFileId), set it as _propertyFileId\n // This handles cases where the property hasn't been saved to the database yet\n if (typeof schemaFromFile.id === 'string') {\n propertySchema._propertyFileId = schemaFromFile.id\n }\n \n // If the schema file has ref but no refModelId, try to resolve it from the database\n if (schemaFromFile.ref && !propertySchema.refModelId) {\n try {\n const db = BaseDb.getAppDb()\n if (db) {\n const refModelRecords = await db\n .select()\n .from(modelsTable)\n .where(eq(modelsTable.name, schemaFromFile.ref))\n .limit(1)\n \n if (refModelRecords.length > 0 && refModelRecords[0].id) {\n propertySchema.refModelId = refModelRecords[0].id\n propertySchema.refModelName = schemaFromFile.ref\n }\n }\n } catch (error) {\n // Ignore errors - model might not exist yet or database not available\n }\n }\n \n return propertySchema\n }\n return undefined\n}\n"],"names":["modelPropertiesToObject","resolveStorageNameToSchemaName","BaseDb","modelsTable","eq","properties","and"],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ UPDATE `versions` SET `uid` = NULL WHERE `uid` = 'NULL';
2
+ --> statement-breakpoint
3
+ UPDATE `versions` SET `seed_uid` = NULL WHERE `seed_uid` = 'NULL';
4
+ --> statement-breakpoint
5
+ UPDATE `metadata` SET `uid` = NULL WHERE `uid` = 'NULL';
6
+ --> statement-breakpoint
7
+ UPDATE `metadata` SET `version_uid` = NULL WHERE `version_uid` = 'NULL';
8
+ --> statement-breakpoint
9
+ UPDATE `seeds` SET `uid` = NULL WHERE `uid` = 'NULL';
@@ -0,0 +1,10 @@
1
+ CREATE TABLE `html_embedded_image_co_publish` (
2
+ `id` integer PRIMARY KEY AUTOINCREMENT NOT NULL,
3
+ `parent_seed_local_id` text NOT NULL,
4
+ `html_seed_local_id` text NOT NULL,
5
+ `image_seed_local_id` text NOT NULL,
6
+ `stable_key` text NOT NULL,
7
+ `created_at` integer NOT NULL
8
+ );
9
+ --> statement-breakpoint
10
+ CREATE UNIQUE INDEX `html_embed_co_pub_parent_html_stable` ON `html_embedded_image_co_publish` (`parent_seed_local_id`,`html_seed_local_id`,`stable_key`);
@@ -78,6 +78,20 @@
78
78
  "when": 1774000000000,
79
79
  "tag": "0010_add_arweave_l1_finalize_jobs",
80
80
  "breakpoints": true
81
+ },
82
+ {
83
+ "idx": 11,
84
+ "version": "6",
85
+ "when": 1774100000000,
86
+ "tag": "0011_normalize_placeholder_uids",
87
+ "breakpoints": true
88
+ },
89
+ {
90
+ "idx": 12,
91
+ "version": "6",
92
+ "when": 1774200000000,
93
+ "tag": "0012_html_embedded_image_co_publish",
94
+ "breakpoints": true
81
95
  }
82
96
  ]
83
97
  }
@@ -1,4 +1,4 @@
1
- import { W as getItemData, t as Item } from './index-BvZCYMxA.js';
1
+ import { $ as getItemData, u as Item } from './index-BrD_NNaX.js';
2
2
  import { startCase } from 'lodash-es';
3
3
  import 'xstate';
4
4
  import 'drizzle-orm/sqlite-core';
@@ -32,8 +32,10 @@ const getItem = async ({ modelName, seedLocalId, seedUid }) => {
32
32
  if (!itemInitObj.modelName && itemInitObj.type) {
33
33
  itemInitObj.modelName = startCase(itemInitObj.type);
34
34
  }
35
- return Item.create(itemInitObj);
35
+ // DB + loadOrCreateItem + concurrent property saves (e.g. during publish) can exceed the default 5s idle wait.
36
+ const getItemReadyTimeoutMs = 120000;
37
+ return Item.create(itemInitObj, { readyTimeout: getItemReadyTimeoutMs });
36
38
  };
37
39
 
38
40
  export { getItem };
39
- //# sourceMappingURL=getItem-Bd9U9Yih.js.map
41
+ //# sourceMappingURL=getItem-VI3QqdZH.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getItem-VI3QqdZH.js","sources":["../../src/db/read/getItem.ts"],"sourcesContent":["import { getItemData } from './getItemData'\nimport { GetItem } from '@/types'\nimport { Item } from '@/Item/Item'\nimport { startCase } from 'lodash-es'\n\nexport const getItem: GetItem = async ({ modelName, seedLocalId, seedUid }) => {\n const itemInitObj = await getItemData({\n modelName,\n seedLocalId,\n seedUid,\n })\n\n if (!itemInitObj) {\n console.error(\n `[db/queries] [getItem] no itemInitObj modelName: ${modelName} seedLocalId: ${seedLocalId} seedUid: ${seedUid}`,\n )\n return\n }\n\n if (!itemInitObj.seedLocalId) {\n console.error(\n `[db/queries] [getItem] no itemInitObj.seedLocalId modelName: ${modelName} seedLocalId: ${seedLocalId} seedUid: ${seedUid}`,\n )\n return\n }\n\n if (!itemInitObj.modelName && itemInitObj.type) {\n itemInitObj.modelName = startCase(itemInitObj.type)\n }\n\n // DB + loadOrCreateItem + concurrent property saves (e.g. during publish) can exceed the default 5s idle wait.\n const getItemReadyTimeoutMs = 120_000\n return Item.create(itemInitObj, { readyTimeout: getItemReadyTimeoutMs })\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAKO,MAAM,OAAO,GAAY,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,OAAO,EAAE,KAAI;AAC5E,IAAA,MAAM,WAAW,GAAG,MAAM,WAAW,CAAC;QACpC,SAAS;QACT,WAAW;QACX,OAAO;AACR,KAAA,CAAC;IAEF,IAAI,CAAC,WAAW,EAAE;QAChB,OAAO,CAAC,KAAK,CACX,CAAA,iDAAA,EAAoD,SAAS,CAAA,cAAA,EAAiB,WAAW,CAAA,UAAA,EAAa,OAAO,CAAA,CAAE,CAChH;QACD;IACF;AAEA,IAAA,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE;QAC5B,OAAO,CAAC,KAAK,CACX,CAAA,6DAAA,EAAgE,SAAS,CAAA,cAAA,EAAiB,WAAW,CAAA,UAAA,EAAa,OAAO,CAAA,CAAE,CAC5H;QACD;IACF;IAEA,IAAI,CAAC,WAAW,CAAC,SAAS,IAAI,WAAW,CAAC,IAAI,EAAE;QAC9C,WAAW,CAAC,SAAS,GAAG,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC;IACrD;;IAGA,MAAM,qBAAqB,GAAG,MAAO;AACrC,IAAA,OAAO,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,EAAE,YAAY,EAAE,qBAAqB,EAAE,CAAC;AAC1E;;;;"}
@@ -1,10 +1,10 @@
1
- import { Z as ZERO_BYTES32, x as getEasSchemaUidForModel, o as BaseDb, y as models, z as properties, V as VERSION_SCHEMA_UID_OPTIMISM_SEPOLIA, A as versions, C as modelPropertiesToObject, b as ModelPropertyDataTypes, r as resolveSeedIdsFromRefString, q as normalizeRelationPropertyValue, E as parseListPropertyValueFromStorage, G as getCorrectId, H as INTERNAL_PROPERTY_NAMES, K as defaultAttestationData, O as INTERNAL_DATA_TYPES, Q as toSnakeCase$1, S as getEasSchemaUidForSchemaDefinition, U as getEasSchemaForItemProperty } from './index-BvZCYMxA.js';
1
+ import { Z as ZERO_BYTES32, z as getEasSchemaUidForModel, p as BaseDb, A as models, C as properties, V as VERSION_SCHEMA_UID_OPTIMISM_SEPOLIA, E as isValidEasAttestationUid, G as getLatestPublishedVersionRow, K as modelPropertiesToObject, b as ModelPropertyDataTypes, r as resolveSeedIdsFromRefString, t as normalizeRelationPropertyValue, x as htmlEmbeddedImageCoPublish, O as parseListPropertyValueFromStorage, Q as getCorrectId, S as INTERNAL_PROPERTY_NAMES, U as defaultAttestationData, W as INTERNAL_DATA_TYPES, X as toSnakeCase$1, Y as getEasSchemaUidForSchemaDefinition, _ as getEasSchemaForItemProperty } from './index-BrD_NNaX.js';
2
2
  import { toSnakeCase } from 'drizzle-orm/casing';
3
3
  import pluralize from 'pluralize';
4
- import { g as getSegmentedItemProperties } from './getSegmentedItemProperties-B74LN_bz.js';
5
- import { getPropertySchema } from './property-BOdk-wW1.js';
4
+ import { g as getSegmentedItemProperties } from './getSegmentedItemProperties-Bz5B4DSA.js';
5
+ import { getPropertySchema } from './property-C63Ddzap.js';
6
6
  import { upperFirst, camelCase } from 'lodash-es';
7
- import { eq, and, desc } from 'drizzle-orm';
7
+ import { eq, and } from 'drizzle-orm';
8
8
  import debug from 'debug';
9
9
  import { ethers } from 'ethers';
10
10
  import 'reflect-metadata';
@@ -73,36 +73,28 @@ function mergeChildPublishPayloadIfDuplicateInBatch(multiPublishPayload, related
73
73
  const getVersionUid = (item) => {
74
74
  const latestVersion = item.latestVersionUid;
75
75
  if (latestVersion && typeof latestVersion === 'object' && latestVersion.uid) {
76
- return latestVersion.uid;
76
+ const u = latestVersion.uid;
77
+ return isValidEasAttestationUid(u) ? u : ZERO_BYTES32;
77
78
  }
78
79
  if (latestVersion && typeof latestVersion === 'string') {
79
- return latestVersion;
80
+ return isValidEasAttestationUid(latestVersion) ? latestVersion : ZERO_BYTES32;
80
81
  }
81
82
  return ZERO_BYTES32;
82
83
  };
83
84
  /**
84
85
  * Resolve versionUid when item.latestVersionUid is empty but item has been published (has seedUid).
85
- * Tries DB first, then EAS. The contract path never calls updateVersionUid, so the versions table
86
- * may have uid=NULL. EAS fallback queries attestations where refUID=seedUid (Version attestations).
86
+ * Tries DB first, then EAS. If the local versions row still has a placeholder uid after publish,
87
+ * EAS fallback queries attestations where refUID=seedUid (Version attestations).
87
88
  */
88
89
  async function resolveVersionUid(seedLocalId, seedUid) {
89
90
  if (!seedLocalId || !seedUid || seedUid === ZERO_BYTES32)
90
91
  return ZERO_BYTES32;
91
- const appDb = BaseDb.getAppDb();
92
- if (appDb) {
93
- const rows = await appDb
94
- .select({ uid: versions.uid })
95
- .from(versions)
96
- .where(eq(versions.seedLocalId, seedLocalId))
97
- .orderBy(desc(versions.createdAt))
98
- .limit(1);
99
- const uid = rows[0]?.uid;
100
- if (uid && uid !== '' && uid !== 'NULL')
101
- return uid;
102
- }
92
+ const published = await getLatestPublishedVersionRow(seedLocalId);
93
+ if (published?.uid)
94
+ return published.uid;
103
95
  try {
104
- const _mod_0 = await import('./index-BvZCYMxA.js');
105
- const _ns_0 = _mod_0.bB;
96
+ const _mod_0 = await import('./index-BrD_NNaX.js');
97
+ const _ns_0 = _mod_0.bO;
106
98
  const { getItemVersionsFromEas } = _ns_0;
107
99
  const attestations = await getItemVersionsFromEas({ seedUids: [seedUid] });
108
100
  const latest = attestations?.[0];
@@ -173,8 +165,8 @@ const ensurePropertyDefs = async (targetItem) => {
173
165
  schema = await getPropertySchema(targetItem.modelName, itemProperty.propertyName);
174
166
  if (!schema) {
175
167
  try {
176
- const _mod_1 = await import('./index-BvZCYMxA.js');
177
- const _ns_1 = _mod_1.bF;
168
+ const _mod_1 = await import('./index-BrD_NNaX.js');
169
+ const _ns_1 = _mod_1.bS;
178
170
  const { Model } = _ns_1;
179
171
  const normalizedModelName = upperFirst(camelCase(targetItem.modelName));
180
172
  let model = Model.getByName(normalizedModelName);
@@ -341,7 +333,7 @@ const processBasicProperties = async (itemBasicProperties, itemPublishData, ctx,
341
333
  }
342
334
  // Validate against property validation rules (enum, pattern, minLength, maxLength) before encoding
343
335
  if (propertyDef?.validation) {
344
- const { SchemaValidationService } = await import('./SchemaValidationService-DQx83Cte.js');
336
+ const { SchemaValidationService } = await import('./SchemaValidationService-Cb-b4kpD.js');
345
337
  const validationService = new SchemaValidationService();
346
338
  const validationResult = validationService.validatePropertyValue(value, propertyDef.dataType, propertyDef.validation, propertyDef.refValueType);
347
339
  if (!validationResult.isValid && validationResult.errors.length > 0) {
@@ -478,8 +470,8 @@ const processRelationOrImageProperty = async (relationOrImageProperty, multiPubl
478
470
  relationOrImageProperty.propertyDef?.refValueType === ModelPropertyDataTypes.Html ||
479
471
  relationOrImageProperty.propertyDef?.refValueType === ModelPropertyDataTypes.Json));
480
472
  if (isStorageSeed && (context.seedLocalId || context.seedUid)) {
481
- const _mod_2 = await import('./index-BvZCYMxA.js');
482
- const _ns_2 = _mod_2.bC;
473
+ const _mod_2 = await import('./index-BrD_NNaX.js');
474
+ const _ns_2 = _mod_2.bP;
483
475
  const { getPropertyData: getPropertyDataFromDb } = _ns_2;
484
476
  const metaRow = await getPropertyDataFromDb({
485
477
  propertyName: relationOrImageProperty.propertyName,
@@ -566,7 +558,7 @@ const processRelationOrImageProperty = async (relationOrImageProperty, multiPubl
566
558
  return multiPublishPayload;
567
559
  }
568
560
  // Use dynamic import to break circular dependency
569
- const getItemMod = await import('./getItem-Bd9U9Yih.js');
561
+ const getItemMod = await import('./getItem-VI3QqdZH.js');
570
562
  const { getItem } = getItemMod;
571
563
  const relatedItem = await getItem({
572
564
  seedLocalId,
@@ -661,6 +653,112 @@ const processRelationOrImageProperty = async (relationOrImageProperty, multiPubl
661
653
  multiPublishPayload.push(publishPayload);
662
654
  return multiPublishPayload;
663
655
  };
656
+ async function resolveHtmlPropertySchemaUidByHtmlSeed(item, htmlSeedLocalId, ctx) {
657
+ const want = htmlSeedLocalId.trim();
658
+ for (const p of item.properties) {
659
+ if (p.propertyDef?.dataType !== ModelPropertyDataTypes.Html)
660
+ continue;
661
+ const snap = p.getService().getSnapshot();
662
+ const c = 'context' in snap ? snap.context : null;
663
+ const pv = typeof c?.propertyValue === 'string' ? c.propertyValue.trim() : '';
664
+ if (pv !== want)
665
+ continue;
666
+ let uid = p.schemaUid;
667
+ if (!uid) {
668
+ const pd = await getPropertyData(p, ctx);
669
+ uid = pd?.schemaUid;
670
+ }
671
+ return uid;
672
+ }
673
+ addValidationError(ctx, `Could not find Html property for embedded image rewrite (html seed ${want}).`, 'html', 'html_embed_schema');
674
+ return undefined;
675
+ }
676
+ async function processHtmlEmbeddedCoPublishImagePayloads(item, multiPublishPayload, uploadedTransactions, originalSeedLocalId, ctx, buildOpts) {
677
+ const appDb = BaseDb.getAppDb();
678
+ if (!appDb)
679
+ return multiPublishPayload;
680
+ const rows = await appDb
681
+ .select()
682
+ .from(htmlEmbeddedImageCoPublish)
683
+ .where(eq(htmlEmbeddedImageCoPublish.parentSeedLocalId, item.seedLocalId));
684
+ if (rows.length === 0)
685
+ return multiPublishPayload;
686
+ const forceFullSnapshot = buildOpts?.forceFullSnapshot === true;
687
+ const getItemMod = await import('./getItem-VI3QqdZH.js');
688
+ const { getItem } = getItemMod;
689
+ const doneImages = new Set();
690
+ for (const row of rows) {
691
+ if (doneImages.has(row.imageSeedLocalId))
692
+ continue;
693
+ doneImages.add(row.imageSeedLocalId);
694
+ const htmlSchemaUid = await resolveHtmlPropertySchemaUidByHtmlSeed(item, row.htmlSeedLocalId, ctx);
695
+ if (!htmlSchemaUid)
696
+ continue;
697
+ const relatedItem = await getItem({ seedLocalId: row.imageSeedLocalId });
698
+ if (!relatedItem) {
699
+ addValidationError(ctx, `Embedded Image item not found for seed ${row.imageSeedLocalId}.`, 'html', 'html_embed_image_missing');
700
+ continue;
701
+ }
702
+ if (relatedItem.seedUid && relatedItem.seedUid !== ZERO_BYTES32) {
703
+ continue;
704
+ }
705
+ const seedSchemaUid = await getEasSchemaUidForModel('Image');
706
+ if (!seedSchemaUid) {
707
+ addValidationError(ctx, `Schema UID not found for model: Image`, 'html');
708
+ continue;
709
+ }
710
+ if (mergeChildPublishPayloadIfDuplicateInBatch(multiPublishPayload, relatedItem.seedLocalId, originalSeedLocalId, htmlSchemaUid)) {
711
+ continue;
712
+ }
713
+ const versionUid = getVersionUid(relatedItem);
714
+ let publishPayload = {
715
+ localId: relatedItem.seedLocalId,
716
+ seedIsRevocable: true,
717
+ versionSchemaUid: VERSION_SCHEMA_UID_OPTIMISM_SEPOLIA,
718
+ seedUid: relatedItem.seedUid || ZERO_BYTES32,
719
+ seedSchemaUid,
720
+ versionUid,
721
+ listOfAttestations: [],
722
+ propertiesToUpdate: [
723
+ {
724
+ publishLocalId: originalSeedLocalId,
725
+ propertySchemaUid: htmlSchemaUid,
726
+ },
727
+ ],
728
+ };
729
+ await ensurePropertyDefs(relatedItem);
730
+ const { itemBasicProperties, itemUploadProperties } = await getSegmentedItemProperties(relatedItem);
731
+ const relatedStorageUpload = resolveStorageTransactionUploadSlot(relatedItem, itemUploadProperties);
732
+ if (relatedStorageUpload) {
733
+ const transactionData = findUploadedTxForSeedLocalId(uploadedTransactions, relatedItem.seedLocalId);
734
+ if (transactionData) {
735
+ const itemProperty = relatedStorageUpload.itemProperty;
736
+ itemProperty.getService().send({
737
+ type: 'updateContext',
738
+ propertyValue: transactionData.txId,
739
+ renderValue: transactionData.txId,
740
+ });
741
+ replaceStorageTransactionInBasicProperties(itemBasicProperties, itemProperty);
742
+ }
743
+ }
744
+ for (const p of itemBasicProperties) {
745
+ if (isStorageTransactionPropertyName(p.propertyName) &&
746
+ !p.propertyDef &&
747
+ relatedItem.modelName) {
748
+ const schema = await getPropertySchema(relatedItem.modelName, 'storageTransactionId');
749
+ if (schema) {
750
+ p.getService().send({ type: 'updateContext', propertyRecordSchema: schema });
751
+ }
752
+ }
753
+ }
754
+ dedupeOneStorageTransactionPropertyInList(itemBasicProperties);
755
+ publishPayload = await processBasicProperties(itemBasicProperties, publishPayload, ctx, {
756
+ forceFullSnapshot,
757
+ });
758
+ multiPublishPayload.push(publishPayload);
759
+ }
760
+ return multiPublishPayload;
761
+ }
664
762
  const processListProperty = async (listProperty, multiPublishPayload, originalSeedLocalId, ctx, buildOpts) => {
665
763
  const forceFullSnapshot = buildOpts?.forceFullSnapshot === true;
666
764
  // processListProperty only handles list-of-relations; list-of-primitives go to itemBasicProperties
@@ -713,7 +811,7 @@ const processListProperty = async (listProperty, multiPublishPayload, originalSe
713
811
  if (!seedLocalId && !seedUid)
714
812
  continue;
715
813
  // Use dynamic import to break circular dependency
716
- const getItemMod = await import('./getItem-Bd9U9Yih.js');
814
+ const getItemMod = await import('./getItem-VI3QqdZH.js');
717
815
  const { getItem } = getItemMod;
718
816
  const relatedItem = await getItem({
719
817
  seedLocalId,
@@ -1006,6 +1104,7 @@ const getPublishPayload = async (item, uploadedTransactions, options) => {
1006
1104
  multiPublishPayload = await processRelationOrImageProperty(relationProperty, multiPublishPayload, uploadedTransactions, item.seedLocalId, validationCtx, { forceFullSnapshot });
1007
1105
  itemBasicProperties.push(relationProperty);
1008
1106
  }
1107
+ multiPublishPayload = await processHtmlEmbeddedCoPublishImagePayloads(item, multiPublishPayload, uploadedTransactions, item.seedLocalId, validationCtx, { forceFullSnapshot });
1009
1108
  for (const listProperty of itemListProperties) {
1010
1109
  multiPublishPayload = await processListProperty(listProperty, multiPublishPayload, item.seedLocalId, validationCtx, { forceFullSnapshot });
1011
1110
  itemBasicProperties.push(listProperty);
@@ -1320,4 +1419,4 @@ const resolvePublishPayloadValues = async (multiPayload, resolvedUids) => {
1320
1419
  };
1321
1420
 
1322
1421
  export { PublishValidationFailedError, getPublishPayload, resolvePublishPayloadValues, validateItemForPublish };
1323
- //# sourceMappingURL=getPublishPayload-eJL7ktes.js.map
1422
+ //# sourceMappingURL=getPublishPayload-DpYwi-rd.js.map