tx · BSzBjLHs51RQTYEZUxcugrV9YpwkDWMucX8hmExVYzsU 3N224YZjtUvQc3haCCvuJSLXoMMQj57CArH: -0.01000000 Waves 2021.10.22 16:34 [1757574] smart account 3N224YZjtUvQc3haCCvuJSLXoMMQj57CArH > SELF 0.00000000 Waves
{ "type": 13, "id": "BSzBjLHs51RQTYEZUxcugrV9YpwkDWMucX8hmExVYzsU", "fee": 1000000, "feeAssetId": null, "timestamp": 1634909646759, "version": 2, "chainId": 84, "sender": "3N224YZjtUvQc3haCCvuJSLXoMMQj57CArH", "senderPublicKey": "E1bLwWNENaR6ZYK4SbhSgXAzVjgxzT4oWFH4jER4JkJG", "proofs": [ "2Yi7bAbZ6XapSnGAxe2vVKJawk2koKpn3Gej2L7hgq6SQiERwrmRnJjjwcvgqPEh5HCGheE8fBg4z9nZ6zQbNTdh" ], "script": "base64:AAIFAAAAAAAAAAgIAhIECgIIAQAAAAIBAAAACWdldEFuc3dlcgAAAAMAAAAIcXVlc3Rpb24AAAAOcHJldmlvdXNBbnN3ZXIAAAAMYW5zd2Vyc0NvdW50BAAAAARoYXNoCQAB9wAAAAEJAAGbAAAAAQkAASwAAAACBQAAAAhxdWVzdGlvbgUAAAAOcHJldmlvdXNBbnN3ZXIEAAAABWluZGV4CQAEsQAAAAEFAAAABGhhc2gEAAAABHJhbmQJAABqAAAAAgUAAAAFaW5kZXgFAAAADGFuc3dlcnNDb3VudAMJAABmAAAAAgAAAAAAAAAAAAUAAAAEcmFuZAkAAGQAAAACCQAAaAAAAAIA//////////8FAAAABHJhbmQAAAAAAAAAAAEJAABkAAAAAgUAAAAEcmFuZAAAAAAAAAAAAQEAAAARZ2V0UHJldmlvdXNBbnN3ZXIAAAABAAAAB2FkZHJlc3MEAAAAByRtYXRjaDAJAAQaAAAAAgUAAAAEdGhpcwkAASwAAAACBQAAAAdhZGRyZXNzAgAAAAJfbgMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAADSW50BAAAAAFuBQAAAAckbWF0Y2gwCQABpAAAAAEFAAAAAW4FAAAAB2FkZHJlc3MAAAABAAAAAWkBAAAACWdldFJhbmRvbQAAAAIAAAAEc2FsdAAAAAxhbnN3ZXJzQ291bnQEAAAADWNhbGxlckFkZHJlc3MJAAJYAAAAAQgIBQAAAAFpAAAABmNhbGxlcgAAAAVieXRlcwQAAAAGYW5zd2VyCQEAAAAJZ2V0QW5zd2VyAAAAAwUAAAAEc2FsdAkBAAAAEWdldFByZXZpb3VzQW5zd2VyAAAAAQUAAAANY2FsbGVyQWRkcmVzcwUAAAAMYW5zd2Vyc0NvdW50CQAETAAAAAIJAQAAAAtTdHJpbmdFbnRyeQAAAAIJAAEsAAAAAgUAAAANY2FsbGVyQWRkcmVzcwIAAAALX3NhbHRfZGVidWcFAAAABHNhbHQJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAAEsAAAAAgUAAAANY2FsbGVyQWRkcmVzcwIAAAACX24FAAAABmFuc3dlcgUAAAADbmlsAAAAAQAAAAJ0eAEAAAAGdmVyaWZ5AAAAAAkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAAIBQAAAAJ0eAAAAA9zZW5kZXJQdWJsaWNLZXm1lQWC", "height": 1757574, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 9Bnue7VWud91YwtwGgbMsQ1182S33nX2xv9NuU7UkhD2 Next: HnhuW9xoADpAxXhGAU4CGofm7ob7FGR4kRfEoPdYmEac Full:
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | let answersCount = 20 | |
5 | - | ||
6 | - | let answers = ["It is certain.", "It is decidedly so.", "Without a doubt.", "Yes - definitely.", "You may rely on it.", "As I see it, yes.", "Most likely.", "Outlook good.", "Yes.", "Signs point to yes.", "Reply hazy, try again.", "Ask again later.", "Better not tell you now.", "Cannot predict now.", "Concentrate and ask again.", "Don't count on it.", "My reply is no.", "My sources say no.", "Outlook not so good.", "Very doubtful."] | |
7 | - | ||
8 | - | func getAnswer (question,previousAnswer) = { | |
4 | + | func getAnswer (question,previousAnswer,answersCount) = { | |
9 | 5 | let hash = sha256(toBytes((question + previousAnswer))) | |
10 | 6 | let index = toInt(hash) | |
11 | - | answers[(index % answersCount)] | |
7 | + | let rand = (index % answersCount) | |
8 | + | if ((0 > rand)) | |
9 | + | then ((-1 * rand) + 1) | |
10 | + | else (rand + 1) | |
12 | 11 | } | |
13 | 12 | ||
14 | 13 | ||
15 | - | func getPreviousAnswer (address) = match | |
16 | - | case | |
17 | - | | |
14 | + | func getPreviousAnswer (address) = match getInteger(this, (address + "_n")) { | |
15 | + | case n: Int => | |
16 | + | toString(n) | |
18 | 17 | case _ => | |
19 | 18 | address | |
20 | 19 | } | |
21 | 20 | ||
22 | 21 | ||
23 | 22 | @Callable(i) | |
24 | - | func | |
23 | + | func getRandom (salt,answersCount) = { | |
25 | 24 | let callerAddress = toBase58String(i.caller.bytes) | |
26 | - | let answer = getAnswer( | |
27 | - | [StringEntry((callerAddress + "_ | |
25 | + | let answer = getAnswer(salt, getPreviousAnswer(callerAddress), answersCount) | |
26 | + | [StringEntry((callerAddress + "_salt_debug"), salt), IntegerEntry((callerAddress + "_n"), answer)] | |
28 | 27 | } | |
29 | 28 | ||
29 | + | ||
30 | + | @Verifier(tx) | |
31 | + | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
30 | 32 |
github/deemru/w8io/169f3d6 27.29 ms ◑