@leofcoin/chain 1.0.8 → 1.0.11

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 (78) hide show
  1. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/chain.js.html +0 -0
  2. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/contracts_factory.js.html +0 -0
  3. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/contracts_nameService.js.html +0 -0
  4. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/contracts_proxies_factoryProxy.js.html +0 -0
  5. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/contracts_proxies_nameServiceProxy.js.html +0 -0
  6. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/contracts_proxies_nativeTokenProxy.js.html +0 -0
  7. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/contracts_proxies_validatorsProxy.js.html +0 -0
  8. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/contracts_proxies_votingProxy.js.html +0 -0
  9. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/contracts_validators.js.html +0 -0
  10. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Bold-webfont.eot +0 -0
  11. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Bold-webfont.svg +0 -0
  12. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Bold-webfont.woff +0 -0
  13. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-BoldItalic-webfont.eot +0 -0
  14. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-BoldItalic-webfont.svg +0 -0
  15. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-BoldItalic-webfont.woff +0 -0
  16. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Italic-webfont.eot +0 -0
  17. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Italic-webfont.svg +0 -0
  18. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Italic-webfont.woff +0 -0
  19. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Light-webfont.eot +0 -0
  20. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Light-webfont.svg +0 -0
  21. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Light-webfont.woff +0 -0
  22. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-LightItalic-webfont.eot +0 -0
  23. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-LightItalic-webfont.svg +0 -0
  24. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-LightItalic-webfont.woff +0 -0
  25. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Regular-webfont.eot +0 -0
  26. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Regular-webfont.svg +0 -0
  27. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Regular-webfont.woff +0 -0
  28. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Semibold-webfont.eot +0 -0
  29. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Semibold-webfont.svg +0 -0
  30. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Semibold-webfont.ttf +0 -0
  31. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-Semibold-webfont.woff +0 -0
  32. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-SemiboldItalic-webfont.eot +0 -0
  33. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-SemiboldItalic-webfont.svg +0 -0
  34. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-SemiboldItalic-webfont.ttf +0 -0
  35. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/fonts/OpenSans-SemiboldItalic-webfont.woff +0 -0
  36. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/global.html +0 -0
  37. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/icons/home.svg +0 -0
  38. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/icons/search.svg +0 -0
  39. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/index.html +0 -0
  40. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/machine.js.html +0 -0
  41. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/scripts/linenumber.js +0 -0
  42. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/scripts/pagelocation.js +0 -0
  43. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/standards_roles.js.html +0 -0
  44. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/standards_token.js.html +0 -0
  45. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/styles/collapse.css +0 -0
  46. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/styles/jsdoc-default.css +0 -0
  47. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/styles/prettify-jsdoc.css +0 -0
  48. package/docs/@leofcoin/chain/{1.0.7 → 1.0.10}/styles/prettify-tomorrow.css +0 -0
  49. package/package.json +2 -2
  50. package/out/@leofcoin/chain/1.0.7/chain.js.html +0 -645
  51. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-Bold-webfont.eot +0 -0
  52. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-Bold-webfont.svg +0 -1830
  53. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-Bold-webfont.woff +0 -0
  54. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-BoldItalic-webfont.eot +0 -0
  55. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-BoldItalic-webfont.svg +0 -1830
  56. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-BoldItalic-webfont.woff +0 -0
  57. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-Italic-webfont.eot +0 -0
  58. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-Italic-webfont.svg +0 -1830
  59. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-Italic-webfont.woff +0 -0
  60. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-Light-webfont.eot +0 -0
  61. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-Light-webfont.svg +0 -1831
  62. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-Light-webfont.woff +0 -0
  63. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-LightItalic-webfont.eot +0 -0
  64. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-LightItalic-webfont.svg +0 -1835
  65. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-LightItalic-webfont.woff +0 -0
  66. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-Regular-webfont.eot +0 -0
  67. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-Regular-webfont.svg +0 -1831
  68. package/out/@leofcoin/chain/1.0.7/fonts/OpenSans-Regular-webfont.woff +0 -0
  69. package/out/@leofcoin/chain/1.0.7/global.html +0 -477
  70. package/out/@leofcoin/chain/1.0.7/index.html +0 -69
  71. package/out/@leofcoin/chain/1.0.7/machine.js.html +0 -180
  72. package/out/@leofcoin/chain/1.0.7/scripts/linenumber.js +0 -25
  73. package/out/@leofcoin/chain/1.0.7/scripts/prettify/Apache-License-2.0.txt +0 -202
  74. package/out/@leofcoin/chain/1.0.7/scripts/prettify/lang-css.js +0 -2
  75. package/out/@leofcoin/chain/1.0.7/scripts/prettify/prettify.js +0 -28
  76. package/out/@leofcoin/chain/1.0.7/styles/jsdoc-default.css +0 -358
  77. package/out/@leofcoin/chain/1.0.7/styles/prettify-jsdoc.css +0 -111
  78. package/out/@leofcoin/chain/1.0.7/styles/prettify-tomorrow.css +0 -132
@@ -1,645 +0,0 @@
1
- <!DOCTYPE html>
2
- <html lang="en">
3
- <head>
4
- <meta charset="utf-8">
5
- <title>JSDoc: Source: chain.js</title>
6
-
7
- <script src="scripts/prettify/prettify.js"> </script>
8
- <script src="scripts/prettify/lang-css.js"> </script>
9
- <!--[if lt IE 9]>
10
- <script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
11
- <![endif]-->
12
- <link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">
13
- <link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css">
14
- </head>
15
-
16
- <body>
17
-
18
- <div id="main">
19
-
20
- <h1 class="page-title">Source: chain.js</h1>
21
-
22
-
23
-
24
-
25
-
26
-
27
- <section>
28
- <article>
29
- <pre class="prettyprint source linenums"><code>import { BigNumber, formatUnits, parseUnits } from './utils/utils'
30
- import Machine from './machine'
31
- import lib from './lib'
32
-
33
- globalThis.BigNumber = BigNumber
34
-
35
- const { ContractMessage, TransactionMessage, BlockMessage, BWMessage, BWRequestMessage } = lib
36
- // check if browser or local
37
- export default class Chain {
38
- #validators = []
39
- #blocks = []
40
- #machine
41
- #runningEpoch = false
42
- #lastBlock = {index: 0, previousHash: '0x0'}
43
-
44
- constructor() {
45
- return this.#init()
46
- }
47
-
48
- get lib() {
49
- return lib
50
- }
51
-
52
- get lastBlock() {
53
- return this.#lastBlock
54
- }
55
-
56
- get nativeToken() {
57
- return lib.nativeToken
58
- }
59
-
60
- get validators() {
61
- return [...this.#validators]
62
- }
63
-
64
- get blocks() {
65
- return [...this.#blocks]
66
- }
67
-
68
- async hasTransactionToHandle() {
69
- const size = await transactionPoolStore.size()
70
- if (size > 0) return true
71
- return false
72
- }
73
-
74
- async #runEpoch() {
75
- const validators = await this.staticCall(lib.validators, 'validators')
76
- if (!validators[peernet.id]?.active) return
77
-
78
- this.#runningEpoch = true
79
- const start = new Date().getTime()
80
- await this.#createBlock()
81
- const end = new Date().getTime()
82
- console.log((end - start) / 1000 + ' s');
83
- if (await this.hasTransactionToHandle()) return this.#runEpoch()
84
- this.#runningEpoch = false
85
- }
86
-
87
- async #setup() {
88
- await contractStore.put(lib.contractFactory, lib.contractFactoryMessage)
89
- await contractStore.put(lib.nativeToken, lib.nativeTokenMessage)
90
- await contractStore.put(lib.validators, lib.validatorsMessage)
91
- await contractStore.put(lib.nameService, lib.nameServiceMessage)
92
- console.log('handle native contracts');
93
- // handle native contracts
94
- }
95
-
96
- async #sync() {
97
- let promises = []
98
- for (const peer of peernet.connections) {
99
- if (peer.peerId !== this.id) {
100
- let data = new peernet.protos['peernet-request']({request: 'lastBlock'})
101
-
102
- const node = await peernet.prepareMessage(id, data.encoded)
103
- promises.push(peer.request(node.encoded))
104
- }
105
- }
106
- // if (this.)
107
-
108
- promises = await Promise.allSettled(promises)
109
- promises = promises.reduce((set, c) => {
110
- console.log({c});
111
- if (c.index > set.index) {
112
- set.index = c.index
113
- set.hash = c.hash
114
- }
115
- return set
116
- }, {index: 0, hash: '0x0'})
117
- // get lastblock
118
- }
119
-
120
- async #init() {
121
- // this.node = await new Node()
122
- this.participants = []
123
- const initialized = await contractStore.has(lib.contractFactory)
124
- if (!initialized) await this.#setup()
125
-
126
- this.#machine = await new Machine()
127
- this.utils = { BigNumber, formatUnits, parseUnits }
128
-
129
- try {
130
- let localBlock = await chainStore.get('lastBlock')
131
- localBlock = await peernet.get(new TextDecoder().decode(localBlock))
132
- localBlock = new BlockMessage(localBlock)
133
- this.#lastBlock = {...localBlock.decoded, hash: localBlock.hash}
134
- // console.log(this.lastBlock.decoded.transactions);
135
- } catch (e) {
136
- await this.#sync()
137
- // this.#setup()
138
- }
139
-
140
- await peernet.addRequestHandler('bw-request-message', () => {
141
-
142
- return new BWMessage(peernet.client.bw) || { up: 0, down: 0 }
143
- })
144
-
145
- await peernet.addRequestHandler('lastBlock', this.#lastBlockHandler.bind(this))
146
-
147
- peernet.subscribe('add-block', this.#addBlock.bind(this))
148
-
149
- peernet.subscribe('add-transaction', async transaction => {
150
- try {
151
- transaction = new TransactionMessage(transaction)
152
- await transactionPoolStore.put(transaction.hash, transaction.encoded)
153
- if (await this.hasTransactionToHandle() &amp;&amp; !this.#runningEpoch) return this.#runEpoch()
154
- } catch (e) {
155
- throw Error('invalid transaction')
156
- }
157
- })
158
-
159
- pubsub.subscribe('peer:connected', this.#peerConnected.bind(this))
160
-
161
- // load local blocks
162
- await this.resolveBlocks()
163
- return this
164
- }
165
-
166
- async #peerConnected(peer) {
167
- let node = new peernet.protos['peernet-request']({request: 'lastBlock'})
168
- node = await peernet.prepareMessage(peer.id, node.encoded)
169
- let response = await peer.request(node.encoded)
170
- response = new Uint8Array(Object.values(response))
171
- const proto = new globalThis.peernet.protos['peernet-message'](response)
172
- response = new globalThis.peernet.protos['peernet-response'](proto.decoded.data)
173
- let lastBlock = JSON.parse(new TextDecoder().decode(response.decoded.response))
174
-
175
- if (!this.lastBlock || this.lastBlock.index &lt; lastBlock.index) {
176
- // TODO: check if valid
177
- const localIndex = this.lastBlock ? this.lastBlock.index : 0
178
- const index = lastBlock.index
179
- await this.resolveBlock(lastBlock.hash)
180
- this.#lastBlock = this.#blocks[this.#blocks.length - 1]
181
- console.log({lastBlock: this.#lastBlock});
182
- console.log(this.#blocks);
183
- let blocksSynced = localIndex > 0 ? localIndex - index : index
184
- blocksSynced += 1
185
- debug(`synced ${blocksSynced} ${blocksSynced > 1 ? 'blocks' : 'block'}`)
186
-
187
- const end = this.#blocks.length
188
- const start = (this.#blocks.length) - blocksSynced
189
- await this.#loadBlocks(this.#blocks)
190
- const message = new BlockMessage(this.lastBlock)
191
- await blockStore.put(message.hash, message.encoded)
192
- await chainStore.put('lastBlock', new TextEncoder().encode(this.lastBlock.hash))
193
- }
194
- }
195
-
196
- async #lastBlockHandler() {
197
- return new peernet.protos['peernet-response']({response: new TextEncoder().encode(JSON.stringify({ hash: this.lastBlock?.hash, index: this.lastBlock?.index }))})
198
- }
199
-
200
- async resolveBlock(hash) {
201
- let block = await peernet.get(hash, 'block')
202
- if (!await peernet.has(hash, 'block')) await peernet.put(hash, block, 'block')
203
- block = await new BlockMessage(block)
204
- const size = block.encoded.length || block.encoded.byteLength
205
- block = {...block.decoded, hash}
206
- this.#blocks[block.index] = block
207
- console.log(`loaded block: ${hash} @${block.index} ${Math.round((size / 1024 / 1024) * 100) / 100} mb`);
208
- if (block.index !== 0) {
209
- return this.resolveBlock(block.previousHash)
210
- }
211
- }
212
-
213
- async resolveBlocks() {
214
- try {
215
-
216
- const localBlock = await chainStore.get('lastBlock')
217
- const hash = new TextDecoder().decode(localBlock)
218
- if (hash !== '0x0')
219
- await this.resolveBlock(new TextDecoder().decode(localBlock))
220
- this.#lastBlock = this.#blocks[this.#blocks.length - 1]
221
- await this.#loadBlocks(this.#blocks)
222
- } catch (e) {
223
- await chainStore.put('lastBlock', new TextEncoder().encode('0x0'))
224
- return this.resolveBlocks()
225
- // console.log(e);
226
- }
227
- }
228
-
229
- async #loadBlocks(blocks) {
230
- for (const block of blocks) {
231
- if (!block.loaded) {
232
- for (const transaction of block.transactions) {
233
- try {
234
- await this.#machine.execute(transaction.to, transaction.method, transaction.params)
235
-
236
- } catch (e) {
237
- console.log(e);
238
- }
239
- }
240
- block.loaded = true
241
- // let message = await peernet.get(block.hash, 'block')
242
-
243
- // const compressed = pako.deflate(message);
244
- // const result = pako.inflate(compressed);
245
- // console.log(result.length, compressed.length);
246
- //
247
- // console.log(result.length - compressed.length);
248
-
249
- // message = new BlockMessage(message)
250
- // for (const transaction of message.decoded.transactions) {
251
- // try {
252
- // await this.#machine.execute(transaction.to, transaction.method, transaction.params)
253
- //
254
- // } catch (e) {
255
- // // console.log(e);
256
- // }
257
- // }
258
- // block.loaded = true
259
- }
260
- }
261
- }
262
-
263
- async #executeTransaction({hash, from, to, method, params, nonce}) {
264
- try {
265
- let result = await this.#machine.execute(to, method, params, from, nonce)
266
- // if (!result) result = this.#machine.state
267
- pubsub.publish(`transaction.completed.${hash}`, {status: 'fulfilled', hash})
268
- return result ? result : 'no state change'
269
- } catch (e) {
270
- pubsub.publish(`transaction.completed.${hash}`, {status: 'fail', hash, error: e})
271
- throw e
272
- }
273
- }
274
-
275
- async #addBlock(block) {
276
- const blockMessage = new BlockMessage(block)
277
- // if (!Buffer.isBuffer(block)) block = Buffer.from(block, 'hex')
278
- // const transactionJob = async transaction => {
279
- // try {
280
- // transaction = await transactionPoolStore.get(transaction)
281
- // } catch (e) {
282
- // try {
283
- // transaction = await peernet.get(transaction, 'transaction')
284
- // } catch (e) {
285
- // console.warn(`couldn't resolve ${transaction}`);
286
- // }
287
- // }
288
- // transaction = new TransactionMessage(transaction)
289
- // return transaction
290
- // }
291
- await Promise.all(blockMessage.decoded.transactions
292
- .map(transaction => transactionPoolStore.delete(transaction.hash)))
293
-
294
- // let transactions = blockMessage.decoded.transactions.map(tx => transactionJob(tx))
295
- // transactions = await Promise.all(transactions)
296
- this.#lastBlock = {hash: blockMessage.hash, ...blockMessage.decoded}
297
- await blockStore.put(blockMessage.hash, blockMessage.encoded)
298
- await chainStore.put('lastBlock', new TextEncoder().encode(blockMessage.hash))
299
- debug(`added block: ${blockMessage.hash}`)
300
- let promises = []
301
- let contracts = []
302
- for (let transaction of blockMessage.decoded.transactions) {
303
- // await transactionStore.put(transaction.hash, transaction.encoded)
304
- const index = contracts.indexOf(transaction.to)
305
- if (index === -1) contracts.push(transaction.to)
306
- promises.push(this.#executeTransaction(transaction))
307
- }
308
- try {
309
- promises = await Promise.allSettled(promises)
310
-
311
- // todo finish state
312
- // for (const contract of contracts) {
313
- // const state = await this.#machine.get(contract, 'state')
314
- // // await stateStore.put(contract, state)
315
- // console.log(state);
316
- // }
317
- pubsub.publish('block-processed', blockMessage.decoded)
318
- } catch (e) {
319
- console.log(e);
320
- }
321
-
322
- }
323
-
324
-
325
-
326
- async participate() {
327
- // TODO: validate participant
328
- // hold min amount of 50k ART for 7 days
329
- // lock the 50k
330
- // introduce peer-reputation
331
- // peerReputation(peerId)
332
- // {bandwith: {up, down}, uptime}
333
- if (!await this.staticCall(lib.validators, 'has', [peernet.id])) await this.createTransactionFrom(peernet.id, lib.validators, 'addValidator', [peernet.id])
334
- if (await this.hasTransactionToHandle() &amp;&amp; !this.#runningEpoch) return this.#runEpoch()
335
- }
336
-
337
- calculateFee(transaction) {
338
- // excluded from fees
339
- if (transaction.decoded.to === lib.validators) return 0
340
- // fee per gb
341
- return (transaction.encoded.length / 1024) / 1e-6
342
- }
343
-
344
- async #createBlock() {
345
- let transactions = await transactionPoolStore.get()
346
-
347
- if (Object.keys(transactions)?.length === 0 ) return
348
- let block = {
349
- transactions: [],
350
- validators: [],
351
- fees: 0
352
- }
353
-
354
- let _transactions = []
355
-
356
- // exclude failing tx
357
- for (let transaction of Object.values(transactions)) {
358
- transaction = new TransactionMessage(new Uint8Array(transaction, transaction.byteOffset, transaction.byteLength))
359
-
360
- block.fees += Number(lib.calculateFee(transaction))
361
- _transactions.push({...transaction.decoded, hash: transaction.hash })
362
- }
363
-
364
- transactions = _transactions.sort((a, b) => a.nonce - b.nonce)
365
- _transactions = []
366
- for (let transaction of transactions) {
367
- try {
368
- await this.#executeTransaction(transaction)
369
- _transactions.push(transaction)
370
- } catch (e) {
371
- transaction = new TransactionMessage(transaction)
372
- block.fees -= Number(lib.calculateFee(transaction))
373
- await transactionPoolStore.delete(transaction.hash)
374
-
375
- }
376
- }
377
- transactions = _transactions
378
- // don't add empty block
379
- if (transactions.length === 0) return
380
-
381
- block.transactions = transactions
382
- const validators = await this.staticCall(lib.validators, 'validators')
383
- console.log({validators});
384
- // block.validators = Object.keys(block.validators).reduce((set, key) => {
385
- // if (block.validators[key].active) {
386
- // push({
387
- // address: key
388
- // })
389
- // }
390
- // }, [])
391
- const peers = {}
392
- for (const entry of peernet.peerEntries) {
393
- peers[entry[0]] = entry[1]
394
- }
395
- for (const validator of Object.keys(validators)) {
396
- if (validators[validator].active) {
397
- const peer = peers[validator]
398
- if (peer &amp;&amp; peer.connected) {
399
- let data = new BWRequestMessage()
400
- const node = await peernet.prepareMessage(validator, data.encoded)
401
- try {
402
- const bw = await peer.request(node.encoded)
403
- console.log(bw);
404
- block.validators.push({
405
- address: validator,
406
- bw: bw.up + bw.down
407
- })
408
- } catch(e) {
409
-
410
- }
411
-
412
- } else if (peernet.id === validator) {
413
- block.validators.push({
414
- address: peernet.id,
415
- bw: peernet.bw.up + peernet.bw.down
416
- })
417
-
418
- }
419
- }
420
-
421
- }
422
-
423
- console.log(block.validators);
424
-
425
- block.reward = 150
426
- block.validators = block.validators.map(validator => {
427
- validator.reward = String(Number(block.fees) + block.reward / block.validators.length)
428
- delete validator.bw
429
- return validator
430
- })
431
- // block.validators = lib.calculateValidatorReward(block.validators, block.fees)
432
-
433
- block.index = this.lastBlock?.index
434
- if (block.index === undefined) block.index = 0
435
- else block.index += 1
436
-
437
- block.previousHash = this.lastBlock?.hash || '0x0'
438
- block.timestamp = new Date().getTime()
439
-
440
- const parts = String(block.fees).split('.')
441
- let decimals = 0
442
- if (parts[1]) {
443
- const potentional = parts[1].split('e')
444
- if (potentional[0] !== parts[1]) {
445
- parts[1] = potentional[0]
446
- decimals = Number(potentional[1]?.replace(/\-|\+/g, '')) + Number(potentional[0].length)
447
- } else {
448
- decimals = parts[1].length
449
- }
450
-
451
- }
452
- block.fees = Number.parseFloat(String(block.fees)).toFixed(decimals)
453
-
454
- try {
455
- let blockMessage = new BlockMessage(block)
456
- this.#lastBlock = {...block, hash: blockMessage.hash}
457
- peernet.publish('add-block', blockMessage.encoded)
458
- this.#addBlock(blockMessage.encoded)
459
- } catch (e) {
460
- throw Error(`invalid block ${block}`)
461
- }
462
- // data = await this.#machine.execute(to, method, params)
463
- // transactionStore.put(message.hash, message.encoded)
464
- }
465
-
466
- async getNonce(address) {
467
- let transactions = await transactionPoolStore.get()
468
- transactions = Object.keys(transactions).map(tx => new TransactionMessage(transactions[tx]))
469
- transactions = transactions.filter(tx => tx.decoded.from === address)
470
- transactions = transactions.map(tx => { return {...tx.decoded, hash: tx.hash} })
471
- if (this.lastBlock &amp;&amp; transactions.length === 0) {
472
- let block = await peernet.get(this.lastBlock.hash)
473
- block = new BlockMessage(block)
474
-
475
- // for (let tx of block.decoded?.transactions) {
476
- // tx = await peernet.get(tx, 'transaction')
477
- // transactions.push(new TransactionMessage(tx))
478
- // }
479
- transactions = transactions.filter(tx => tx.from === address)
480
- while (transactions.length === 0 &amp;&amp; block.decoded.index !== 0) {
481
- block = await blockStore.get(block.decoded.previousHash)
482
- block = new BlockMessage(block)
483
- transactions = block.decoded.transactions.filter(tx => tx.from === address)
484
- }
485
-
486
- }
487
- if (transactions.length === 0) return 0
488
-
489
- transactions = transactions.sort((a, b) => a.timestamp - b.timestamp)
490
- return transactions[transactions.length - 1].nonce
491
- }
492
-
493
- /**
494
- * whenever method = createContract params should hold the contract hash
495
- *
496
- * example: [hash]
497
- * createTransaction('0x0', 'createContract', [hash])
498
- */
499
- createTransaction(to, method, params, nonce) {
500
- return this.createTransactionFrom(peernet.id, to, method, params, nonce)
501
- }
502
- /**
503
- * every tx done is trough contracts so no need for amount
504
- * data is undefined when nothing is returned
505
- * error is thrown on error so undefined data doesn't mean there is an error...
506
- */
507
- async createTransactionFrom(from, to, method, params, nonce) {
508
- if (nonce === undefined) {
509
- nonce = await this.getNonce(from)
510
- nonce += 1
511
- }
512
-
513
- let data
514
- let message = new TransactionMessage({timestamp: new Date().getTime(), from, to, nonce, method, params})
515
- try {
516
- // await transactionPoolStore.put(message.hash, new TextEncoder().encode(JSON.stringify({signature, message: message.encoded})))
517
- await transactionPoolStore.put(message.hash, message.encoded)
518
- peernet.publish('add-transaction', message.encoded)
519
- } catch (e) {
520
- throw e
521
- }
522
- const wait = () => new Promise((resolve, reject) => {
523
- const completed = result => {
524
- result.status === 'fulfilled' ? resolve(result.hash) : reject({hash: result.hash, error: result.error})
525
-
526
- pubsub.unsubscribe(`transaction.completed.${message.hash}`, completed)
527
- }
528
- pubsub.subscribe(`transaction.completed.${message.hash}`, completed)
529
- })
530
-
531
- if (await this.hasTransactionToHandle() &amp;&amp; !this.#runningEpoch) this.#runEpoch()
532
- return {hash: message.hash, data, fee: lib.calculateFee(message), wait}
533
- }
534
-
535
- async createContractMessage(creator, contract, constructorParameters = []) {
536
- return new ContractMessage({
537
- creator,
538
- contract,
539
- constructorParameters
540
- })
541
- }
542
-
543
- async createContractAddress(creator, contract, constructorParameters = []) {
544
- return this.createContractMessage(creator, contract, constructorParameters)
545
- .hash
546
- }
547
-
548
- /**
549
- *
550
- */
551
- async deployContract(contract, params = []) {
552
- globalThis.msg = {sender: peernet.id, call: this.call}
553
-
554
- const hash = await this.createContractAddress(creator, contract, params)
555
-
556
- try {
557
- const tx = await this.createTransactionFrom(peernet.id, lib.contractFactory, 'deployContract', [hash, creator, contract, constructorParameters])
558
- } catch (e) {
559
- throw e
560
- }
561
- return this.#machine.addContract(message)
562
- }
563
-
564
- #createMessage(sender = peernet.id) {
565
- return {
566
- sender: peernet.id,
567
- call: this.call,
568
- staticCall: this.staticCall,
569
- delegate: this.delegate,
570
- staticDelegate: this.staticDelegate
571
- }
572
- }
573
-
574
- internalCall(sender, contract, method, params) {
575
- globalThis.msg = this.#createMessage(sender)
576
-
577
- return this.#machine.execute(contract, method, params)
578
- }
579
-
580
- call(contract, method, params) {
581
- globalThis.msg = this.#createMessage()
582
-
583
- return this.#machine.execute(contract, method, params)
584
- }
585
-
586
- staticCall(contract, method, params) {
587
- globalThis.msg = this.#createMessage()
588
- return this.#machine.get(contract, method, params)
589
- }
590
-
591
- delegate(contract, method, params) {
592
- globalThis.msg = this.#createMessage()
593
-
594
- return this.#machine.execute(contract, method, params)
595
- }
596
-
597
- staticDelegate(contract, method, params) {
598
- globalThis.msg = this.#createMessage()
599
-
600
- return this.#machine.get(contract, method, params)
601
- }
602
-
603
- mint(to, amount) {
604
- return this.call(lib.nativeToken, 'mint', [to, amount])
605
- }
606
-
607
- transfer(from, to, amount) {
608
- return this.call(lib.nativeToken, 'transfer', [from, to, amount])
609
- }
610
-
611
- get balances() {
612
- return this.staticCall(lib.nativeToken, 'balances')
613
- }
614
-
615
- deleteAll() {
616
- return this.#machine.deleteAll()
617
- }
618
-
619
- lookup(name) {
620
- return this.call(lib.nameService, 'lookup', [name])
621
- }
622
- }
623
- </code></pre>
624
- </article>
625
- </section>
626
-
627
-
628
-
629
-
630
- </div>
631
-
632
- <nav>
633
- <h2><a href="index.html">Home</a></h2><h3>Global</h3><ul><li><a href="global.html#addContract">addContract</a></li><li><a href="global.html#createTransaction">createTransaction</a></li><li><a href="global.html#createTransactionFrom">createTransactionFrom</a></li><li><a href="global.html#deployContract">deployContract</a></li></ul>
634
- </nav>
635
-
636
- <br class="clear">
637
-
638
- <footer>
639
- Documentation generated by <a href="https://github.com/jsdoc/jsdoc">JSDoc 3.6.10</a> on Thu May 26 2022 18:02:07 GMT+0200 (Midden-Europese zomertijd)
640
- </footer>
641
-
642
- <script> prettyPrint(); </script>
643
- <script src="scripts/linenumber.js"> </script>
644
- </body>
645
- </html>