tx · 5anrxs2uvATurPbsEwXJxJZYAY9aP55fQDXqqhr4cLVr 3N2kVUxYqFz4rHNgnVr7ffhsnC7DptJ1BzH: -0.01000000 Waves 2023.04.23 04:49 [2546557] smart account 3N2kVUxYqFz4rHNgnVr7ffhsnC7DptJ1BzH > SELF 0.00000000 Waves
{ "type": 13, "id": "5anrxs2uvATurPbsEwXJxJZYAY9aP55fQDXqqhr4cLVr", "fee": 1000000, "feeAssetId": null, "timestamp": 1682214584253, "version": 2, "chainId": 84, "sender": "3N2kVUxYqFz4rHNgnVr7ffhsnC7DptJ1BzH", "senderPublicKey": "8cCvpHrqwPyT7CYYANjtE4ZUgLzCDCqFDMVAX5RRZMPN", "proofs": [ "sNvq1Cd158uD1aM77hzApehsToZTeUwky3B28htahVraXiq6gUFF9grq5z32h3NhuMUdMzVBFJSEchw5H4vtxvW" ], "script": "base64:BgJNCAISBwoFCAgICAgSDAoKCAgICAgICAgICBIECgIICBIMCgoICAgICAgICAgIEggKBggICAgICBIDCgEIEgMKAQgSBAoCCAgSBAoCCAgFABBhZG1pbl93YWxsZXRfb25lAiMzTXBEZkRUMzU5cVNTbU5GWm5NZW9QUXB5SkEyVTFLNTF1NQAQYWRtaW5fd2FsbGV0X3R3bwIjM04zRENuZ2ppZGl2a0piVEp3RlRFdmJZUlRmZkNXVkJMQ0wAEmFkbWluX3dhbGxldF90aHJlZQIjM044eDltYjQ4MWkyazZjRzdROVhVVjNlNW56aDFtZHpzTnkBFGNoZWNrX2FkbWluc193YWxsZXRzAQt1c2VyX3dhbGxldAMDAwkAAAIFC3VzZXJfd2FsbGV0BRBhZG1pbl93YWxsZXRfb25lBgkAAAIFC3VzZXJfd2FsbGV0BRBhZG1pbl93YWxsZXRfdHdvBgkAAAIFC3VzZXJfd2FsbGV0BRJhZG1pbl93YWxsZXRfdGhyZWUGBwENdHJ5R2V0SW50ZWdlcgEDa2V5BAckbWF0Y2gwCQCaCAIFBHRoaXMFA2tleQMJAAECBQckbWF0Y2gwAgNJbnQEAWIFByRtYXRjaDAFAWIAAAkBaQEIYWRkX2Jsb2cFCXB1Ymxpc2hlcgV0aXRlbA1hcndlYXZlX3R4X2lkCXNpZ25hdHVyZQpibG9nX2NvdmVyAwMJAAACCQClCAEIBQFpBmNhbGxlcgUJcHVibGlzaGVyBgkBFGNoZWNrX2FkbWluc193YWxsZXRzAQkApQgBCAUBaQZjYWxsZXIEBXR4X2lkCQDYBAEIBQFpDXRyYW5zYWN0aW9uSWQEBWJsb2NrBQlsYXN0QmxvY2sEDHB1Ymxpc2hfdGltZQgFBWJsb2NrCXRpbWVzdGFtcAQHYmxvZ19pZAkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIFdXNlcl8FCXB1Ymxpc2hlcgIIX2Jsb2dfaWQEC25ld19ibG9nX2lkCQBkAgUHYmxvZ19pZAABCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgVibG9nXwUFdHhfaWQCCl9wdWJsaXNoZXIFCXB1Ymxpc2hlcgkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIFYmxvZ18FBXR4X2lkAg5fYXJ3ZWF2ZV90eF9pZAUNYXJ3ZWF2ZV90eF9pZAkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIFYmxvZ18FBXR4X2lkAgpfc2lnbmF0dXJlBQlzaWduYXR1cmUJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgICBWJsb2dfBQV0eF9pZAILX2Jsb2dfY292ZXIFCmJsb2dfY292ZXIJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgICBWJsb2dfBQV0eF9pZAIGX3RpdGVsBQV0aXRlbAkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgkArAICAgV1c2VyXwUJcHVibGlzaGVyAgVfYmxvZwkApAMBBQtuZXdfYmxvZ19pZAUFdHhfaWQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgV1c2VyXwUJcHVibGlzaGVyAghfYmxvZ19pZAULbmV3X2Jsb2dfaWQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgVibG9nXwUFdHhfaWQCDV9wdWJsaXNoX3RpbWUFDHB1Ymxpc2hfdGltZQUDbmlsCQACAQJNRVJSUk9SICEsIGFkZF9ibG9nLCBNRVNTQUdFOiBzb3JyeSB5b3UgYXJlIG5vdCBhbGxvdyB0byBpbnZva2UgdGhpcyBmdW5hY3Rpb24BaQEJYWRkX3N0b3J5CglwdWJsaXNoZXIFdGl0ZWwNYXJ3ZWF2ZV90eF9pZAlzaWduYXR1cmULc3RvcnlfY292ZXILZGVzY3JpcHRpb24EdGFncwhsYW5ndWFnZQljYXRlZ29yeXMGc3RhdHVzAwMJAAACCQClCAEIBQFpBmNhbGxlcgUJcHVibGlzaGVyBgkBFGNoZWNrX2FkbWluc193YWxsZXRzAQkApQgBCAUBaQZjYWxsZXIEBXR4X2lkCQDYBAEIBQFpDXRyYW5zYWN0aW9uSWQEBWJsb2NrBQlsYXN0QmxvY2sEDHB1Ymxpc2hfdGltZQgFBWJsb2NrCXRpbWVzdGFtcAQIc3RvcnlfaWQJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICBXVzZXJfBQlwdWJsaXNoZXICCV9zdG9yeV9pZAQMbmV3X3N0b3J5X2lkCQBkAgUIc3RvcnlfaWQAAQkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIGc3RvcnlfBQV0eF9pZAIKX3B1Ymxpc2hlcgUJcHVibGlzaGVyCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgZzdG9yeV8FBXR4X2lkAg5fYXJ3ZWF2ZV90eF9pZAUNYXJ3ZWF2ZV90eF9pZAkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIGc3RvcnlfBQV0eF9pZAIKX3NpZ25hdHVyZQUJc2lnbmF0dXJlCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgZzdG9yeV8FBXR4X2lkAgxfc3RvcnlfY292ZXIFC3N0b3J5X2NvdmVyCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgZzdG9yeV8FBXR4X2lkAgZfdGl0ZWwFBXRpdGVsCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgZzdG9yeV8FBXR4X2lkAgxfZGVzY3JpcHRpb24FC2Rlc2NyaXB0aW9uCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgZzdG9yeV8FBXR4X2lkAgVfdGFncwUEdGFncwkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIGc3RvcnlfBQV0eF9pZAIJX2xhbmd1YWdlBQhsYW5ndWFnZQkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIGc3RvcnlfBQV0eF9pZAIKX2NhdGVnb3J5cwUJY2F0ZWdvcnlzCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgZzdG9yeV8FBXR4X2lkAgdfc3RhdHVzBQZzdGF0dXMJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAKwCAgIFdXNlcl8FCXB1Ymxpc2hlcgIGX3N0b3J5CQCkAwEFDG5ld19zdG9yeV9pZAUFdHhfaWQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgV1c2VyXwUJcHVibGlzaGVyAglfc3RvcnlfaWQFDG5ld19zdG9yeV9pZAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICBnN0b3J5XwUFdHhfaWQCDV9wdWJsaXNoX3RpbWUFDHB1Ymxpc2hfdGltZQUDbmlsCQACAQJORVJSUk9SICEsIGFkZF9zdG9yeSwgTUVTU0FHRTogc29ycnkgeW91IGFyZSBub3QgYWxsb3cgdG8gaW52b2tlIHRoaXMgZnVuYWN0aW9uAWkBC2FkZF9jaGFwdGVyAgtzdG9yeV90eF9pZBVjaGFwdGVyX2Fyd2VhdmVfdHhfaWQED2xhc3RfY2hhcHRlcl9pZAkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIGc3RvcnlfBQtzdG9yeV90eF9pZAIQX2xhc3RfY2hhcHRlcl9pZAQFdHhfaWQJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAQFYmxvY2sFCWxhc3RCbG9jawQMcHVibGlzaF90aW1lCAUFYmxvY2sJdGltZXN0YW1wCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICCQCsAgICBnN0b3J5XwULc3RvcnlfdHhfaWQCCV9jaGFwdGVyXwkApAMBBQ9sYXN0X2NoYXB0ZXJfaWQFBXR4X2lkCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAghjaGFwdGVyXwUFdHhfaWQCDl9hcndlYXZlX3R4X2lkBRVjaGFwdGVyX2Fyd2VhdmVfdHhfaWQJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgICCGNoYXB0ZXJfBQV0eF9pZAIMX3N0b3J5X3R4X2lkBQtzdG9yeV90eF9pZAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICCGNoYXB0ZXJfBQV0eF9pZAIDX2lkBQ9sYXN0X2NoYXB0ZXJfaWQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgZzdG9yeV8FC3N0b3J5X3R4X2lkAhBfbGFzdF9jaGFwdGVyX2lkCQBkAgUPbGFzdF9jaGFwdGVyX2lkAAEJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAghjaGFwdGVyXwUFdHhfaWQCDV9wdWJsaXNoX3RpbWUFDHB1Ymxpc2hfdGltZQUDbmlsAWkBDXNldF91c2VyX2RhdGEKBndhbGxldARuYW1lCmltYWdlX2xpbmsKY292ZXJfbGluawNiaW8QZ29vZ2xlX2FuYWx5dGljcwd0d2l0dGVyCHRlbGVncmFtEHlhbmRleF9hbmFseXRpY3MFbm90ZXMDAwkAAAIJAKUIAQgFAWkGY2FsbGVyBQZ3YWxsZXQGCQEUY2hlY2tfYWRtaW5zX3dhbGxldHMBCQClCAEIBQFpBmNhbGxlcgkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIFdXNlcl8FBndhbGxldAIHX2pvaW5lZAIDeWVzCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgV1c2VyXwUGd2FsbGV0AgVfbmFtZQUEbmFtZQkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIFdXNlcl8FBndhbGxldAIKX2ltYWdlTGluawUKaW1hZ2VfbGluawkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIFdXNlcl8FBndhbGxldAIKX2NvdmVyTGluawUKY292ZXJfbGluawkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIFdXNlcl8FBndhbGxldAIEX2JpbwUDYmlvCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgV1c2VyXwUGd2FsbGV0AhBfZ29vZ2xlQW5hbHl0aWNzBRBnb29nbGVfYW5hbHl0aWNzCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgV1c2VyXwUGd2FsbGV0AhBfeWFuZGV4QW5hbHl0aWNzBRB5YW5kZXhfYW5hbHl0aWNzCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgV1c2VyXwUGd2FsbGV0AghfdHdpdHRlcgUHdHdpdHRlcgkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIFdXNlcl8FBndhbGxldAIJX3RlbGVncmFtBQh0ZWxlZ3JhbQkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIFdXNlcl8FBndhbGxldAIGX25vdGVzBQVub3RlcwUDbmlsCQACAQJSRVJSUk9SICEsIHNldF91c2VyX2RhdGEsIE1FU1NBR0U6IHNvcnJ5IHlvdSBhcmUgbm90IGFsbG93IHRvIGludm9rZSB0aGlzIGZ1bmFjdGlvbgFpARFzZXRfdmVyaWZpZWRfdXNlcgYGd2FsbGV0BG5hbWUHdHdpdHRlcgh0ZWxlZ3JhbQVlbWFpbAVub3RlcwMJARRjaGVja19hZG1pbnNfd2FsbGV0cwEJAKUIAQgFAWkGY2FsbGVyCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgV1c2VyXwUGd2FsbGV0AglfdmVyaWZpZWQCA3llcwkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIFdXNlcl8FBndhbGxldAIOX3ZlcmlmaWVkX25hbWUFBG5hbWUJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgICBXVzZXJfBQZ3YWxsZXQCEV92ZXJpZmllZF90d2l0dGVyBQd0d2l0dGVyCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgV1c2VyXwUGd2FsbGV0AhJfdmVyaWZpZWRfdGVsZWdyYW0FCHRlbGVncmFtCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgV1c2VyXwUGd2FsbGV0Ag9fdmVyaWZpZWRfbm90ZXMFBW5vdGVzBQNuaWwJAAIBAlZFUlJST1IgISwgc2V0X3ZlcmlmaWVkX3VzZXIsIE1FU1NBR0U6IHNvcnJ5IHlvdSBhcmUgbm90IGFsbG93IHRvIGludm9rZSB0aGlzIGZ1bmFjdGlvbgFpAQtmb2xsb3dfdXNlcgEGd2FsbGV0BAZjYWxsZXIJAKUIAQgFAWkGY2FsbGVyCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICCQCsAgICBXVzZXJfBQZ3YWxsZXQCDV9mb2xsb3dlZF9ieV8FBmNhbGxlcgIDeWVzCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICCQCsAgICBXVzZXJfBQZjYWxsZXICCF9mb2xsb3dfBQZ3YWxsZXQCA3llcwUDbmlsAWkBDnVuX2ZvbGxvd191c2VyAQZ3YWxsZXQEBmNhbGxlcgkApQgBCAUBaQZjYWxsZXIJAMwIAgkBC0RlbGV0ZUVudHJ5AQkArAICCQCsAgIJAKwCAgIFdXNlcl8FBndhbGxldAINX2ZvbGxvd2VkX2J5XwUGY2FsbGVyCQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICCQCsAgICBXVzZXJfBQZjYWxsZXICCF9mb2xsb3dfBQZ3YWxsZXQFA25pbAFpARVhZGRfYmxvZ190b19mYXZvcml0ZXMCBndhbGxldApibG9nX3R4X2lkAwMJAAACCQClCAEIBQFpBmNhbGxlcgUGd2FsbGV0BgkBFGNoZWNrX2FkbWluc193YWxsZXRzAQkApQgBCAUBaQZjYWxsZXIEAmlkCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgVibG9nXwUKYmxvZ190eF9pZAIMX2Zhdm9yaXRlX2lkBAd1c2VyX2lkCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgV1c2VyXwUGd2FsbGV0AgxfZmF2b3JpdGVfaWQJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAKwCAgIFdXNlcl8FBndhbGxldAIPX2Jsb2dfZmF2b3JpdGVfCQCkAwEFB3VzZXJfaWQFCmJsb2dfdHhfaWQJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAKwCAgIFYmxvZ18FCmJsb2dfdHhfaWQCCl9mYXZvcml0ZV8JAKQDAQUCaWQFBndhbGxldAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICBWJsb2dfBQpibG9nX3R4X2lkAgxfZmF2b3JpdGVfaWQJAGQCBQJpZAABCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIFdXNlcl8FBndhbGxldAIMX2Zhdm9yaXRlX2lkCQBkAgUHdXNlcl9pZAABBQNuaWwJAAIBAlVFUlJST1IgISwgYWRkX3RvX2Zhdm9yaXRlcywgTUVTU0FHRTogc29ycnkgeW91IGFyZSBub3QgYWxsb3cgdG8gaW52b2tlIHRoaXMgZnVuYWN0aW9uAWkBFmFkZF9zdG9yeV90b19mYXZvcml0ZXMCBndhbGxldAtzdG9yeV90eF9pZAMDCQAAAgkApQgBCAUBaQZjYWxsZXIFBndhbGxldAYJARRjaGVja19hZG1pbnNfd2FsbGV0cwEJAKUIAQgFAWkGY2FsbGVyBAJpZAkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIGc3RvcnlfBQtzdG9yeV90eF9pZAIMX2Zhdm9yaXRlX2lkBAd1c2VyX2lkCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgV1c2VyXwUGd2FsbGV0AgxfZmF2b3JpdGVfaWQJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAKwCAgIFdXNlcl8FBndhbGxldAIQX3N0b3J5X2Zhdm9yaXRlXwkApAMBBQd1c2VyX2lkBQtzdG9yeV90eF9pZAkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgkArAICAgZzdG9yeV8FC3N0b3J5X3R4X2lkAgpfZmF2b3JpdGVfCQCkAwEFAmlkBQZ3YWxsZXQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgZzdG9yeV8FC3N0b3J5X3R4X2lkAgxfZmF2b3JpdGVfaWQJAGQCBQJpZAABCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIFdXNlcl8FBndhbGxldAIMX2Zhdm9yaXRlX2lkCQBkAgUHdXNlcl9pZAABBQNuaWwJAAIBAlVFUlJST1IgISwgYWRkX3RvX2Zhdm9yaXRlcywgTUVTU0FHRTogc29ycnkgeW91IGFyZSBub3QgYWxsb3cgdG8gaW52b2tlIHRoaXMgZnVuYWN0aW9uAQJ0eAEGdmVyaWZ5AAkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tleVJlMCE=", "height": 2546557, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: B6i6FS9GDUbHvZHZnkrwfWvVvXmTvDTExeHTA28MDBVd Next: EjNWTXavRbUh9P3twmQDF3yGkDpqP8QMygUqfmW7iNPs Diff:
Old | New | Differences | |
---|---|---|---|
32 | 32 | let tx_id = toBase58String(i.transactionId) | |
33 | 33 | let block = lastBlock | |
34 | 34 | let publish_time = block.timestamp | |
35 | - | [StringEntry((("blog_" + tx_id) + "_publisher"), publisher), StringEntry((("blog_" + tx_id) + "_arweave_tx_id"), arweave_tx_id), StringEntry((("blog_" + tx_id) + "_signature"), signature), StringEntry((("blog_" + tx_id) + "_blog_cover"), blog_cover), StringEntry((("blog_" + tx_id) + "_titel"), titel), IntegerEntry((("blog_" + tx_id) + "_publish_time"), publish_time)] | |
35 | + | let blog_id = tryGetInteger((("user_" + publisher) + "_blog_id")) | |
36 | + | let new_blog_id = (blog_id + 1) | |
37 | + | [StringEntry((("blog_" + tx_id) + "_publisher"), publisher), StringEntry((("blog_" + tx_id) + "_arweave_tx_id"), arweave_tx_id), StringEntry((("blog_" + tx_id) + "_signature"), signature), StringEntry((("blog_" + tx_id) + "_blog_cover"), blog_cover), StringEntry((("blog_" + tx_id) + "_titel"), titel), StringEntry(((("user_" + publisher) + "_blog") + toString(new_blog_id)), tx_id), IntegerEntry((("user_" + publisher) + "_blog_id"), new_blog_id), IntegerEntry((("blog_" + tx_id) + "_publish_time"), publish_time)] | |
36 | 38 | } | |
37 | 39 | else throw("ERRROR !, add_blog, MESSAGE: sorry you are not allow to invoke this funaction") | |
38 | 40 | ||
46 | 48 | let tx_id = toBase58String(i.transactionId) | |
47 | 49 | let block = lastBlock | |
48 | 50 | let publish_time = block.timestamp | |
49 | - | [StringEntry((("story_" + tx_id) + "_publisher"), publisher), StringEntry((("story_" + tx_id) + "_arweave_tx_id"), arweave_tx_id), StringEntry((("story_" + tx_id) + "_signature"), signature), StringEntry((("story_" + tx_id) + "_story_cover"), story_cover), StringEntry((("story_" + tx_id) + "_titel"), titel), StringEntry((("story_" + tx_id) + "_description"), description), StringEntry((("story_" + tx_id) + "_tags"), tags), StringEntry((("story_" + tx_id) + "_language"), language), StringEntry((("story_" + tx_id) + "_categorys"), categorys), StringEntry((("story_" + tx_id) + "_status"), status), IntegerEntry((("story_" + tx_id) + "_publish_time"), publish_time)] | |
51 | + | let story_id = tryGetInteger((("user_" + publisher) + "_story_id")) | |
52 | + | let new_story_id = (story_id + 1) | |
53 | + | [StringEntry((("story_" + tx_id) + "_publisher"), publisher), StringEntry((("story_" + tx_id) + "_arweave_tx_id"), arweave_tx_id), StringEntry((("story_" + tx_id) + "_signature"), signature), StringEntry((("story_" + tx_id) + "_story_cover"), story_cover), StringEntry((("story_" + tx_id) + "_titel"), titel), StringEntry((("story_" + tx_id) + "_description"), description), StringEntry((("story_" + tx_id) + "_tags"), tags), StringEntry((("story_" + tx_id) + "_language"), language), StringEntry((("story_" + tx_id) + "_categorys"), categorys), StringEntry((("story_" + tx_id) + "_status"), status), StringEntry(((("user_" + publisher) + "_story") + toString(new_story_id)), tx_id), IntegerEntry((("user_" + publisher) + "_story_id"), new_story_id), IntegerEntry((("story_" + tx_id) + "_publish_time"), publish_time)] | |
50 | 54 | } | |
51 | 55 | else throw("ERRROR !, add_story, MESSAGE: sorry you are not allow to invoke this funaction") | |
52 | 56 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let admin_wallet_one = "3MpDfDT359qSSmNFZnMeoPQpyJA2U1K51u5" | |
5 | 5 | ||
6 | 6 | let admin_wallet_two = "3N3DCngjidivkJbTJwFTEvbYRTffCWVBLCL" | |
7 | 7 | ||
8 | 8 | let admin_wallet_three = "3N8x9mb481i2k6cG7Q9XUV3e5nzh1mdzsNy" | |
9 | 9 | ||
10 | 10 | func check_admins_wallets (user_wallet) = if (if (if ((user_wallet == admin_wallet_one)) | |
11 | 11 | then true | |
12 | 12 | else (user_wallet == admin_wallet_two)) | |
13 | 13 | then true | |
14 | 14 | else (user_wallet == admin_wallet_three)) | |
15 | 15 | then true | |
16 | 16 | else false | |
17 | 17 | ||
18 | 18 | ||
19 | 19 | func tryGetInteger (key) = match getInteger(this, key) { | |
20 | 20 | case b: Int => | |
21 | 21 | b | |
22 | 22 | case _ => | |
23 | 23 | 0 | |
24 | 24 | } | |
25 | 25 | ||
26 | 26 | ||
27 | 27 | @Callable(i) | |
28 | 28 | func add_blog (publisher,titel,arweave_tx_id,signature,blog_cover) = if (if ((toString(i.caller) == publisher)) | |
29 | 29 | then true | |
30 | 30 | else check_admins_wallets(toString(i.caller))) | |
31 | 31 | then { | |
32 | 32 | let tx_id = toBase58String(i.transactionId) | |
33 | 33 | let block = lastBlock | |
34 | 34 | let publish_time = block.timestamp | |
35 | - | [StringEntry((("blog_" + tx_id) + "_publisher"), publisher), StringEntry((("blog_" + tx_id) + "_arweave_tx_id"), arweave_tx_id), StringEntry((("blog_" + tx_id) + "_signature"), signature), StringEntry((("blog_" + tx_id) + "_blog_cover"), blog_cover), StringEntry((("blog_" + tx_id) + "_titel"), titel), IntegerEntry((("blog_" + tx_id) + "_publish_time"), publish_time)] | |
35 | + | let blog_id = tryGetInteger((("user_" + publisher) + "_blog_id")) | |
36 | + | let new_blog_id = (blog_id + 1) | |
37 | + | [StringEntry((("blog_" + tx_id) + "_publisher"), publisher), StringEntry((("blog_" + tx_id) + "_arweave_tx_id"), arweave_tx_id), StringEntry((("blog_" + tx_id) + "_signature"), signature), StringEntry((("blog_" + tx_id) + "_blog_cover"), blog_cover), StringEntry((("blog_" + tx_id) + "_titel"), titel), StringEntry(((("user_" + publisher) + "_blog") + toString(new_blog_id)), tx_id), IntegerEntry((("user_" + publisher) + "_blog_id"), new_blog_id), IntegerEntry((("blog_" + tx_id) + "_publish_time"), publish_time)] | |
36 | 38 | } | |
37 | 39 | else throw("ERRROR !, add_blog, MESSAGE: sorry you are not allow to invoke this funaction") | |
38 | 40 | ||
39 | 41 | ||
40 | 42 | ||
41 | 43 | @Callable(i) | |
42 | 44 | func add_story (publisher,titel,arweave_tx_id,signature,story_cover,description,tags,language,categorys,status) = if (if ((toString(i.caller) == publisher)) | |
43 | 45 | then true | |
44 | 46 | else check_admins_wallets(toString(i.caller))) | |
45 | 47 | then { | |
46 | 48 | let tx_id = toBase58String(i.transactionId) | |
47 | 49 | let block = lastBlock | |
48 | 50 | let publish_time = block.timestamp | |
49 | - | [StringEntry((("story_" + tx_id) + "_publisher"), publisher), StringEntry((("story_" + tx_id) + "_arweave_tx_id"), arweave_tx_id), StringEntry((("story_" + tx_id) + "_signature"), signature), StringEntry((("story_" + tx_id) + "_story_cover"), story_cover), StringEntry((("story_" + tx_id) + "_titel"), titel), StringEntry((("story_" + tx_id) + "_description"), description), StringEntry((("story_" + tx_id) + "_tags"), tags), StringEntry((("story_" + tx_id) + "_language"), language), StringEntry((("story_" + tx_id) + "_categorys"), categorys), StringEntry((("story_" + tx_id) + "_status"), status), IntegerEntry((("story_" + tx_id) + "_publish_time"), publish_time)] | |
51 | + | let story_id = tryGetInteger((("user_" + publisher) + "_story_id")) | |
52 | + | let new_story_id = (story_id + 1) | |
53 | + | [StringEntry((("story_" + tx_id) + "_publisher"), publisher), StringEntry((("story_" + tx_id) + "_arweave_tx_id"), arweave_tx_id), StringEntry((("story_" + tx_id) + "_signature"), signature), StringEntry((("story_" + tx_id) + "_story_cover"), story_cover), StringEntry((("story_" + tx_id) + "_titel"), titel), StringEntry((("story_" + tx_id) + "_description"), description), StringEntry((("story_" + tx_id) + "_tags"), tags), StringEntry((("story_" + tx_id) + "_language"), language), StringEntry((("story_" + tx_id) + "_categorys"), categorys), StringEntry((("story_" + tx_id) + "_status"), status), StringEntry(((("user_" + publisher) + "_story") + toString(new_story_id)), tx_id), IntegerEntry((("user_" + publisher) + "_story_id"), new_story_id), IntegerEntry((("story_" + tx_id) + "_publish_time"), publish_time)] | |
50 | 54 | } | |
51 | 55 | else throw("ERRROR !, add_story, MESSAGE: sorry you are not allow to invoke this funaction") | |
52 | 56 | ||
53 | 57 | ||
54 | 58 | ||
55 | 59 | @Callable(i) | |
56 | 60 | func add_chapter (story_tx_id,chapter_arweave_tx_id) = { | |
57 | 61 | let last_chapter_id = tryGetInteger((("story_" + story_tx_id) + "_last_chapter_id")) | |
58 | 62 | let tx_id = toBase58String(i.transactionId) | |
59 | 63 | let block = lastBlock | |
60 | 64 | let publish_time = block.timestamp | |
61 | 65 | [StringEntry(((("story_" + story_tx_id) + "_chapter_") + toString(last_chapter_id)), tx_id), StringEntry((("chapter_" + tx_id) + "_arweave_tx_id"), chapter_arweave_tx_id), StringEntry((("chapter_" + tx_id) + "_story_tx_id"), story_tx_id), IntegerEntry((("chapter_" + tx_id) + "_id"), last_chapter_id), IntegerEntry((("story_" + story_tx_id) + "_last_chapter_id"), (last_chapter_id + 1)), IntegerEntry((("chapter_" + tx_id) + "_publish_time"), publish_time)] | |
62 | 66 | } | |
63 | 67 | ||
64 | 68 | ||
65 | 69 | ||
66 | 70 | @Callable(i) | |
67 | 71 | func set_user_data (wallet,name,image_link,cover_link,bio,google_analytics,twitter,telegram,yandex_analytics,notes) = if (if ((toString(i.caller) == wallet)) | |
68 | 72 | then true | |
69 | 73 | else check_admins_wallets(toString(i.caller))) | |
70 | 74 | then [StringEntry((("user_" + wallet) + "_joined"), "yes"), StringEntry((("user_" + wallet) + "_name"), name), StringEntry((("user_" + wallet) + "_imageLink"), image_link), StringEntry((("user_" + wallet) + "_coverLink"), cover_link), StringEntry((("user_" + wallet) + "_bio"), bio), StringEntry((("user_" + wallet) + "_googleAnalytics"), google_analytics), StringEntry((("user_" + wallet) + "_yandexAnalytics"), yandex_analytics), StringEntry((("user_" + wallet) + "_twitter"), twitter), StringEntry((("user_" + wallet) + "_telegram"), telegram), StringEntry((("user_" + wallet) + "_notes"), notes)] | |
71 | 75 | else throw("ERRROR !, set_user_data, MESSAGE: sorry you are not allow to invoke this funaction") | |
72 | 76 | ||
73 | 77 | ||
74 | 78 | ||
75 | 79 | @Callable(i) | |
76 | 80 | func set_verified_user (wallet,name,twitter,telegram,email,notes) = if (check_admins_wallets(toString(i.caller))) | |
77 | 81 | then [StringEntry((("user_" + wallet) + "_verified"), "yes"), StringEntry((("user_" + wallet) + "_verified_name"), name), StringEntry((("user_" + wallet) + "_verified_twitter"), twitter), StringEntry((("user_" + wallet) + "_verified_telegram"), telegram), StringEntry((("user_" + wallet) + "_verified_notes"), notes)] | |
78 | 82 | else throw("ERRROR !, set_verified_user, MESSAGE: sorry you are not allow to invoke this funaction") | |
79 | 83 | ||
80 | 84 | ||
81 | 85 | ||
82 | 86 | @Callable(i) | |
83 | 87 | func follow_user (wallet) = { | |
84 | 88 | let caller = toString(i.caller) | |
85 | 89 | [StringEntry(((("user_" + wallet) + "_followed_by_") + caller), "yes"), StringEntry(((("user_" + caller) + "_follow_") + wallet), "yes")] | |
86 | 90 | } | |
87 | 91 | ||
88 | 92 | ||
89 | 93 | ||
90 | 94 | @Callable(i) | |
91 | 95 | func un_follow_user (wallet) = { | |
92 | 96 | let caller = toString(i.caller) | |
93 | 97 | [DeleteEntry(((("user_" + wallet) + "_followed_by_") + caller)), DeleteEntry(((("user_" + caller) + "_follow_") + wallet))] | |
94 | 98 | } | |
95 | 99 | ||
96 | 100 | ||
97 | 101 | ||
98 | 102 | @Callable(i) | |
99 | 103 | func add_blog_to_favorites (wallet,blog_tx_id) = if (if ((toString(i.caller) == wallet)) | |
100 | 104 | then true | |
101 | 105 | else check_admins_wallets(toString(i.caller))) | |
102 | 106 | then { | |
103 | 107 | let id = tryGetInteger((("blog_" + blog_tx_id) + "_favorite_id")) | |
104 | 108 | let user_id = tryGetInteger((("user_" + wallet) + "_favorite_id")) | |
105 | 109 | [StringEntry(((("user_" + wallet) + "_blog_favorite_") + toString(user_id)), blog_tx_id), StringEntry(((("blog_" + blog_tx_id) + "_favorite_") + toString(id)), wallet), IntegerEntry((("blog_" + blog_tx_id) + "_favorite_id"), (id + 1)), IntegerEntry((("user_" + wallet) + "_favorite_id"), (user_id + 1))] | |
106 | 110 | } | |
107 | 111 | else throw("ERRROR !, add_to_favorites, MESSAGE: sorry you are not allow to invoke this funaction") | |
108 | 112 | ||
109 | 113 | ||
110 | 114 | ||
111 | 115 | @Callable(i) | |
112 | 116 | func add_story_to_favorites (wallet,story_tx_id) = if (if ((toString(i.caller) == wallet)) | |
113 | 117 | then true | |
114 | 118 | else check_admins_wallets(toString(i.caller))) | |
115 | 119 | then { | |
116 | 120 | let id = tryGetInteger((("story_" + story_tx_id) + "_favorite_id")) | |
117 | 121 | let user_id = tryGetInteger((("user_" + wallet) + "_favorite_id")) | |
118 | 122 | [StringEntry(((("user_" + wallet) + "_story_favorite_") + toString(user_id)), story_tx_id), StringEntry(((("story_" + story_tx_id) + "_favorite_") + toString(id)), wallet), IntegerEntry((("story_" + story_tx_id) + "_favorite_id"), (id + 1)), IntegerEntry((("user_" + wallet) + "_favorite_id"), (user_id + 1))] | |
119 | 123 | } | |
120 | 124 | else throw("ERRROR !, add_to_favorites, MESSAGE: sorry you are not allow to invoke this funaction") | |
121 | 125 | ||
122 | 126 | ||
123 | 127 | @Verifier(tx) | |
124 | 128 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
125 | 129 |
github/deemru/w8io/169f3d6 33.82 ms ◑