tx · E1x1qRdbqayi6HGBkecMcSADfUvHttcbbiSofg4AcFwE

3MxorpV6jKdNhrzHSujnjVXu7fr8PCHhMwi:  -0.01400000 Waves

2020.03.11 04:49 [903849] smart account 3MxorpV6jKdNhrzHSujnjVXu7fr8PCHhMwi > SELF 0.00000000 Waves

{ "type": 13, "id": "E1x1qRdbqayi6HGBkecMcSADfUvHttcbbiSofg4AcFwE", "fee": 1400000, "feeAssetId": null, "timestamp": 1583891511610, "version": 1, "sender": "3MxorpV6jKdNhrzHSujnjVXu7fr8PCHhMwi", "senderPublicKey": "BZT5fzv8ZeHVn8xAGZVXZHUvoAkdRNCbtEuBn3pCuXEH", "proofs": [ "2m4erRqejPeyPEdx5CTeNUVsdbR6m5VKdZgnghRqbrUxgayLvVN2q7ybgoQzTtNPH9FoSxafZGrFUBfWXt43GVC3" ], "script": "base64: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", "chainId": 84, "height": 903849, "spentComplexity": 0 } View: original | compacted Prev: HfsuBxwEwcqAbd26XgsgHLCqhuxCy1547RLSCuUTtG8n Next: E9NCyoFAUqQxX9z3VX6Y57f5jVV2CJuyS825qCwRVXZi Diff:
OldNewDifferences
66 let RandomizeKey = fromBase58String("BZT5fzv8ZeHVn8xAGZVXZHUvoAkdRNCbtEuBn3pCuXEH")
77
88 let deployInfo = "added data functionality (testphase)"
9+
10+let asset = base58'6khhQRn6E7dsLqxnkGHnEKoZZJv9U7bhadzprWvjAi6m'
911
1012 func encryptData (message,pKey) = {
1113 let output = "rsaVerify(Sha256 ,message,pKey,pKey)"
1921 }
2022
2123
22-func randomize (rsaSign,thisSession) = {
23- let gameId = thisSession
24- let rsaSigValid = sigVerify(toBytes(gameId), toBytes(rsaSign), RandomizeKey)
25- if (rsaSigValid)
26- then {
27- let rand = (toInt(sha256(toBytes(rsaSign))) % 6)
28- if ((0 > rand))
29- then ((-1 * rand) + 1)
30- else (rand + 1)
31- }
32- else throw("Invalid RSA signature")
24+func getData (dataKey) = {
25+ let dataPackage = getStringValue(this, dataKey)
26+ dataPackage
3327 }
3428
3529
36-func listParser (dataString,separator) = {
37- let choppedlist = "x"
38- choppedlist
39- }
40-
41-
42-func listBuilder (receiver,amount,txid) = {
43- let compiledList = "placeholder"
44- compiledList
45- }
46-
47-
48-func getData (dataKey) = {
49- let dataPackage = getStringValue(this, dataKey)
50- dataPackage
30+func updateField (dataList,listSeparator,fieldIndex,newFieldData) = {
31+ let numFields = size(dataList)
32+ if ((numFields >= fieldIndex))
33+ then if ((fieldIndex == 0))
34+ then {
35+ let field0 = newFieldData
36+ let field1 = extract(split(dataList, ";")[1])
37+ let field2 = extract(split(dataList, ";")[2])
38+ let field3 = extract(split(dataList, ";")[3])
39+ let field4 = extract(split(dataList, ";")[4])
40+ let field5 = extract(split(dataList, ";")[5])
41+ let field6 = extract(split(dataList, ";")[6])
42+ let field7 = extract(split(dataList, ";")[7])
43+ let returnString = ((((((((((((((field0 + listSeparator) + field1) + listSeparator) + field2) + listSeparator) + field3) + listSeparator) + field4) + listSeparator) + field5) + listSeparator) + field6) + listSeparator) + field7)
44+ returnString
45+ }
46+ else throw("error creating datastring")
47+ else throw(("field index out of range. Number of fields for string is: " + toString(numFields)))
5148 }
5249
5350
5956 let callerAccount = toBase58String(extract(i.callerPublicKey))
6057 let callerAddress = toBase58String(extract(i.caller.bytes))
6158 let callerTxId = i.transactionId
62- let asset = base58'6khhQRn6E7dsLqxnkGHnEKoZZJv9U7bhadzprWvjAi6m'
6359 let sizing = if ((paid.amount == 100000000))
6460 then "S"
6561 else if ((paid.amount == 200000000))
7066 let messageData = (((((((("SUBMITTED" + ";") + toBase58String(extract(i.caller.bytes))) + ";") + toString(paid.amount)) + ";") + toString(height)) + ";") + sizing)
7167 if ((sizing == "error"))
7268 then throw("Prices are 1, 2, and 4 waves. Other amounts will be rejected by the smart contract")
73- else {
74- let tokenAmount = (paid.amount * 3)
75- WriteSet([DataEntry(gameId, messageData)])
76- }
69+ else WriteSet([DataEntry(gameId, messageData)])
7770 }
71+
72+
73+
74+@Callable(i)
75+func finalize (txId) = if ((i.callerPublicKey != ownerPublicKey))
76+ then throw("Only owner can call finalize function")
77+ else {
78+ let coinData = getData(txId)
79+ let coinAmount = parseIntValue(extract(split(coinData, ";")[8]))
80+ let statusField = parseIntValue(extract(split(coinData, ";")[0]))
81+ let messageData = updateField(coinData, ";", 0, "COMPLETED")
82+ ScriptResult(WriteSet([DataEntry(txId, messageData)]), TransferSet([ScriptTransfer(i.caller, coinAmount, asset)]))
83+ }
7884
7985
8086 @Verifier(tx)
8187 func verify () = match tx {
82- case d: ReissueTransaction|IssueTransaction|SetScriptTransaction =>
88+ case d: TransferTransaction|ReissueTransaction|IssueTransaction|SetScriptTransaction =>
8389 sigVerify(tx.bodyBytes, tx.proofs[0], ownerPublicKey)
8490 case d: DataTransaction =>
8591 sigVerify(tx.bodyBytes, tx.proofs[0], ownerPublicKey)
86- case d: TransferTransaction =>
87- true
8892 case _ =>
8993 false
9094 }
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 3 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let ownerPublicKey = base58'BZT5fzv8ZeHVn8xAGZVXZHUvoAkdRNCbtEuBn3pCuXEH'
55
66 let RandomizeKey = fromBase58String("BZT5fzv8ZeHVn8xAGZVXZHUvoAkdRNCbtEuBn3pCuXEH")
77
88 let deployInfo = "added data functionality (testphase)"
9+
10+let asset = base58'6khhQRn6E7dsLqxnkGHnEKoZZJv9U7bhadzprWvjAi6m'
911
1012 func encryptData (message,pKey) = {
1113 let output = "rsaVerify(Sha256 ,message,pKey,pKey)"
1214 output
1315 }
1416
1517
1618 func sessionId () = {
1719 let gid = toInt(sha256(toBytes(lastBlock.height)))
1820 gid
1921 }
2022
2123
22-func randomize (rsaSign,thisSession) = {
23- let gameId = thisSession
24- let rsaSigValid = sigVerify(toBytes(gameId), toBytes(rsaSign), RandomizeKey)
25- if (rsaSigValid)
26- then {
27- let rand = (toInt(sha256(toBytes(rsaSign))) % 6)
28- if ((0 > rand))
29- then ((-1 * rand) + 1)
30- else (rand + 1)
31- }
32- else throw("Invalid RSA signature")
24+func getData (dataKey) = {
25+ let dataPackage = getStringValue(this, dataKey)
26+ dataPackage
3327 }
3428
3529
36-func listParser (dataString,separator) = {
37- let choppedlist = "x"
38- choppedlist
39- }
40-
41-
42-func listBuilder (receiver,amount,txid) = {
43- let compiledList = "placeholder"
44- compiledList
45- }
46-
47-
48-func getData (dataKey) = {
49- let dataPackage = getStringValue(this, dataKey)
50- dataPackage
30+func updateField (dataList,listSeparator,fieldIndex,newFieldData) = {
31+ let numFields = size(dataList)
32+ if ((numFields >= fieldIndex))
33+ then if ((fieldIndex == 0))
34+ then {
35+ let field0 = newFieldData
36+ let field1 = extract(split(dataList, ";")[1])
37+ let field2 = extract(split(dataList, ";")[2])
38+ let field3 = extract(split(dataList, ";")[3])
39+ let field4 = extract(split(dataList, ";")[4])
40+ let field5 = extract(split(dataList, ";")[5])
41+ let field6 = extract(split(dataList, ";")[6])
42+ let field7 = extract(split(dataList, ";")[7])
43+ let returnString = ((((((((((((((field0 + listSeparator) + field1) + listSeparator) + field2) + listSeparator) + field3) + listSeparator) + field4) + listSeparator) + field5) + listSeparator) + field6) + listSeparator) + field7)
44+ returnString
45+ }
46+ else throw("error creating datastring")
47+ else throw(("field index out of range. Number of fields for string is: " + toString(numFields)))
5148 }
5249
5350
5451 @Callable(i)
5552 func initiate () = {
5653 let gameId = toBase58String(i.transactionId)
5754 let paid = extract(i.payment)
5855 let message = "default message for now"
5956 let callerAccount = toBase58String(extract(i.callerPublicKey))
6057 let callerAddress = toBase58String(extract(i.caller.bytes))
6158 let callerTxId = i.transactionId
62- let asset = base58'6khhQRn6E7dsLqxnkGHnEKoZZJv9U7bhadzprWvjAi6m'
6359 let sizing = if ((paid.amount == 100000000))
6460 then "S"
6561 else if ((paid.amount == 200000000))
6662 then "M"
6763 else if ((paid.amount == 400000000))
6864 then "L"
6965 else "error"
7066 let messageData = (((((((("SUBMITTED" + ";") + toBase58String(extract(i.caller.bytes))) + ";") + toString(paid.amount)) + ";") + toString(height)) + ";") + sizing)
7167 if ((sizing == "error"))
7268 then throw("Prices are 1, 2, and 4 waves. Other amounts will be rejected by the smart contract")
73- else {
74- let tokenAmount = (paid.amount * 3)
75- WriteSet([DataEntry(gameId, messageData)])
76- }
69+ else WriteSet([DataEntry(gameId, messageData)])
7770 }
71+
72+
73+
74+@Callable(i)
75+func finalize (txId) = if ((i.callerPublicKey != ownerPublicKey))
76+ then throw("Only owner can call finalize function")
77+ else {
78+ let coinData = getData(txId)
79+ let coinAmount = parseIntValue(extract(split(coinData, ";")[8]))
80+ let statusField = parseIntValue(extract(split(coinData, ";")[0]))
81+ let messageData = updateField(coinData, ";", 0, "COMPLETED")
82+ ScriptResult(WriteSet([DataEntry(txId, messageData)]), TransferSet([ScriptTransfer(i.caller, coinAmount, asset)]))
83+ }
7884
7985
8086 @Verifier(tx)
8187 func verify () = match tx {
82- case d: ReissueTransaction|IssueTransaction|SetScriptTransaction =>
88+ case d: TransferTransaction|ReissueTransaction|IssueTransaction|SetScriptTransaction =>
8389 sigVerify(tx.bodyBytes, tx.proofs[0], ownerPublicKey)
8490 case d: DataTransaction =>
8591 sigVerify(tx.bodyBytes, tx.proofs[0], ownerPublicKey)
86- case d: TransferTransaction =>
87- true
8892 case _ =>
8993 false
9094 }
9195

github/deemru/w8io/169f3d6 
28.40 ms