@aztec/pxe 0.0.1-commit.3469e52 → 0.0.1-commit.35158ae7e

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 (247) hide show
  1. package/dest/access_scopes.d.ts +9 -0
  2. package/dest/access_scopes.d.ts.map +1 -0
  3. package/dest/access_scopes.js +6 -0
  4. package/dest/bin/check_oracle_version.js +1 -1
  5. package/dest/block_synchronizer/block_synchronizer.d.ts +9 -5
  6. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  7. package/dest/block_synchronizer/block_synchronizer.js +62 -16
  8. package/dest/config/index.d.ts +4 -2
  9. package/dest/config/index.d.ts.map +1 -1
  10. package/dest/config/index.js +18 -1
  11. package/dest/config/package_info.js +1 -1
  12. package/dest/contract_function_simulator/contract_function_simulator.d.ts +61 -31
  13. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  14. package/dest/contract_function_simulator/contract_function_simulator.js +201 -78
  15. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -7
  16. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  17. package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -11
  18. package/dest/contract_function_simulator/index.d.ts +2 -1
  19. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  20. package/dest/contract_function_simulator/index.js +1 -0
  21. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +3 -4
  22. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  23. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +6 -5
  24. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +1 -1
  25. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
  26. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +1 -3
  27. package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts +16 -0
  28. package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts.map +1 -0
  29. package/dest/contract_function_simulator/noir-structs/message_tx_context.js +57 -0
  30. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +3 -5
  31. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  32. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +4 -6
  33. package/dest/contract_function_simulator/oracle/interfaces.d.ts +54 -46
  34. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  35. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +9 -0
  36. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +1 -0
  37. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +42 -0
  38. package/dest/contract_function_simulator/oracle/oracle.d.ts +45 -42
  39. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  40. package/dest/contract_function_simulator/oracle/oracle.js +201 -110
  41. package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -22
  42. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
  43. package/dest/contract_function_simulator/oracle/private_execution.js +5 -40
  44. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +60 -77
  45. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  46. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +110 -86
  47. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +104 -54
  48. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  49. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +216 -119
  50. package/dest/contract_logging.d.ts +22 -0
  51. package/dest/contract_logging.d.ts.map +1 -0
  52. package/dest/contract_logging.js +23 -0
  53. package/dest/contract_sync/contract_sync_service.d.ts +45 -0
  54. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  55. package/dest/contract_sync/contract_sync_service.js +114 -0
  56. package/dest/contract_sync/helpers.d.ts +29 -0
  57. package/dest/contract_sync/helpers.d.ts.map +1 -0
  58. package/dest/contract_sync/helpers.js +55 -0
  59. package/dest/debug/pxe_debug_utils.d.ts +24 -10
  60. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  61. package/dest/debug/pxe_debug_utils.js +28 -17
  62. package/dest/entrypoints/client/bundle/index.d.ts +4 -1
  63. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  64. package/dest/entrypoints/client/bundle/index.js +3 -0
  65. package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
  66. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  67. package/dest/entrypoints/client/bundle/utils.js +21 -7
  68. package/dest/entrypoints/client/lazy/index.d.ts +4 -1
  69. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  70. package/dest/entrypoints/client/lazy/index.js +3 -0
  71. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  72. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  73. package/dest/entrypoints/client/lazy/utils.js +22 -8
  74. package/dest/entrypoints/pxe_creation_options.d.ts +3 -2
  75. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  76. package/dest/entrypoints/server/index.d.ts +4 -1
  77. package/dest/entrypoints/server/index.d.ts.map +1 -1
  78. package/dest/entrypoints/server/index.js +3 -0
  79. package/dest/entrypoints/server/utils.d.ts +1 -1
  80. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  81. package/dest/entrypoints/server/utils.js +28 -9
  82. package/dest/events/event_service.d.ts +5 -6
  83. package/dest/events/event_service.d.ts.map +1 -1
  84. package/dest/events/event_service.js +6 -7
  85. package/dest/job_coordinator/job_coordinator.d.ts +3 -2
  86. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -1
  87. package/dest/job_coordinator/job_coordinator.js +3 -2
  88. package/dest/logs/log_service.d.ts +7 -5
  89. package/dest/logs/log_service.d.ts.map +1 -1
  90. package/dest/logs/log_service.js +28 -32
  91. package/dest/messages/message_context_service.d.ts +17 -0
  92. package/dest/messages/message_context_service.d.ts.map +1 -0
  93. package/dest/messages/message_context_service.js +36 -0
  94. package/dest/notes/note_service.d.ts +9 -8
  95. package/dest/notes/note_service.d.ts.map +1 -1
  96. package/dest/notes/note_service.js +17 -16
  97. package/dest/notes_filter.d.ts +25 -0
  98. package/dest/notes_filter.d.ts.map +1 -0
  99. package/dest/notes_filter.js +4 -0
  100. package/dest/oracle_version.d.ts +3 -3
  101. package/dest/oracle_version.d.ts.map +1 -1
  102. package/dest/oracle_version.js +5 -4
  103. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  104. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  105. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  106. package/dest/private_kernel/hints/index.d.ts +1 -1
  107. package/dest/private_kernel/hints/index.js +1 -1
  108. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +4 -3
  109. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -1
  110. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +129 -68
  111. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  112. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  113. package/dest/private_kernel/hints/test_utils.js +203 -0
  114. package/dest/private_kernel/private_kernel_execution_prover.d.ts +3 -2
  115. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  116. package/dest/private_kernel/private_kernel_execution_prover.js +21 -13
  117. package/dest/private_kernel/private_kernel_oracle.d.ts +8 -4
  118. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  119. package/dest/private_kernel/private_kernel_oracle.js +7 -3
  120. package/dest/pxe.d.ts +74 -24
  121. package/dest/pxe.d.ts.map +1 -1
  122. package/dest/pxe.js +134 -80
  123. package/dest/storage/address_store/address_store.d.ts +1 -1
  124. package/dest/storage/address_store/address_store.d.ts.map +1 -1
  125. package/dest/storage/address_store/address_store.js +12 -11
  126. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
  127. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
  128. package/dest/storage/anchor_block_store/anchor_block_store.js +8 -1
  129. package/dest/storage/capsule_store/capsule_store.js +6 -8
  130. package/dest/storage/contract_store/contract_store.d.ts +42 -16
  131. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  132. package/dest/storage/contract_store/contract_store.js +157 -84
  133. package/dest/storage/metadata.d.ts +1 -1
  134. package/dest/storage/metadata.js +1 -1
  135. package/dest/storage/note_store/note_store.d.ts +47 -49
  136. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  137. package/dest/storage/note_store/note_store.js +278 -252
  138. package/dest/storage/note_store/stored_note.d.ts +16 -0
  139. package/dest/storage/note_store/stored_note.d.ts.map +1 -0
  140. package/dest/storage/note_store/stored_note.js +43 -0
  141. package/dest/storage/private_event_store/private_event_store.d.ts +17 -4
  142. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  143. package/dest/storage/private_event_store/private_event_store.js +198 -147
  144. package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
  145. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
  146. package/dest/storage/private_event_store/stored_private_event.js +56 -0
  147. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
  148. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  149. package/dest/storage/tagging_store/recipient_tagging_store.js +31 -19
  150. package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
  151. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
  152. package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
  153. package/dest/storage/tagging_store/sender_tagging_store.d.ts +29 -28
  154. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  155. package/dest/storage/tagging_store/sender_tagging_store.js +233 -137
  156. package/dest/tagging/get_all_logs_by_tags.d.ts +24 -0
  157. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
  158. package/dest/tagging/get_all_logs_by_tags.js +60 -0
  159. package/dest/tagging/index.d.ts +4 -3
  160. package/dest/tagging/index.d.ts.map +1 -1
  161. package/dest/tagging/index.js +2 -1
  162. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +5 -5
  163. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -1
  164. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +7 -7
  165. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  166. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +7 -7
  167. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -1
  168. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +16 -12
  169. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +5 -8
  170. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  171. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +13 -7
  172. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +4 -3
  173. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  174. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +23 -16
  175. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +6 -7
  176. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  177. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +42 -27
  178. package/package.json +25 -16
  179. package/src/access_scopes.ts +9 -0
  180. package/src/bin/check_oracle_version.ts +1 -0
  181. package/src/block_synchronizer/block_synchronizer.ts +76 -33
  182. package/src/config/index.ts +15 -1
  183. package/src/config/package_info.ts +1 -1
  184. package/src/contract_function_simulator/contract_function_simulator.ts +361 -142
  185. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -14
  186. package/src/contract_function_simulator/index.ts +1 -0
  187. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +9 -6
  188. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +1 -4
  189. package/src/contract_function_simulator/noir-structs/message_tx_context.ts +55 -0
  190. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +4 -7
  191. package/src/contract_function_simulator/oracle/interfaces.ts +67 -58
  192. package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +135 -0
  193. package/src/contract_function_simulator/oracle/oracle.ts +217 -149
  194. package/src/contract_function_simulator/oracle/private_execution.ts +5 -64
  195. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +150 -182
  196. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +330 -134
  197. package/src/contract_logging.ts +39 -0
  198. package/src/contract_sync/contract_sync_service.ts +181 -0
  199. package/src/contract_sync/helpers.ts +98 -0
  200. package/src/debug/pxe_debug_utils.ts +63 -18
  201. package/src/entrypoints/client/bundle/index.ts +3 -0
  202. package/src/entrypoints/client/bundle/utils.ts +16 -15
  203. package/src/entrypoints/client/lazy/index.ts +3 -0
  204. package/src/entrypoints/client/lazy/utils.ts +17 -15
  205. package/src/entrypoints/pxe_creation_options.ts +2 -1
  206. package/src/entrypoints/server/index.ts +3 -0
  207. package/src/entrypoints/server/utils.ts +22 -26
  208. package/src/events/event_service.ts +5 -7
  209. package/src/job_coordinator/job_coordinator.ts +4 -3
  210. package/src/logs/log_service.ts +48 -39
  211. package/src/messages/message_context_service.ts +45 -0
  212. package/src/notes/note_service.ts +24 -22
  213. package/src/notes_filter.ts +26 -0
  214. package/src/oracle_version.ts +5 -4
  215. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  216. package/src/private_kernel/hints/index.ts +1 -1
  217. package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +164 -117
  218. package/src/private_kernel/hints/test_utils.ts +325 -0
  219. package/src/private_kernel/private_kernel_execution_prover.ts +25 -15
  220. package/src/private_kernel/private_kernel_oracle.ts +9 -9
  221. package/src/pxe.ts +261 -126
  222. package/src/storage/address_store/address_store.ts +15 -15
  223. package/src/storage/anchor_block_store/anchor_block_store.ts +8 -0
  224. package/src/storage/capsule_store/capsule_store.ts +8 -8
  225. package/src/storage/contract_store/contract_store.ts +186 -96
  226. package/src/storage/metadata.ts +1 -1
  227. package/src/storage/note_store/note_store.ts +321 -318
  228. package/src/storage/note_store/stored_note.ts +48 -0
  229. package/src/storage/private_event_store/private_event_store.ts +250 -190
  230. package/src/storage/private_event_store/stored_private_event.ts +73 -0
  231. package/src/storage/tagging_store/recipient_tagging_store.ts +38 -24
  232. package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
  233. package/src/storage/tagging_store/sender_tagging_store.ts +287 -156
  234. package/src/tagging/get_all_logs_by_tags.ts +92 -0
  235. package/src/tagging/index.ts +3 -2
  236. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +17 -10
  237. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  238. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +17 -16
  239. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +25 -10
  240. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +29 -26
  241. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +39 -29
  242. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  243. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  244. package/dest/tree_membership/tree_membership_service.d.ts +0 -50
  245. package/dest/tree_membership/tree_membership_service.d.ts.map +0 -1
  246. package/dest/tree_membership/tree_membership_service.js +0 -75
  247. package/src/tree_membership/tree_membership_service.ts +0 -97
@@ -1,5 +1,5 @@
1
1
  import type { AztecAsyncKVStore, AztecAsyncMap } from '@aztec/kv-store';
2
- import type { DirectionalAppTaggingSecret } from '@aztec/stdlib/logs';
2
+ import type { ExtendedDirectionalAppTaggingSecret } from '@aztec/stdlib/logs';
3
3
 
4
4
  import type { StagedStore } from '../../job_coordinator/job_coordinator.js';
5
5
 
@@ -45,7 +45,11 @@ export class RecipientTaggingStore implements StagedStore {
45
45
  }
46
46
 
47
47
  async #readHighestAgedIndex(jobId: string, secret: string): Promise<number | undefined> {
48
- return this.#getHighestAgedIndexForJob(jobId).get(secret) ?? (await this.#highestAgedIndex.getAsync(secret));
48
+ // Always issue DB read to keep IndexedDB transaction alive (they auto-commit when a new micro-task starts and there
49
+ // are no pending read requests). The staged value still takes precedence if it exists.
50
+ const dbValue = await this.#highestAgedIndex.getAsync(secret);
51
+ const staged = this.#getHighestAgedIndexForJob(jobId).get(secret);
52
+ return staged ?? dbValue;
49
53
  }
50
54
 
51
55
  #writeHighestAgedIndex(jobId: string, secret: string, index: number) {
@@ -62,9 +66,11 @@ export class RecipientTaggingStore implements StagedStore {
62
66
  }
63
67
 
64
68
  async #readHighestFinalizedIndex(jobId: string, secret: string): Promise<number | undefined> {
65
- return (
66
- this.#getHighestFinalizedIndexForJob(jobId).get(secret) ?? (await this.#highestFinalizedIndex.getAsync(secret))
67
- );
69
+ // Always issue DB read to keep IndexedDB transaction alive (they auto-commit when a new micro-task starts and there
70
+ // are no pending read requests). The staged value still takes precedence if it exists.
71
+ const dbValue = await this.#highestFinalizedIndex.getAsync(secret);
72
+ const staged = this.#getHighestFinalizedIndexForJob(jobId).get(secret);
73
+ return staged ?? dbValue;
68
74
  }
69
75
 
70
76
  #writeHighestFinalizedIndex(jobId: string, secret: string, index: number) {
@@ -100,30 +106,38 @@ export class RecipientTaggingStore implements StagedStore {
100
106
  return Promise.resolve();
101
107
  }
102
108
 
103
- getHighestAgedIndex(secret: DirectionalAppTaggingSecret, jobId: string): Promise<number | undefined> {
104
- return this.#readHighestAgedIndex(jobId, secret.toString());
109
+ getHighestAgedIndex(secret: ExtendedDirectionalAppTaggingSecret, jobId: string): Promise<number | undefined> {
110
+ return this.#store.transactionAsync(() => this.#readHighestAgedIndex(jobId, secret.toString()));
105
111
  }
106
112
 
107
- async updateHighestAgedIndex(secret: DirectionalAppTaggingSecret, index: number, jobId: string): Promise<void> {
108
- const currentIndex = await this.#readHighestAgedIndex(jobId, secret.toString());
109
- if (currentIndex !== undefined && index <= currentIndex) {
110
- // Log sync should never set a lower highest aged index.
111
- throw new Error(`New highest aged index (${index}) must be higher than the current one (${currentIndex})`);
112
- }
113
- this.#writeHighestAgedIndex(jobId, secret.toString(), index);
113
+ updateHighestAgedIndex(secret: ExtendedDirectionalAppTaggingSecret, index: number, jobId: string): Promise<void> {
114
+ return this.#store.transactionAsync(async () => {
115
+ const currentIndex = await this.#readHighestAgedIndex(jobId, secret.toString());
116
+ if (currentIndex !== undefined && index <= currentIndex) {
117
+ // Log sync should never set a lower highest aged index.
118
+ throw new Error(`New highest aged index (${index}) must be higher than the current one (${currentIndex})`);
119
+ }
120
+ this.#writeHighestAgedIndex(jobId, secret.toString(), index);
121
+ });
114
122
  }
115
123
 
116
- getHighestFinalizedIndex(secret: DirectionalAppTaggingSecret, jobId: string): Promise<number | undefined> {
117
- return this.#readHighestFinalizedIndex(jobId, secret.toString());
124
+ getHighestFinalizedIndex(secret: ExtendedDirectionalAppTaggingSecret, jobId: string): Promise<number | undefined> {
125
+ return this.#store.transactionAsync(() => this.#readHighestFinalizedIndex(jobId, secret.toString()));
118
126
  }
119
127
 
120
- async updateHighestFinalizedIndex(secret: DirectionalAppTaggingSecret, index: number, jobId: string): Promise<void> {
121
- const currentIndex = await this.#readHighestFinalizedIndex(jobId, secret.toString());
122
- if (currentIndex !== undefined && index < currentIndex) {
123
- // Log sync should never set a lower highest finalized index but it can happen that it would try to set the same
124
- // one because we are loading logs from highest aged index + 1 and not from the highest finalized index.
125
- throw new Error(`New highest finalized index (${index}) must be higher than the current one (${currentIndex})`);
126
- }
127
- this.#writeHighestFinalizedIndex(jobId, secret.toString(), index);
128
+ updateHighestFinalizedIndex(
129
+ secret: ExtendedDirectionalAppTaggingSecret,
130
+ index: number,
131
+ jobId: string,
132
+ ): Promise<void> {
133
+ return this.#store.transactionAsync(async () => {
134
+ const currentIndex = await this.#readHighestFinalizedIndex(jobId, secret.toString());
135
+ if (currentIndex !== undefined && index < currentIndex) {
136
+ // Log sync should never set a lower highest finalized index but it can happen that it would try to set the same
137
+ // one because we are loading logs from highest aged index + 1 and not from the highest finalized index.
138
+ throw new Error(`New highest finalized index (${index}) must be higher than the current one (${currentIndex})`);
139
+ }
140
+ this.#writeHighestFinalizedIndex(jobId, secret.toString(), index);
141
+ });
128
142
  }
129
143
  }
@@ -16,27 +16,33 @@ export class SenderAddressBookStore {
16
16
  this.#addressBook = this.#store.openMap('address_book');
17
17
  }
18
18
 
19
- async addSender(address: AztecAddress): Promise<boolean> {
20
- if (await this.#addressBook.hasAsync(address.toString())) {
21
- return false;
22
- }
19
+ addSender(address: AztecAddress): Promise<boolean> {
20
+ return this.#store.transactionAsync(async () => {
21
+ if (await this.#addressBook.hasAsync(address.toString())) {
22
+ return false;
23
+ }
23
24
 
24
- await this.#addressBook.set(address.toString(), true);
25
+ await this.#addressBook.set(address.toString(), true);
25
26
 
26
- return true;
27
+ return true;
28
+ });
27
29
  }
28
30
 
29
- async getSenders(): Promise<AztecAddress[]> {
30
- return (await toArray(this.#addressBook.keysAsync())).map(AztecAddress.fromString);
31
+ getSenders(): Promise<AztecAddress[]> {
32
+ return this.#store.transactionAsync(async () => {
33
+ return (await toArray(this.#addressBook.keysAsync())).map(AztecAddress.fromString);
34
+ });
31
35
  }
32
36
 
33
- async removeSender(address: AztecAddress): Promise<boolean> {
34
- if (!(await this.#addressBook.hasAsync(address.toString()))) {
35
- return false;
36
- }
37
+ removeSender(address: AztecAddress): Promise<boolean> {
38
+ return this.#store.transactionAsync(async () => {
39
+ if (!(await this.#addressBook.hasAsync(address.toString()))) {
40
+ return false;
41
+ }
37
42
 
38
- await this.#addressBook.delete(address.toString());
43
+ await this.#addressBook.delete(address.toString());
39
44
 
40
- return true;
45
+ return true;
46
+ });
41
47
  }
42
48
  }