Settings

Blockchain
Network
Unit
Language
Theme
Sound New Block

Transaction

cc92b95bc8e8b54e005390cdc088432d82e2077fcc858bbd604d5560aecb10ca
Timestamp (utc)
2020-09-30 03:03:26
Fee Paid
0.00002215 BSV
(
0.00073188 BSV
-
0.00070973 BSV
)
Fee Rate
500.2 sat/KB
Version
1
Confirmations
339,444
Size Stats
4,428 B

3 Outputs

Total Output:
0.00070973 BSV
  • jrun b1b605103eMJ{"in":0,"ref":["native://Jig","aafa7d86c83122ef8f3437425071a8da74e3edd0b03af515ab44357b951e20f9_o2"],"out":["2e44260aa084ec2eb854fcd4ab184fb1707e44be4fdf33844bbb2661c91a6279"],"del":[],"cre":["n2UeYD39YQ9pzxkbJfkDtNBRiV8PoNvLbq"],"exec":[{"op":"DEPLOY","data":["class Blacklist extends Jig {\n init(timestamp) {\n this.classname = \"Blacklist: \";\n const function_id = this.classname + \"init(): \";\n if (!timestamp) throw function_id + \"timestamp missing: \" + timestamp;\n\n this._checkTimestamp(timestamp);\n\n this.list = [];\n this.timestamps = [];\n this.list_action_numbers = [];\n this.action = \"init\";\n }\n\n linkAdminCounter(admincounter) {\n /* this should be done right after creation, we need it separate from init() because we first need to link multlist to the tokencontract and then the other way */\n if (this.admincounter) throw this.classname + \": already an admincounter linked: \" + this.admincounter.origin;\n this.admincounter = admincounter;\n this.action = \"linkAdminCounter\";\n }\n\n blacklist(address, timestamp) {\n const function_id = this.classname + \"blacklist(): \"; // params checks\n\n if (!timestamp) throw this.classname + \": publish: timestamp missing: \" + timestamp;\n\n this._checkTimestamp(timestamp);\n\n if (this.owner != this.constructor.owner) throw function_id + \" Only \" + this.classname + \"'s owner may manage blacklist\";\n if (typeof address != \"string\") throw function_id + ' address to blacklist must be a string: ' + address;\n if (address == this.owner) throw function_id + \" you cannot blacklist your own administration address\";\n if (address.length < 26) throw function_id + \" address is too short: \" + address.length;\n if (!address.match(\"^[A-Za-z0-9]+$\")) throw function_id + \" wrong character in address: \" + address;\n if (this.list.includes(address)) throw function_id + \" address is already in blacklist\"; // all parameters checks passed\n\n if (!this.admincounter) {\n throw function_id + \" no admincounter contract found, please link one before publishing\";\n } else {\n this.admincounter.auth(); //ensures only the tokencontract owner can publish // for run 0.6\n\n this.action_count = this.admincounter.nonce; // for run 0.6\n }\n\n this.list_action_numbers.push(this.action_count); // as an array for practicality\n\n this.list.push(address);\n this.timestamps.push(timestamp);\n this.action = \"blacklist\";\n } // beware allowing remove introduces a security breach if an hacker can unblacklist his address and send some of his tokens to others to taint them\n //remove(address){\n // expect(address).toBeString(this.classname+': address to blacklist must be a string')\n // if(!this.list.has(address)) throw this.classname+\": address to remove is not in blacklist\" \n // this.list.delete(address)\n //}\n\n\n isBlacklisted(address) {\n if (this.list.includes(address)) return true;else return false;\n }\n\n _checkNum(number) {\n // check that number is a positive number (but can be float)\n const function_id = this.classname + \": _checkNum(): \";\n if (typeof number !== 'number') throw function_id + 'number is not a number : ' + number; // throw gives better error trace than expect()\n\n if (!(number > 0)) throw new Error(function_id + 'number must be positive : ' + number);\n if (number > Number.MAX_SAFE_INTEGER) throw new Error(function_id + 'number too large : ' + number);\n }\n\n _checkTimestamp(timestamp) {\n const function_id = this.classname + \": _checkTimestamp(): \";\n\n try {\n this._checkNum(timestamp); // applies as well to timestamp\n\n } catch (e) {\n throw function_id + e;\n }\n\n if (!Number.isInteger(timestamp)) throw function_id + 'timestamp must be an integer : ' + timestamp; //necessary because _checkNum doesn't do it\n\n if (!(timestamp > 1600939295117)) throw function_id + ': timestamp must be older than 1600939295117 : ' + timestamp; // make sure the timestamp here is in ms!!\n }\n\n}",{"deps":{"Jig":{"$jig":0},"expect":{"$jig":1}},"sealed":true}]}]}
    https://whatsonchain.com/tx/cc92b95bc8e8b54e005390cdc088432d82e2077fcc858bbd604d5560aecb10ca