tx · CfG3QU1BHJTxY3eFZXD6iJpZ5wRLn7DtG5qhJR6YPHvm 3N1oZwpYE3p4x63jWiKpszmfLU3Lk3KtSWe: -0.01500000 Waves 2025.01.03 22:10 [3443416] smart account 3N1oZwpYE3p4x63jWiKpszmfLU3Lk3KtSWe > SELF 0.00000000 Waves
{ "type": 13, "id": "CfG3QU1BHJTxY3eFZXD6iJpZ5wRLn7DtG5qhJR6YPHvm", "fee": 1500000, "feeAssetId": null, "timestamp": 1735931416872, "version": 2, "chainId": 84, "sender": "3N1oZwpYE3p4x63jWiKpszmfLU3Lk3KtSWe", "senderPublicKey": "CqqNd9FdJdY64okp1oAAQ8z3kyrEcd6UKxtboqZgrSaP", "proofs": [ "4w69io9TTs6eersuqWnzq8VSv4araCr4JDTU7zFr8gZEWVh5bALbCHLE6xZ1YUFKSCy8ev6DiZtCMUW9nk8o4bFU" ], "script": "base64:BgIWCAISAwoBCBIAEgQKAgQIEgASAwoBCCEBB2dldEJvb2wBA2tleQQHJG1hdGNoMAkAmwgCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBYgUHJG1hdGNoMAUBYgcBCWlzVGVzdEVudgAJAQdnZXRCb29sAQIHVEVTVEVOVgEXc3RhdGljS2V5X29yYWNsZUFkZHJlc3MAAhRzdGF0aWNfb3JhY2xlQWRkcmVzcwEYc3RhdGljS2V5X2JyZWVkZXJBZGRyZXNzAAIVc3RhdGljX2JyZWVkZXJBZGRyZXNzARZzdGF0aWNLZXlfaXRlbXNBZGRyZXNzAAITc3RhdGljX2l0ZW1zQWRkcmVzcwESc3RhdGljS2V5X2V4dHJhRmVlAAIPc3RhdGljX2V4dHJhRmVlARhzdGF0aWNLZXlfZXh0cmFGZWVSZW1vdmUAAhVzdGF0aWNfZXh0cmFGZWVSZW1vdmUBF3N0YXRpY0tleV9mZWVBZ2dyZWdhdG9yAAIUc3RhdGljX2ZlZUFnZ3JlZ2F0b3IACXdlYXJhYmxlcwkAzAgCAghBUlQtQ0FQRQkAzAgCAgdBUlQtSEFUCQDMCAICCkFSVC1YU0NBUkYJAMwIAgIMQVJULVhTV0VBVEVSBQNuaWwBD2tleUFydGVmYWN0RHVjawIGZHVja0lkCHdlYXJhYmxlCQCsAgIJAKwCAgUGZHVja0lkAgFfBQh3ZWFyYWJsZQEMa2V5VHlwZXNEdWNrAgZkdWNrSWQEdHlwZQkArAICCQCsAgIFBmR1Y2tJZAIBXwUEdHlwZQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCB2FkZHJlc3MDa2V5BAckbWF0Y2gwCQCdCAIFB2FkZHJlc3MFA2tleQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAWEFByRtYXRjaDAFAWECAAEMdHJ5R2V0U3RyaW5nAQNrZXkJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIFBHRoaXMFA2tleQEFYXNJbnQBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgNJbnQEA2ludAUHJG1hdGNoMAUDaW50CQACAQIZd3JvbmcgdHlwZSwgZXhwZWN0ZWQ6IEludAEIYXNTdHJpbmcBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEBnN0cmluZwUHJG1hdGNoMAUGc3RyaW5nCQACAQIcd3JvbmcgdHlwZSwgZXhwZWN0ZWQ6IFN0cmluZwEJZ2V0T3JhY2xlAAkBB0FkZHJlc3MBCQDZBAEJAQx0cnlHZXRTdHJpbmcBCQEXc3RhdGljS2V5X29yYWNsZUFkZHJlc3MAARFnZXRCcmVlZGVyQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBGHN0YXRpY0tleV9icmVlZGVyQWRkcmVzcwABD2dldEl0ZW1zQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBFnN0YXRpY0tleV9pdGVtc0FkZHJlc3MAARBnZXRGZWVBZ2dyZWdhdG9yAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEXc3RhdGljS2V5X2ZlZUFnZ3JlZ2F0b3IAARlnZXRUdXJ0bGVJbmN1YmF0b3JBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAh1zdGF0aWNfdHVydGxlSW5jdWJhdG9yQWRkcmVzcwEXZ2V0VHVydGxlQnJlZWRlckFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACG3N0YXRpY190dXJ0bGVCcmVlZGVyQWRkcmVzcwETZ2V0SW5jdWJhdG9yQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAIXc3RhdGljX2luY3ViYXRvckFkZHJlc3MBGWdldENhbmluZUluY3ViYXRvckFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACHXN0YXRpY19jYW5pbmVJbmN1YmF0b3JBZGRyZXNzARdnZXRDYW5pbmVCcmVlZGVyQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAIbc3RhdGljX2NhbmluZUJyZWVkZXJBZGRyZXNzARlnZXRGZWxpbmVJbmN1YmF0b3JBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAh1zdGF0aWNfZmVsaW5lSW5jdWJhdG9yQWRkcmVzcwEXZ2V0RmVsaW5lQnJlZWRlckFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACG3N0YXRpY19mZWxpbmVCcmVlZGVyQWRkcmVzcwEXZ2V0TXV0YW50QnJlZWRlckFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACHXN0YXRpY19tdXRhbnRJbmN1YmF0b3JBZGRyZXNzARZjaGVja0FkZGl0aW9uYWxQYXltZW50AgdwYXltZW50DmFtb3VudE92ZXJyaWRlAwkBCWlzRGVmaW5lZAEIBQdwYXltZW50B2Fzc2V0SWQJAAIBAhlXQ0FQOiBQbGVhc2UgYXR0YWNoIHdhdmVzBAlmZWVBbW91bnQDCQECIT0CBQ5hbW91bnRPdmVycmlkZQAABQ5hbW91bnRPdmVycmlkZQkBEUBleHRyTmF0aXZlKDEwNTApAgkBCWdldE9yYWNsZQAJARJzdGF0aWNLZXlfZXh0cmFGZWUAAwkBAiE9AggFB3BheW1lbnQGYW1vdW50BQlmZWVBbW91bnQJAAIBCQCsAgIJAKwCAgIcV0NBUDogUGxlYXNlIGF0dGFjaCBleGFjdGx5IAkApAMBBQlmZWVBbW91bnQCEyBhbW91bnQgb2Ygd2F2ZWxldHMJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEGdldEZlZUFnZ3JlZ2F0b3IABQlmZWVBbW91bnQFBHVuaXQFA25pbAESdHJ5R2V0Q29zbWV0aWNJdGVtAQRpdGVtBANrZXkJAKwCAgIQZGlyZWN0X2Nvc21ldGljXwUEaXRlbQQHJG1hdGNoMAkAmggCCQEPZ2V0SXRlbXNBZGRyZXNzAAUDa2V5AwkAAQIFByRtYXRjaDACA0ludAQBYQUHJG1hdGNoMAUBYQUEdW5pdAEKdHJ5R2V0VHlwZQEId2VhcmFibGUJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQ9nZXRJdGVtc0FkZHJlc3MACQCsAgICDnR5cGVfY29zbWV0aWNfBQh3ZWFyYWJsZQEId2Vhckl0ZW0DD2Fzc2V0SWRXZWFyQWJsZQZkdWNrSWQIYWxsVHlwZXMEDGFydGVmYWN0TmFtZQkBCGFzU3RyaW5nAQkA/AcECQEPZ2V0SXRlbXNBZGRyZXNzAAIUY2hlY2tBcnRlZmFjdERldGFpbHMJAMwIAgUPYXNzZXRJZFdlYXJBYmxlBQNuaWwFA25pbAMJAAACBQxhcnRlZmFjdE5hbWUFDGFydGVmYWN0TmFtZQMDCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCBQl3ZWFyYWJsZXMFDGFydGVmYWN0TmFtZQkBASEBCQEJaXNEZWZpbmVkAQkBEnRyeUdldENvc21ldGljSXRlbQEFDGFydGVmYWN0TmFtZQcJAAIBAhtXUklURDogVW5zdXBwb3J0ZWQgd2VhcmFibGUECmFydGVmYWN0SWQJAQx0cnlHZXRTdHJpbmcBCQEPa2V5QXJ0ZWZhY3REdWNrAgUGZHVja0lkBQxhcnRlZmFjdE5hbWUECWJvb3N0RHVjawMJAAACBQxhcnRlZmFjdE5hbWUCCkFSVC1YU0NBUkYJAPwHBAkBD2dldEl0ZW1zQWRkcmVzcwACD21hbmlwdWxhdGVCb29zdAkAzAgCAEUJAMwIAgUGZHVja0lkBQNuaWwFA25pbAUDbmlsAwkAAAIFCWJvb3N0RHVjawUJYm9vc3REdWNrAwkBAiE9AgUKYXJ0ZWZhY3RJZAIACQACAQkArAICAhpEdWNrIGlzIGFscmVhZHkgd2VhcmluZyBhIAUMYXJ0ZWZhY3ROYW1lBAR0eXBlCQEKdHJ5R2V0VHlwZQEFDGFydGVmYWN0TmFtZQMDCQEBIQEFCGFsbFR5cGVzCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCCQDMCAICA1BFVAkAzAgCAgRCQUNLCQDMCAICBFRBSUwJAMwIAgIJQUNDRVNTT1JZCQDMCAICBEhFQUQFA25pbAUEdHlwZQcJAAIBAjJZb3UgY2FuJ3QgYXR0YWNoIHRoaXMgaXRlbSB0byB5b3VyIE5GVCEgUGV0cyBvbmx5IQQKdHlwZU9uRHVjawMJAQIhPQIFBHR5cGUCAAkBAiE9AgkBDHRyeUdldFN0cmluZwEJAQxrZXlUeXBlc0R1Y2sCBQZkdWNrSWQFBHR5cGUCAAkAAgEJAKwCAgImVHlwZSB1bmRlZmluZWQsIHBsZWFzZSBjb250YWN0IGFkbWlucyAFDGFydGVmYWN0TmFtZQMFCnR5cGVPbkR1Y2sJAAIBAjJZb3UgY2FuIG9ubHkgYXR0YWNoIDEgZnJvbSBlYWNoIHR5cGUgdG8geW91ciBkdWNrIQQKdHlwZVJlc3VsdAMJAQIhPQIFBHR5cGUCAAkAzAgCCQELU3RyaW5nRW50cnkCCQEMa2V5VHlwZXNEdWNrAgUGZHVja0lkBQR0eXBlBQ9hc3NldElkV2VhckFibGUFA25pbAUDbmlsCQDOCAIJAMwIAgkBC1N0cmluZ0VudHJ5AgkBD2tleUFydGVmYWN0RHVjawIFBmR1Y2tJZAUMYXJ0ZWZhY3ROYW1lBQ9hc3NldElkV2VhckFibGUFA25pbAUKdHlwZVJlc3VsdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEVdHJ5R2V0Qm9vbGVhbkV4dGVybmFsAgdhZGRyZXNzA2tleQQHJG1hdGNoMAkAmwgCBQdhZGRyZXNzBQNrZXkDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBYgUHJG1hdGNoMAUBYgcBFGdldElmQWxsVHlwZXNBbGxvd2VkAQdhc3NldElkBAZpc3N1ZXIICQEFdmFsdWUBCQDsBwEFB2Fzc2V0SWQGaXNzdWVyBAtibGFja2xpc3RlZAkBFXRyeUdldEJvb2xlYW5FeHRlcm5hbAIFBmlzc3VlcgkArAICCQDYBAEFB2Fzc2V0SWQCDF9ibGFja2xpc3RlZAMFC2JsYWNrbGlzdGVkCQACAQIQR08gRlVDSyBZT1VSU0VMRgQEbmFtZQgJAQV2YWx1ZQEJAOwHAQUHYXNzZXRJZARuYW1lAwMJAAACBQZpc3N1ZXIJARNnZXRJbmN1YmF0b3JBZGRyZXNzAAYJAAACBQZpc3N1ZXIJARFnZXRCcmVlZGVyQWRkcmVzcwAGAwMJAAACBQZpc3N1ZXIJARlnZXRUdXJ0bGVJbmN1YmF0b3JBZGRyZXNzAAYJAAACBQZpc3N1ZXIJARdnZXRUdXJ0bGVCcmVlZGVyQWRkcmVzcwAHAwMJAAACBQZpc3N1ZXIJARlnZXRDYW5pbmVJbmN1YmF0b3JBZGRyZXNzAAYJAAACBQZpc3N1ZXIJARdnZXRDYW5pbmVCcmVlZGVyQWRkcmVzcwAHAwMJAAACBQZpc3N1ZXIJARlnZXRGZWxpbmVJbmN1YmF0b3JBZGRyZXNzAAYJAAACBQZpc3N1ZXIJARdnZXRGZWxpbmVCcmVlZGVyQWRkcmVzcwAHAwkAAAIFBmlzc3VlcgkBF2dldE11dGFudEJyZWVkZXJBZGRyZXNzAAcJAAIBAhtNQUc6IEFzc2V0IGlzIG5vdCBzdXBwb3J0ZWQFAWkBD2NvbmZpZ3VyZU9yYWNsZQEGb3JhY2xlAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIKYWRtaW4gb25seQkAzAgCCQELU3RyaW5nRW50cnkCCQEXc3RhdGljS2V5X29yYWNsZUFkZHJlc3MABQZvcmFjbGUFA25pbAFpAQ53ZWFySXRlbVRvRHVjawAEDGZpcnN0UGF5bWVudAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABA1zZWNvbmRQYXltZW50CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAEEDHZhbGlkUGF5bWVudAkBFmNoZWNrQWRkaXRpb25hbFBheW1lbnQCCQCRAwIIBQFpCHBheW1lbnRzAAIAAAQGZHVja0lkCQDYBAEJAQV2YWx1ZQEIBQxmaXJzdFBheW1lbnQHYXNzZXRJZAQNc2Vjb25kQXNzZXRJZAkA2AQBCQEFdmFsdWUBCAUNc2Vjb25kUGF5bWVudAdhc3NldElkAwMJAQIhPQIIBQxmaXJzdFBheW1lbnQGYW1vdW50AAEGCQECIT0CCAUNc2Vjb25kUGF5bWVudAZhbW91bnQAAQkAAgECGldSSVREOiBORlQgaXMgbm90IGF0dGFjaGVkBAhhbGxUeXBlcwkBFGdldElmQWxsVHlwZXNBbGxvd2VkAQkBBXZhbHVlAQgFDGZpcnN0UGF5bWVudAdhc3NldElkCQDOCAIJAM4IAgkBCHdlYXJJdGVtAwUNc2Vjb25kQXNzZXRJZAUGZHVja0lkBQhhbGxUeXBlcwkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIAAQgFDGZpcnN0UGF5bWVudAdhc3NldElkBQNuaWwFDHZhbGlkUGF5bWVudAFpARJyZW1vdmVJdGVtRnJvbUR1Y2sCCGJ1cm5JdGVtDGFydGVmYWN0TmFtZQQId2F2ZXNGZWUDBQhidXJuSXRlbQAACQERQGV4dHJOYXRpdmUoMTA1MCkCCQEJZ2V0T3JhY2xlAAkBGHN0YXRpY0tleV9leHRyYUZlZVJlbW92ZQAEC2R1Y2tQYXltZW50CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAED3JvYm9EdWNrUGF5bWVudAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwABBAx2YWxpZFBheW1lbnQJARZjaGVja0FkZGl0aW9uYWxQYXltZW50AgkAkQMCCAUBaQhwYXltZW50cwACBQh3YXZlc0ZlZQQGZHVja0lkCQDYBAEJAQV2YWx1ZQEIBQtkdWNrUGF5bWVudAdhc3NldElkBApyb2JvRHVja0lkCQDYBAEJAQV2YWx1ZQEIBQ9yb2JvRHVja1BheW1lbnQHYXNzZXRJZAMDCQECIT0CCAULZHVja1BheW1lbnQGYW1vdW50AAEGCQECIT0CCAUPcm9ib0R1Y2tQYXltZW50BmFtb3VudAABCQACAQIaV1JJVEQ6IE5GVCBpcyBub3QgYXR0YWNoZWQECGNoaWxkcmVuCQEFYXNJbnQBCQD8BwQJARFnZXRCcmVlZGVyQWRkcmVzcwACFnZhbGlkYXRlQW5kR2V0Q2hpbGRyZW4JAMwIAgUGZHVja0lkBQNuaWwFA25pbAMJAAACBQhjaGlsZHJlbgUIY2hpbGRyZW4EFGFydGVmYWN0TmFtZVJvYm9kdWNrCQEIYXNTdHJpbmcBCQD8BwQJAQ9nZXRJdGVtc0FkZHJlc3MAAhRjaGVja0FydGVmYWN0RGV0YWlscwkAzAgCBQpyb2JvRHVja0lkBQNuaWwFA25pbAMJAAACBRRhcnRlZmFjdE5hbWVSb2JvZHVjawUUYXJ0ZWZhY3ROYW1lUm9ib2R1Y2sDCQECIT0CBRRhcnRlZmFjdE5hbWVSb2JvZHVjawIMQVJULVJPQk9EVUNLCQACAQIfT25seSByb2RvZHVjayBjYW4gcmVtb3ZlIGl0ZW1zIQMDCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCBQl3ZWFyYWJsZXMFDGFydGVmYWN0TmFtZQkBASEBCQEJaXNEZWZpbmVkAQkBEnRyeUdldENvc21ldGljSXRlbQEFDGFydGVmYWN0TmFtZQcJAAIBAhtXUklURDogVW5zdXBwb3J0ZWQgd2VhcmFibGUECmFydGVmYWN0SWQJAQx0cnlHZXRTdHJpbmcBCQEPa2V5QXJ0ZWZhY3REdWNrAgUGZHVja0lkBQxhcnRlZmFjdE5hbWUECWJvb3N0RHVjawMJAAACBQxhcnRlZmFjdE5hbWUCCkFSVC1YU0NBUkYJAPwHBAkBD2dldEl0ZW1zQWRkcmVzcwACD21hbmlwdWxhdGVCb29zdAkAzAgCAEUJAMwIAgUGZHVja0lkBQNuaWwFA25pbAUDbmlsAwkAAAIFCWJvb3N0RHVjawUJYm9vc3REdWNrAwkAAAIFCmFydGVmYWN0SWQCAAkAAgEJAKwCAgITRHVjayBub3Qgd2VhcmluZyBhIAUMYXJ0ZWZhY3ROYW1lBAR0eXBlCQEKdHJ5R2V0VHlwZQEFDGFydGVmYWN0TmFtZQQKdHlwZVJlc3VsdAMJAQIhPQIFBHR5cGUCAAkAzAgCCQELRGVsZXRlRW50cnkBCQEMa2V5VHlwZXNEdWNrAgUGZHVja0lkBQR0eXBlBQNuaWwFA25pbAQEYnVybgMFCGJ1cm5JdGVtCQDMCAIJAQRCdXJuAgkA2QQBBQphcnRlZmFjdElkAAEFA25pbAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIAAQkA2QQBBQphcnRlZmFjdElkBQNuaWwJAM4IAgkAzggCCQDOCAIJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBD2tleUFydGVmYWN0RHVjawIFBmR1Y2tJZAUMYXJ0ZWZhY3ROYW1lCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgABCAULZHVja1BheW1lbnQHYXNzZXRJZAkAzAgCCQEEQnVybgIJANkEAQUKcm9ib0R1Y2tJZAABBQNuaWwFBGJ1cm4FDHZhbGlkUGF5bWVudAUKdHlwZVJlc3VsdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARB3ZWFyWEl0ZW1zVG9EdWNrAAQMdmFsaWRQYXltZW50CQEWY2hlY2tBZGRpdGlvbmFsUGF5bWVudAIJAJEDAggFAWkIcGF5bWVudHMAAQAAAwkAZgIAAwkAkAMBCAUBaQhwYXltZW50cwkAAgECMVdXWElURDogUGxlYXNlIGF0dGFjaCBhdCBsZWFzdCAxIGl0ZW0gYW5kIDEgZHVjayEDCQBmAgkAkAMBCAUBaQhwYXltZW50cwAHCQACAQIxV1dYSVREOiBZb3UgY2FuIG9ubHkgYXR0YWNoIDUgaXRlbXMgYW5kIG9uZSBkdWNrIQoBCmhhbmRsZUl0ZW0CA2FjYwdwYXltZW50BAVpbmRleAkAzwgCCAUBaQhwYXltZW50cwUHcGF5bWVudAMJAAACBQVpbmRleAAABAZkdWNrSWQJANgEAQkBBXZhbHVlAQgFB3BheW1lbnQHYXNzZXRJZAMJAQIhPQIIBQdwYXltZW50BmFtb3VudAABCQACAQIbV1JJVEQ6IER1Y2sgaXMgbm90IGF0dGFjaGVkBAhjaGlsZHJlbgkBBWFzSW50AQkA/AcECQERZ2V0QnJlZWRlckFkZHJlc3MAAhZ2YWxpZGF0ZUFuZEdldENoaWxkcmVuCQDMCAIFBmR1Y2tJZAUDbmlsBQNuaWwDCQAAAgUIY2hpbGRyZW4FCGNoaWxkcmVuCQDOCAIFA2FjYwkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIAAQgFB3BheW1lbnQHYXNzZXRJZAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQDOCAIFA2FjYwkBCHdlYXJJdGVtAwkA2AQBCQEFdmFsdWUBCAUHcGF5bWVudAdhc3NldElkCQDYBAEJAQV2YWx1ZQEICQCRAwIIBQFpCHBheW1lbnRzAAEHYXNzZXRJZAYJAM4IAgoAAiRsCAUBaQhwYXltZW50cwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEKaGFuZGxlSXRlbQIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQITTGlzdCBzaXplIGV4Y2VlZHMgNgkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgUMdmFsaWRQYXltZW50AWkBFmNhbGN1bGF0ZVdlYXJibGVzQm9vc3QBBmR1Y2tJZAQEYmFjawkBDHRyeUdldFN0cmluZwEJAQxrZXlUeXBlc0R1Y2sCBQZkdWNrSWQCBEJBQ0sEBGhlYWQJAQx0cnlHZXRTdHJpbmcBCQEMa2V5VHlwZXNEdWNrAgUGZHVja0lkAgRIRUFEBAlsZWZ0X3dpbmcJAQx0cnlHZXRTdHJpbmcBCQEMa2V5VHlwZXNEdWNrAgUGZHVja0lkAglMRUZUX1dJTkcECnJpZ2h0X3dpbmcJAQx0cnlHZXRTdHJpbmcBCQEMa2V5VHlwZXNEdWNrAgUGZHVja0lkAgpSSUdIVF9XSU5HBAN0b3AJAQx0cnlHZXRTdHJpbmcBCQEMa2V5VHlwZXNEdWNrAgUGZHVja0lkAgNUT1AEA3BldAkBDHRyeUdldFN0cmluZwEJAQxrZXlUeXBlc0R1Y2sCBQZkdWNrSWQCA1BFVAQEdGFpbAkBDHRyeUdldFN0cmluZwEJAQxrZXlUeXBlc0R1Y2sCBQZkdWNrSWQCBFRBSUwECWFjY2Vzc29yeQkBDHRyeUdldFN0cmluZwEJAQxrZXlUeXBlc0R1Y2sCBQZkdWNrSWQCCUFDQ0VTU09SWQQMYXNzZXRJZEFycmF5CQDMCAIFBGJhY2sJAMwIAgUEaGVhZAkAzAgCBQlsZWZ0X3dpbmcJAMwIAgUKcmlnaHRfd2luZwkAzAgCBQN0b3AJAMwIAgUDcGV0CQDMCAIFBHRhaWwJAMwIAgUJYWNjZXNzb3J5BQNuaWwKAQ9jb3VudFRvdGFsQm9vc3QCA2FjYwdhc3NldElkAwkBAiE9AgUHYXNzZXRJZAIABAxhcnRlZmFjdE5hbWUJAQhhc1N0cmluZwEJAPwHBAkBD2dldEl0ZW1zQWRkcmVzcwACFGNoZWNrQXJ0ZWZhY3REZXRhaWxzCQDMCAIFB2Fzc2V0SWQFA25pbAUDbmlsAwkAAAIFDGFydGVmYWN0TmFtZQUMYXJ0ZWZhY3ROYW1lBAVib29zdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEJAKwCAgIGYm9vc3RfBQxhcnRlZmFjdE5hbWUJAKwCAgITTm8gYm9vc3QgZm91bmQgZm9yIAUMYXJ0ZWZhY3ROYW1lCQBkAgUDYWNjBQVib29zdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgUDYWNjBAp0b3RhbEJvb3N0CgACJGwFDGFzc2V0SWRBcnJheQoAAiRzCQCQAwEFAiRsCgAFJGFjYzAAAAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEPY291bnRUb3RhbEJvb3N0AgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhNMaXN0IHNpemUgZXhjZWVkcyA4CQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBmR1Y2tJZAIKX2xhc3RCb29zdAUKdG90YWxCb29zdAUDbmlsBQp0b3RhbEJvb3N0AQJ0eAEGdmVyaWZ5AAMJAQlpc1Rlc3RFbnYACQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5BAlmaXJzdFVzZXIBIFEc5P1m/xJp0vFaFJ87suL0O3/By2gnojRebDjXV91tBApzZWNvbmRVc2VyASBccg5LrvEhT2bmGUX6aqKx7bE2KVlfGczMsOFNQYhqfQQJdGhpcmRVc2VyASCgr5HlLXlDYWEyEq2OufoYWVGdLVNJNsPQo/eoYBk7TgQPZmlyc3RVc2VyU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUJZmlyc3RVc2VyAAEDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwABBQlmaXJzdFVzZXIAAQMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAIFCWZpcnN0VXNlcgABAAAEEHNlY29uZFVzZXJTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQpzZWNvbmRVc2VyAAEDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwABBQpzZWNvbmRVc2VyAAEDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwACBQpzZWNvbmRVc2VyAAEAAAQPdGhpcmRVc2VyU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUJdGhpcmRVc2VyAAEDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwABBQl0aGlyZFVzZXIAAQMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAIFCXRoaXJkVXNlcgABAAAED3NpZ25hdHVyZXNDb3VudAkAZAIJAGQCBQ9maXJzdFVzZXJTaWduZWQFEHNlY29uZFVzZXJTaWduZWQFD3RoaXJkVXNlclNpZ25lZAQHJG1hdGNoMAUCdHgJAGcCBQ9zaWduYXR1cmVzQ291bnQAAhqBqHg=", "height": 3443416, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 973cNKYfrjYVZRqwRzvBsFQhs89yrFPHsiNkfgPUaf8i Next: none Diff:
Old | New | Differences | |
---|---|---|---|
145 | 145 | else { | |
146 | 146 | let type = tryGetType(artefactName) | |
147 | 147 | if (if (!(allTypes)) | |
148 | - | then !(containsElement(["PET", "BACK", "TAIL", "ACCESSORY"], type)) | |
148 | + | then !(containsElement(["PET", "BACK", "TAIL", "ACCESSORY", "HEAD"], type)) | |
149 | 149 | else false) | |
150 | 150 | then throw("You can't attach this item to your NFT! Pets only!") | |
151 | 151 | else { |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | func getBool (key) = match getBoolean(this, key) { | |
5 | 5 | case b: Boolean => | |
6 | 6 | b | |
7 | 7 | case _ => | |
8 | 8 | false | |
9 | 9 | } | |
10 | 10 | ||
11 | 11 | ||
12 | 12 | func isTestEnv () = getBool("TESTENV") | |
13 | 13 | ||
14 | 14 | ||
15 | 15 | func staticKey_oracleAddress () = "static_oracleAddress" | |
16 | 16 | ||
17 | 17 | ||
18 | 18 | func staticKey_breederAddress () = "static_breederAddress" | |
19 | 19 | ||
20 | 20 | ||
21 | 21 | func staticKey_itemsAddress () = "static_itemsAddress" | |
22 | 22 | ||
23 | 23 | ||
24 | 24 | func staticKey_extraFee () = "static_extraFee" | |
25 | 25 | ||
26 | 26 | ||
27 | 27 | func staticKey_extraFeeRemove () = "static_extraFeeRemove" | |
28 | 28 | ||
29 | 29 | ||
30 | 30 | func staticKey_feeAggregator () = "static_feeAggregator" | |
31 | 31 | ||
32 | 32 | ||
33 | 33 | let wearables = ["ART-CAPE", "ART-HAT", "ART-XSCARF", "ART-XSWEATER"] | |
34 | 34 | ||
35 | 35 | func keyArtefactDuck (duckId,wearable) = ((duckId + "_") + wearable) | |
36 | 36 | ||
37 | 37 | ||
38 | 38 | func keyTypesDuck (duckId,type) = ((duckId + "_") + type) | |
39 | 39 | ||
40 | 40 | ||
41 | 41 | func tryGetStringExternal (address,key) = match getString(address, key) { | |
42 | 42 | case a: String => | |
43 | 43 | a | |
44 | 44 | case _ => | |
45 | 45 | "" | |
46 | 46 | } | |
47 | 47 | ||
48 | 48 | ||
49 | 49 | func tryGetString (key) = tryGetStringExternal(this, key) | |
50 | 50 | ||
51 | 51 | ||
52 | 52 | func asInt (value) = match value { | |
53 | 53 | case int: Int => | |
54 | 54 | int | |
55 | 55 | case _ => | |
56 | 56 | throw("wrong type, expected: Int") | |
57 | 57 | } | |
58 | 58 | ||
59 | 59 | ||
60 | 60 | func asString (value) = match value { | |
61 | 61 | case string: String => | |
62 | 62 | string | |
63 | 63 | case _ => | |
64 | 64 | throw("wrong type, expected: String") | |
65 | 65 | } | |
66 | 66 | ||
67 | 67 | ||
68 | 68 | func getOracle () = Address(fromBase58String(tryGetString(staticKey_oracleAddress()))) | |
69 | 69 | ||
70 | 70 | ||
71 | 71 | func getBreederAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_breederAddress()))) | |
72 | 72 | ||
73 | 73 | ||
74 | 74 | func getItemsAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_itemsAddress()))) | |
75 | 75 | ||
76 | 76 | ||
77 | 77 | func getFeeAggregator () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_feeAggregator()))) | |
78 | 78 | ||
79 | 79 | ||
80 | 80 | func getTurtleIncubatorAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_turtleIncubatorAddress"))) | |
81 | 81 | ||
82 | 82 | ||
83 | 83 | func getTurtleBreederAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_turtleBreederAddress"))) | |
84 | 84 | ||
85 | 85 | ||
86 | 86 | func getIncubatorAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_incubatorAddress"))) | |
87 | 87 | ||
88 | 88 | ||
89 | 89 | func getCanineIncubatorAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_canineIncubatorAddress"))) | |
90 | 90 | ||
91 | 91 | ||
92 | 92 | func getCanineBreederAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_canineBreederAddress"))) | |
93 | 93 | ||
94 | 94 | ||
95 | 95 | func getFelineIncubatorAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_felineIncubatorAddress"))) | |
96 | 96 | ||
97 | 97 | ||
98 | 98 | func getFelineBreederAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_felineBreederAddress"))) | |
99 | 99 | ||
100 | 100 | ||
101 | 101 | func getMutantBreederAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_mutantIncubatorAddress"))) | |
102 | 102 | ||
103 | 103 | ||
104 | 104 | func checkAdditionalPayment (payment,amountOverride) = if (isDefined(payment.assetId)) | |
105 | 105 | then throw("WCAP: Please attach waves") | |
106 | 106 | else { | |
107 | 107 | let feeAmount = if ((amountOverride != 0)) | |
108 | 108 | then amountOverride | |
109 | 109 | else getIntegerValue(getOracle(), staticKey_extraFee()) | |
110 | 110 | if ((payment.amount != feeAmount)) | |
111 | 111 | then throw((("WCAP: Please attach exactly " + toString(feeAmount)) + " amount of wavelets")) | |
112 | 112 | else [ScriptTransfer(getFeeAggregator(), feeAmount, unit)] | |
113 | 113 | } | |
114 | 114 | ||
115 | 115 | ||
116 | 116 | func tryGetCosmeticItem (item) = { | |
117 | 117 | let key = ("direct_cosmetic_" + item) | |
118 | 118 | match getInteger(getItemsAddress(), key) { | |
119 | 119 | case a: Int => | |
120 | 120 | a | |
121 | 121 | case _ => | |
122 | 122 | unit | |
123 | 123 | } | |
124 | 124 | } | |
125 | 125 | ||
126 | 126 | ||
127 | 127 | func tryGetType (wearable) = tryGetStringExternal(getItemsAddress(), ("type_cosmetic_" + wearable)) | |
128 | 128 | ||
129 | 129 | ||
130 | 130 | func wearItem (assetIdWearAble,duckId,allTypes) = { | |
131 | 131 | let artefactName = asString(invoke(getItemsAddress(), "checkArtefactDetails", [assetIdWearAble], nil)) | |
132 | 132 | if ((artefactName == artefactName)) | |
133 | 133 | then if (if (!(containsElement(wearables, artefactName))) | |
134 | 134 | then !(isDefined(tryGetCosmeticItem(artefactName))) | |
135 | 135 | else false) | |
136 | 136 | then throw("WRITD: Unsupported wearable") | |
137 | 137 | else { | |
138 | 138 | let artefactId = tryGetString(keyArtefactDuck(duckId, artefactName)) | |
139 | 139 | let boostDuck = if ((artefactName == "ART-XSCARF")) | |
140 | 140 | then invoke(getItemsAddress(), "manipulateBoost", [69, duckId], nil) | |
141 | 141 | else nil | |
142 | 142 | if ((boostDuck == boostDuck)) | |
143 | 143 | then if ((artefactId != "")) | |
144 | 144 | then throw(("Duck is already wearing a " + artefactName)) | |
145 | 145 | else { | |
146 | 146 | let type = tryGetType(artefactName) | |
147 | 147 | if (if (!(allTypes)) | |
148 | - | then !(containsElement(["PET", "BACK", "TAIL", "ACCESSORY"], type)) | |
148 | + | then !(containsElement(["PET", "BACK", "TAIL", "ACCESSORY", "HEAD"], type)) | |
149 | 149 | else false) | |
150 | 150 | then throw("You can't attach this item to your NFT! Pets only!") | |
151 | 151 | else { | |
152 | 152 | let typeOnDuck = if ((type != "")) | |
153 | 153 | then (tryGetString(keyTypesDuck(duckId, type)) != "") | |
154 | 154 | else throw(("Type undefined, please contact admins " + artefactName)) | |
155 | 155 | if (typeOnDuck) | |
156 | 156 | then throw("You can only attach 1 from each type to your duck!") | |
157 | 157 | else { | |
158 | 158 | let typeResult = if ((type != "")) | |
159 | 159 | then [StringEntry(keyTypesDuck(duckId, type), assetIdWearAble)] | |
160 | 160 | else nil | |
161 | 161 | ([StringEntry(keyArtefactDuck(duckId, artefactName), assetIdWearAble)] ++ typeResult) | |
162 | 162 | } | |
163 | 163 | } | |
164 | 164 | } | |
165 | 165 | else throw("Strict value is not equal to itself.") | |
166 | 166 | } | |
167 | 167 | else throw("Strict value is not equal to itself.") | |
168 | 168 | } | |
169 | 169 | ||
170 | 170 | ||
171 | 171 | func tryGetBooleanExternal (address,key) = match getBoolean(address, key) { | |
172 | 172 | case b: Boolean => | |
173 | 173 | b | |
174 | 174 | case _ => | |
175 | 175 | false | |
176 | 176 | } | |
177 | 177 | ||
178 | 178 | ||
179 | 179 | func getIfAllTypesAllowed (assetId) = { | |
180 | 180 | let issuer = value(assetInfo(assetId)).issuer | |
181 | 181 | let blacklisted = tryGetBooleanExternal(issuer, (toBase58String(assetId) + "_blacklisted")) | |
182 | 182 | if (blacklisted) | |
183 | 183 | then throw("GO FUCK YOURSELF") | |
184 | 184 | else { | |
185 | 185 | let name = value(assetInfo(assetId)).name | |
186 | 186 | if (if ((issuer == getIncubatorAddress())) | |
187 | 187 | then true | |
188 | 188 | else (issuer == getBreederAddress())) | |
189 | 189 | then true | |
190 | 190 | else if (if ((issuer == getTurtleIncubatorAddress())) | |
191 | 191 | then true | |
192 | 192 | else (issuer == getTurtleBreederAddress())) | |
193 | 193 | then false | |
194 | 194 | else if (if ((issuer == getCanineIncubatorAddress())) | |
195 | 195 | then true | |
196 | 196 | else (issuer == getCanineBreederAddress())) | |
197 | 197 | then false | |
198 | 198 | else if (if ((issuer == getFelineIncubatorAddress())) | |
199 | 199 | then true | |
200 | 200 | else (issuer == getFelineBreederAddress())) | |
201 | 201 | then false | |
202 | 202 | else if ((issuer == getMutantBreederAddress())) | |
203 | 203 | then false | |
204 | 204 | else throw("MAG: Asset is not supported") | |
205 | 205 | } | |
206 | 206 | } | |
207 | 207 | ||
208 | 208 | ||
209 | 209 | @Callable(i) | |
210 | 210 | func configureOracle (oracle) = if ((i.caller != this)) | |
211 | 211 | then throw("admin only") | |
212 | 212 | else [StringEntry(staticKey_oracleAddress(), oracle)] | |
213 | 213 | ||
214 | 214 | ||
215 | 215 | ||
216 | 216 | @Callable(i) | |
217 | 217 | func wearItemToDuck () = { | |
218 | 218 | let firstPayment = value(i.payments[0]) | |
219 | 219 | let secondPayment = value(i.payments[1]) | |
220 | 220 | let validPayment = checkAdditionalPayment(i.payments[2], 0) | |
221 | 221 | let duckId = toBase58String(value(firstPayment.assetId)) | |
222 | 222 | let secondAssetId = toBase58String(value(secondPayment.assetId)) | |
223 | 223 | if (if ((firstPayment.amount != 1)) | |
224 | 224 | then true | |
225 | 225 | else (secondPayment.amount != 1)) | |
226 | 226 | then throw("WRITD: NFT is not attached") | |
227 | 227 | else { | |
228 | 228 | let allTypes = getIfAllTypesAllowed(value(firstPayment.assetId)) | |
229 | 229 | ((wearItem(secondAssetId, duckId, allTypes) ++ [ScriptTransfer(i.caller, 1, firstPayment.assetId)]) ++ validPayment) | |
230 | 230 | } | |
231 | 231 | } | |
232 | 232 | ||
233 | 233 | ||
234 | 234 | ||
235 | 235 | @Callable(i) | |
236 | 236 | func removeItemFromDuck (burnItem,artefactName) = { | |
237 | 237 | let wavesFee = if (burnItem) | |
238 | 238 | then 0 | |
239 | 239 | else getIntegerValue(getOracle(), staticKey_extraFeeRemove()) | |
240 | 240 | let duckPayment = value(i.payments[0]) | |
241 | 241 | let roboDuckPayment = value(i.payments[1]) | |
242 | 242 | let validPayment = checkAdditionalPayment(i.payments[2], wavesFee) | |
243 | 243 | let duckId = toBase58String(value(duckPayment.assetId)) | |
244 | 244 | let roboDuckId = toBase58String(value(roboDuckPayment.assetId)) | |
245 | 245 | if (if ((duckPayment.amount != 1)) | |
246 | 246 | then true | |
247 | 247 | else (roboDuckPayment.amount != 1)) | |
248 | 248 | then throw("WRITD: NFT is not attached") | |
249 | 249 | else { | |
250 | 250 | let children = asInt(invoke(getBreederAddress(), "validateAndGetChildren", [duckId], nil)) | |
251 | 251 | if ((children == children)) | |
252 | 252 | then { | |
253 | 253 | let artefactNameRoboduck = asString(invoke(getItemsAddress(), "checkArtefactDetails", [roboDuckId], nil)) | |
254 | 254 | if ((artefactNameRoboduck == artefactNameRoboduck)) | |
255 | 255 | then if ((artefactNameRoboduck != "ART-ROBODUCK")) | |
256 | 256 | then throw("Only rododuck can remove items!") | |
257 | 257 | else if (if (!(containsElement(wearables, artefactName))) | |
258 | 258 | then !(isDefined(tryGetCosmeticItem(artefactName))) | |
259 | 259 | else false) | |
260 | 260 | then throw("WRITD: Unsupported wearable") | |
261 | 261 | else { | |
262 | 262 | let artefactId = tryGetString(keyArtefactDuck(duckId, artefactName)) | |
263 | 263 | let boostDuck = if ((artefactName == "ART-XSCARF")) | |
264 | 264 | then invoke(getItemsAddress(), "manipulateBoost", [69, duckId], nil) | |
265 | 265 | else nil | |
266 | 266 | if ((boostDuck == boostDuck)) | |
267 | 267 | then if ((artefactId == "")) | |
268 | 268 | then throw(("Duck not wearing a " + artefactName)) | |
269 | 269 | else { | |
270 | 270 | let type = tryGetType(artefactName) | |
271 | 271 | let typeResult = if ((type != "")) | |
272 | 272 | then [DeleteEntry(keyTypesDuck(duckId, type))] | |
273 | 273 | else nil | |
274 | 274 | let burn = if (burnItem) | |
275 | 275 | then [Burn(fromBase58String(artefactId), 1)] | |
276 | 276 | else [ScriptTransfer(i.caller, 1, fromBase58String(artefactId))] | |
277 | 277 | ((([DeleteEntry(keyArtefactDuck(duckId, artefactName)), ScriptTransfer(i.caller, 1, duckPayment.assetId), Burn(fromBase58String(roboDuckId), 1)] ++ burn) ++ validPayment) ++ typeResult) | |
278 | 278 | } | |
279 | 279 | else throw("Strict value is not equal to itself.") | |
280 | 280 | } | |
281 | 281 | else throw("Strict value is not equal to itself.") | |
282 | 282 | } | |
283 | 283 | else throw("Strict value is not equal to itself.") | |
284 | 284 | } | |
285 | 285 | } | |
286 | 286 | ||
287 | 287 | ||
288 | 288 | ||
289 | 289 | @Callable(i) | |
290 | 290 | func wearXItemsToDuck () = { | |
291 | 291 | let validPayment = checkAdditionalPayment(i.payments[1], 0) | |
292 | 292 | if ((3 > size(i.payments))) | |
293 | 293 | then throw("WWXITD: Please attach at least 1 item and 1 duck!") | |
294 | 294 | else if ((size(i.payments) > 7)) | |
295 | 295 | then throw("WWXITD: You can only attach 5 items and one duck!") | |
296 | 296 | else { | |
297 | 297 | func handleItem (acc,payment) = { | |
298 | 298 | let index = indexOf(i.payments, payment) | |
299 | 299 | if ((index == 0)) | |
300 | 300 | then { | |
301 | 301 | let duckId = toBase58String(value(payment.assetId)) | |
302 | 302 | if ((payment.amount != 1)) | |
303 | 303 | then throw("WRITD: Duck is not attached") | |
304 | 304 | else { | |
305 | 305 | let children = asInt(invoke(getBreederAddress(), "validateAndGetChildren", [duckId], nil)) | |
306 | 306 | if ((children == children)) | |
307 | 307 | then (acc ++ [ScriptTransfer(i.caller, 1, payment.assetId)]) | |
308 | 308 | else throw("Strict value is not equal to itself.") | |
309 | 309 | } | |
310 | 310 | } | |
311 | 311 | else (acc ++ wearItem(toBase58String(value(payment.assetId)), toBase58String(value(i.payments[1].assetId)), true)) | |
312 | 312 | } | |
313 | 313 | ||
314 | 314 | ({ | |
315 | 315 | let $l = i.payments | |
316 | 316 | let $s = size($l) | |
317 | 317 | let $acc0 = nil | |
318 | 318 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
319 | 319 | then $a | |
320 | 320 | else handleItem($a, $l[$i]) | |
321 | 321 | ||
322 | 322 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
323 | 323 | then $a | |
324 | 324 | else throw("List size exceeds 6") | |
325 | 325 | ||
326 | 326 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6) | |
327 | 327 | } ++ validPayment) | |
328 | 328 | } | |
329 | 329 | } | |
330 | 330 | ||
331 | 331 | ||
332 | 332 | ||
333 | 333 | @Callable(i) | |
334 | 334 | func calculateWearblesBoost (duckId) = { | |
335 | 335 | let back = tryGetString(keyTypesDuck(duckId, "BACK")) | |
336 | 336 | let head = tryGetString(keyTypesDuck(duckId, "HEAD")) | |
337 | 337 | let left_wing = tryGetString(keyTypesDuck(duckId, "LEFT_WING")) | |
338 | 338 | let right_wing = tryGetString(keyTypesDuck(duckId, "RIGHT_WING")) | |
339 | 339 | let top = tryGetString(keyTypesDuck(duckId, "TOP")) | |
340 | 340 | let pet = tryGetString(keyTypesDuck(duckId, "PET")) | |
341 | 341 | let tail = tryGetString(keyTypesDuck(duckId, "TAIL")) | |
342 | 342 | let accessory = tryGetString(keyTypesDuck(duckId, "ACCESSORY")) | |
343 | 343 | let assetIdArray = [back, head, left_wing, right_wing, top, pet, tail, accessory] | |
344 | 344 | func countTotalBoost (acc,assetId) = if ((assetId != "")) | |
345 | 345 | then { | |
346 | 346 | let artefactName = asString(invoke(getItemsAddress(), "checkArtefactDetails", [assetId], nil)) | |
347 | 347 | if ((artefactName == artefactName)) | |
348 | 348 | then { | |
349 | 349 | let boost = valueOrErrorMessage(getInteger(("boost_" + artefactName)), ("No boost found for " + artefactName)) | |
350 | 350 | (acc + boost) | |
351 | 351 | } | |
352 | 352 | else throw("Strict value is not equal to itself.") | |
353 | 353 | } | |
354 | 354 | else acc | |
355 | 355 | ||
356 | 356 | let totalBoost = { | |
357 | 357 | let $l = assetIdArray | |
358 | 358 | let $s = size($l) | |
359 | 359 | let $acc0 = 0 | |
360 | 360 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
361 | 361 | then $a | |
362 | 362 | else countTotalBoost($a, $l[$i]) | |
363 | 363 | ||
364 | 364 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
365 | 365 | then $a | |
366 | 366 | else throw("List size exceeds 8") | |
367 | 367 | ||
368 | 368 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8) | |
369 | 369 | } | |
370 | 370 | $Tuple2([IntegerEntry((duckId + "_lastBoost"), totalBoost)], totalBoost) | |
371 | 371 | } | |
372 | 372 | ||
373 | 373 | ||
374 | 374 | @Verifier(tx) | |
375 | 375 | func verify () = if (isTestEnv()) | |
376 | 376 | then sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
377 | 377 | else { | |
378 | 378 | let firstUser = base58'6TdaXEfhnjYquvPf3yV7MFxt2CbgFmaqsvGwkKfXtKi4' | |
379 | 379 | let secondUser = base58'7DsP2WaMLocbHuUxux7pbXRjTrrZ1TFQPsi5QumS3gr8' | |
380 | 380 | let thirdUser = base58'BpFWP3p3JgYrrP45xfrKzeMcWMEXoinj4FVPPkUiA8D3' | |
381 | 381 | let firstUserSigned = if (sigVerify(tx.bodyBytes, tx.proofs[0], firstUser)) | |
382 | 382 | then 1 | |
383 | 383 | else if (sigVerify(tx.bodyBytes, tx.proofs[1], firstUser)) | |
384 | 384 | then 1 | |
385 | 385 | else if (sigVerify(tx.bodyBytes, tx.proofs[2], firstUser)) | |
386 | 386 | then 1 | |
387 | 387 | else 0 | |
388 | 388 | let secondUserSigned = if (sigVerify(tx.bodyBytes, tx.proofs[0], secondUser)) | |
389 | 389 | then 1 | |
390 | 390 | else if (sigVerify(tx.bodyBytes, tx.proofs[1], secondUser)) | |
391 | 391 | then 1 | |
392 | 392 | else if (sigVerify(tx.bodyBytes, tx.proofs[2], secondUser)) | |
393 | 393 | then 1 | |
394 | 394 | else 0 | |
395 | 395 | let thirdUserSigned = if (sigVerify(tx.bodyBytes, tx.proofs[0], thirdUser)) | |
396 | 396 | then 1 | |
397 | 397 | else if (sigVerify(tx.bodyBytes, tx.proofs[1], thirdUser)) | |
398 | 398 | then 1 | |
399 | 399 | else if (sigVerify(tx.bodyBytes, tx.proofs[2], thirdUser)) | |
400 | 400 | then 1 | |
401 | 401 | else 0 | |
402 | 402 | let signaturesCount = ((firstUserSigned + secondUserSigned) + thirdUserSigned) | |
403 | 403 | match tx { | |
404 | 404 | case _ => | |
405 | 405 | (signaturesCount >= 2) | |
406 | 406 | } | |
407 | 407 | } | |
408 | 408 |
github/deemru/w8io/169f3d6 369.04 ms ◑