tx · 3Y61pD3A2KLV1vJA7MMu53hFE5xstD6iyNshVztvYg8e
3MxorpV6jKdNhrzHSujnjVXu7fr8PCHhMwi: -0.01400000 Waves
2019.10.04 23:33 [705485] smart account 3MxorpV6jKdNhrzHSujnjVXu7fr8PCHhMwi > SELF 0.00000000 Waves
{
"type": 13,
"id": "3Y61pD3A2KLV1vJA7MMu53hFE5xstD6iyNshVztvYg8e",
"fee": 1400000,
"feeAssetId": null,
"timestamp": 1570221341991,
"version": 1,
"sender": "3MxorpV6jKdNhrzHSujnjVXu7fr8PCHhMwi",
"senderPublicKey": "BZT5fzv8ZeHVn8xAGZVXZHUvoAkdRNCbtEuBn3pCuXEH",
"proofs": [
"2KZpN34fUnnKofNBQLnj3AvtPvG49SvKeA4dR35h1VE7moPqLwfuTWYzZoc8ZkNKoAB54m5akANCfJDaFaUXLz7s"
],
"script": "base64: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",
"chainId": 84,
"height": 705485,
"spentComplexity": 0
}
View: original | compacted
Prev: 2DnrS96vgKjqCWTEvLHL6QZTJSszcKZCZewozravCtif
Next: 4zScMVSEjUomSn2qj2bXPS4G76F9gAEShBkrxsQwCRd3
Diff:
Old | New | | Differences |
---|
19 | 19 | | } |
---|
20 | 20 | | |
---|
21 | 21 | | |
---|
22 | | - | func randomize (rsaSign) = { |
---|
23 | | - | let gameId = sessionId() |
---|
| 22 | + | func randomize (rsaSign,thisSession) = { |
---|
| 23 | + | let gameId = thisSession |
---|
24 | 24 | | let rsaSigValid = sigVerify(toBytes(gameId), toBytes(rsaSign), RandomizeKey) |
---|
25 | 25 | | if (rsaSigValid) |
---|
26 | 26 | | then { |
---|
|
53 | 53 | | |
---|
54 | 54 | | @Callable(i) |
---|
55 | 55 | | func dispense () = { |
---|
| 56 | + | let thisSession = sessionId() |
---|
56 | 57 | | let paid = extract(i.payment) |
---|
57 | 58 | | let message = "default message for now" |
---|
58 | 59 | | let callerAccount = toBase58String(extract(i.callerPublicKey)) |
---|
|
66 | 67 | | else if ((paid.amount == 400000000)) |
---|
67 | 68 | | then "L" |
---|
68 | 69 | | else "error" |
---|
69 | | - | let messageData = ((((((((toBase58String(extract(i.callerPublicKey)) + ";") + toString(paid.amount)) + ";") + toString(height)) + ";") + toString(randomize(toString(sessionId())))) + ";") + sizing) |
---|
| 70 | + | let messageData = ((((((((((toBase58String(extract(i.callerPublicKey)) + ";") + toString(paid.amount)) + ";") + toString(height)) + ";") + toString(thisSession)) + ";") + toString(randomize(toString(thisSession), toString(thisSession)))) + ";") + sizing) |
---|
70 | 71 | | if ((sizing == "error")) |
---|
71 | 72 | | then throw("Prices are 1, 2, and 4 waves. Other amounts will be rejected by the smart contract") |
---|
72 | 73 | | else { |
---|
Full:
Old | New | | Differences |
---|
1 | 1 | | {-# STDLIB_VERSION 3 #-} |
---|
2 | 2 | | {-# SCRIPT_TYPE ACCOUNT #-} |
---|
3 | 3 | | {-# CONTENT_TYPE DAPP #-} |
---|
4 | 4 | | let ownerPublicKey = base58'BZT5fzv8ZeHVn8xAGZVXZHUvoAkdRNCbtEuBn3pCuXEH' |
---|
5 | 5 | | |
---|
6 | 6 | | let RandomizeKey = fromBase58String("BZT5fzv8ZeHVn8xAGZVXZHUvoAkdRNCbtEuBn3pCuXEH") |
---|
7 | 7 | | |
---|
8 | 8 | | let deployInfo = "added data functionality (testphase)" |
---|
9 | 9 | | |
---|
10 | 10 | | func encryptData (message,pKey) = { |
---|
11 | 11 | | let output = "rsaVerify(Sha256 ,message,pKey,pKey)" |
---|
12 | 12 | | output |
---|
13 | 13 | | } |
---|
14 | 14 | | |
---|
15 | 15 | | |
---|
16 | 16 | | func sessionId () = { |
---|
17 | 17 | | let gid = toInt(sha256(toBytes(lastBlock.height))) |
---|
18 | 18 | | gid |
---|
19 | 19 | | } |
---|
20 | 20 | | |
---|
21 | 21 | | |
---|
22 | | - | func randomize (rsaSign) = { |
---|
23 | | - | let gameId = sessionId() |
---|
| 22 | + | func randomize (rsaSign,thisSession) = { |
---|
| 23 | + | let gameId = thisSession |
---|
24 | 24 | | let rsaSigValid = sigVerify(toBytes(gameId), toBytes(rsaSign), RandomizeKey) |
---|
25 | 25 | | if (rsaSigValid) |
---|
26 | 26 | | then { |
---|
27 | 27 | | let rand = (toInt(sha256(toBytes(rsaSign))) % 6) |
---|
28 | 28 | | if ((0 > rand)) |
---|
29 | 29 | | then ((-1 * rand) + 1) |
---|
30 | 30 | | else (rand + 1) |
---|
31 | 31 | | } |
---|
32 | 32 | | else throw("Invalid RSA signature") |
---|
33 | 33 | | } |
---|
34 | 34 | | |
---|
35 | 35 | | |
---|
36 | 36 | | func listParser (dataString,separator) = { |
---|
37 | 37 | | let choppedlist = "x" |
---|
38 | 38 | | choppedlist |
---|
39 | 39 | | } |
---|
40 | 40 | | |
---|
41 | 41 | | |
---|
42 | 42 | | func listBuilder (receiver,amount,txid) = { |
---|
43 | 43 | | let compiledList = "placeholder" |
---|
44 | 44 | | compiledList |
---|
45 | 45 | | } |
---|
46 | 46 | | |
---|
47 | 47 | | |
---|
48 | 48 | | func getData (dataKey) = { |
---|
49 | 49 | | let dataPackage = getStringValue(this, dataKey) |
---|
50 | 50 | | dataPackage |
---|
51 | 51 | | } |
---|
52 | 52 | | |
---|
53 | 53 | | |
---|
54 | 54 | | @Callable(i) |
---|
55 | 55 | | func dispense () = { |
---|
| 56 | + | let thisSession = sessionId() |
---|
56 | 57 | | let paid = extract(i.payment) |
---|
57 | 58 | | let message = "default message for now" |
---|
58 | 59 | | let callerAccount = toBase58String(extract(i.callerPublicKey)) |
---|
59 | 60 | | let callerAddress = toBase58String(extract(i.caller.bytes)) |
---|
60 | 61 | | let callerTxId = i.transactionId |
---|
61 | 62 | | let asset = base58'6khhQRn6E7dsLqxnkGHnEKoZZJv9U7bhadzprWvjAi6m' |
---|
62 | 63 | | let sizing = if ((paid.amount == 100000000)) |
---|
63 | 64 | | then "S" |
---|
64 | 65 | | else if ((paid.amount == 200000000)) |
---|
65 | 66 | | then "M" |
---|
66 | 67 | | else if ((paid.amount == 400000000)) |
---|
67 | 68 | | then "L" |
---|
68 | 69 | | else "error" |
---|
69 | | - | let messageData = ((((((((toBase58String(extract(i.callerPublicKey)) + ";") + toString(paid.amount)) + ";") + toString(height)) + ";") + toString(randomize(toString(sessionId())))) + ";") + sizing) |
---|
| 70 | + | let messageData = ((((((((((toBase58String(extract(i.callerPublicKey)) + ";") + toString(paid.amount)) + ";") + toString(height)) + ";") + toString(thisSession)) + ";") + toString(randomize(toString(thisSession), toString(thisSession)))) + ";") + sizing) |
---|
70 | 71 | | if ((sizing == "error")) |
---|
71 | 72 | | then throw("Prices are 1, 2, and 4 waves. Other amounts will be rejected by the smart contract") |
---|
72 | 73 | | else { |
---|
73 | 74 | | let tokenAmount = (paid.amount * 3) |
---|
74 | 75 | | ScriptResult(WriteSet([DataEntry(callerAccount, messageData)]), TransferSet([ScriptTransfer(i.caller, tokenAmount, asset)])) |
---|
75 | 76 | | } |
---|
76 | 77 | | } |
---|
77 | 78 | | |
---|
78 | 79 | | |
---|
79 | 80 | | @Verifier(tx) |
---|
80 | 81 | | func verify () = match tx { |
---|
81 | 82 | | case d: SetScriptTransaction => |
---|
82 | 83 | | sigVerify(tx.bodyBytes, tx.proofs[0], ownerPublicKey) |
---|
83 | 84 | | case d: DataTransaction => |
---|
84 | 85 | | true |
---|
85 | 86 | | case d: TransferTransaction => |
---|
86 | 87 | | true |
---|
87 | 88 | | case d: IssueTransaction => |
---|
88 | 89 | | true |
---|
89 | 90 | | case d: ReissueTransaction => |
---|
90 | 91 | | true |
---|
91 | 92 | | case _ => |
---|
92 | 93 | | false |
---|
93 | 94 | | } |
---|
94 | 95 | | |
---|