{
  "address": "0x4C98aF741e352C6551BfF9509b3f8ca9Dd4E6397",
  "abi": [
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "_owner",
          "type": "address"
        },
        {
          "internalType": "address",
          "name": "_memberToken",
          "type": "address"
        },
        {
          "internalType": "address",
          "name": "_controllerRegistry",
          "type": "address"
        },
        {
          "internalType": "address",
          "name": "_proxyFactoryAddress",
          "type": "address"
        },
        {
          "internalType": "address",
          "name": "_gnosisMasterAddress",
          "type": "address"
        },
        {
          "internalType": "address",
          "name": "_podEnsRegistrar",
          "type": "address"
        },
        {
          "internalType": "address",
          "name": "_fallbackHandlerAddress",
          "type": "address"
        }
      ],
      "stateMutability": "nonpayable",
      "type": "constructor"
    },
    {
      "anonymous": false,
      "inputs": [
        {
          "indexed": false,
          "internalType": "uint256",
          "name": "podId",
          "type": "uint256"
        },
        {
          "indexed": false,
          "internalType": "address",
          "name": "safe",
          "type": "address"
        },
        {
          "indexed": false,
          "internalType": "address",
          "name": "admin",
          "type": "address"
        },
        {
          "indexed": false,
          "internalType": "string",
          "name": "ensName",
          "type": "string"
        }
      ],
      "name": "CreatePod",
      "type": "event"
    },
    {
      "anonymous": false,
      "inputs": [
        {
          "indexed": false,
          "internalType": "uint256",
          "name": "podId",
          "type": "uint256"
        }
      ],
      "name": "DeregisterPod",
      "type": "event"
    },
    {
      "anonymous": false,
      "inputs": [
        {
          "indexed": true,
          "internalType": "address",
          "name": "previousOwner",
          "type": "address"
        },
        {
          "indexed": true,
          "internalType": "address",
          "name": "newOwner",
          "type": "address"
        }
      ],
      "name": "OwnershipTransferred",
      "type": "event"
    },
    {
      "anonymous": false,
      "inputs": [
        {
          "indexed": false,
          "internalType": "uint256",
          "name": "podId",
          "type": "uint256"
        },
        {
          "indexed": false,
          "internalType": "address",
          "name": "admin",
          "type": "address"
        }
      ],
      "name": "UpdatePodAdmin",
      "type": "event"
    },
    {
      "inputs": [],
      "name": "ENCODED_SIG_ADD_OWNER",
      "outputs": [
        {
          "internalType": "bytes4",
          "name": "",
          "type": "bytes4"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "ENCODED_SIG_DISABLE_MOD",
      "outputs": [
        {
          "internalType": "bytes4",
          "name": "",
          "type": "bytes4"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "ENCODED_SIG_ENABLE_MOD",
      "outputs": [
        {
          "internalType": "bytes4",
          "name": "",
          "type": "bytes4"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "ENCODED_SIG_REMOVE_OWNER",
      "outputs": [
        {
          "internalType": "bytes4",
          "name": "",
          "type": "bytes4"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "ENCODED_SIG_SET_GUARD",
      "outputs": [
        {
          "internalType": "bytes4",
          "name": "",
          "type": "bytes4"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "ENCODED_SIG_SWAP_OWNER",
      "outputs": [
        {
          "internalType": "bytes4",
          "name": "",
          "type": "bytes4"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "FUNCTION_SIG_ENABLE",
      "outputs": [
        {
          "internalType": "string",
          "name": "",
          "type": "string"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "FUNCTION_SIG_EXEC",
      "outputs": [
        {
          "internalType": "string",
          "name": "",
          "type": "string"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "FUNCTION_SIG_SETUP",
      "outputs": [
        {
          "internalType": "string",
          "name": "",
          "type": "string"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "VERSION",
      "outputs": [
        {
          "internalType": "string",
          "name": "",
          "type": "string"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "",
          "type": "address"
        }
      ],
      "name": "areModulesLocked",
      "outputs": [
        {
          "internalType": "bool",
          "name": "",
          "type": "bool"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "uint256",
          "name": "_podId",
          "type": "uint256"
        },
        {
          "internalType": "address[]",
          "name": "_mintMembers",
          "type": "address[]"
        },
        {
          "internalType": "address[]",
          "name": "_burnMembers",
          "type": "address[]"
        }
      ],
      "name": "batchMintAndBurn",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "operator",
          "type": "address"
        },
        {
          "internalType": "address",
          "name": "from",
          "type": "address"
        },
        {
          "internalType": "address",
          "name": "to",
          "type": "address"
        },
        {
          "internalType": "uint256[]",
          "name": "ids",
          "type": "uint256[]"
        },
        {
          "internalType": "uint256[]",
          "name": "",
          "type": "uint256[]"
        },
        {
          "internalType": "bytes",
          "name": "data",
          "type": "bytes"
        }
      ],
      "name": "beforeTokenTransfer",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "bytes32",
          "name": "",
          "type": "bytes32"
        },
        {
          "internalType": "bool",
          "name": "",
          "type": "bool"
        }
      ],
      "name": "checkAfterExecution",
      "outputs": [],
      "stateMutability": "pure",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "",
          "type": "address"
        },
        {
          "internalType": "uint256",
          "name": "",
          "type": "uint256"
        },
        {
          "internalType": "bytes",
          "name": "data",
          "type": "bytes"
        },
        {
          "internalType": "enum Enum.Operation",
          "name": "",
          "type": "uint8"
        },
        {
          "internalType": "uint256",
          "name": "",
          "type": "uint256"
        },
        {
          "internalType": "uint256",
          "name": "",
          "type": "uint256"
        },
        {
          "internalType": "uint256",
          "name": "",
          "type": "uint256"
        },
        {
          "internalType": "address",
          "name": "",
          "type": "address"
        },
        {
          "internalType": "address payable",
          "name": "",
          "type": "address"
        },
        {
          "internalType": "bytes",
          "name": "",
          "type": "bytes"
        },
        {
          "internalType": "address",
          "name": "",
          "type": "address"
        }
      ],
      "name": "checkTransaction",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "controllerRegistry",
      "outputs": [
        {
          "internalType": "contract IControllerRegistry",
          "name": "",
          "type": "address"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address[]",
          "name": "_members",
          "type": "address[]"
        },
        {
          "internalType": "uint256",
          "name": "threshold",
          "type": "uint256"
        },
        {
          "internalType": "address",
          "name": "_admin",
          "type": "address"
        },
        {
          "internalType": "bytes32",
          "name": "_label",
          "type": "bytes32"
        },
        {
          "internalType": "string",
          "name": "_ensString",
          "type": "string"
        },
        {
          "internalType": "uint256",
          "name": "expectedPodId",
          "type": "uint256"
        },
        {
          "internalType": "string",
          "name": "_imageUrl",
          "type": "string"
        }
      ],
      "name": "createPod",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "_admin",
          "type": "address"
        },
        {
          "internalType": "address",
          "name": "_safe",
          "type": "address"
        },
        {
          "internalType": "bytes32",
          "name": "_label",
          "type": "bytes32"
        },
        {
          "internalType": "string",
          "name": "_ensString",
          "type": "string"
        },
        {
          "internalType": "uint256",
          "name": "expectedPodId",
          "type": "uint256"
        },
        {
          "internalType": "string",
          "name": "_imageUrl",
          "type": "string"
        }
      ],
      "name": "createPodWithSafe",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "_context",
          "type": "address"
        }
      ],
      "name": "delegateSetup",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "uint256",
          "name": "podId",
          "type": "uint256"
        },
        {
          "internalType": "bytes32",
          "name": "label",
          "type": "bytes32"
        },
        {
          "internalType": "address",
          "name": "previousModule",
          "type": "address"
        }
      ],
      "name": "ejectSafe",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "module",
          "type": "address"
        }
      ],
      "name": "enableModule",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "fallbackHandlerAddress",
      "outputs": [
        {
          "internalType": "address",
          "name": "",
          "type": "address"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "safe",
          "type": "address"
        }
      ],
      "name": "getSafeMembers",
      "outputs": [
        {
          "internalType": "address[]",
          "name": "",
          "type": "address[]"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "gnosisMasterAddress",
      "outputs": [
        {
          "internalType": "address",
          "name": "",
          "type": "address"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "safe",
          "type": "address"
        },
        {
          "internalType": "address",
          "name": "member",
          "type": "address"
        }
      ],
      "name": "isSafeMember",
      "outputs": [
        {
          "internalType": "bool",
          "name": "",
          "type": "bool"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "safe",
          "type": "address"
        }
      ],
      "name": "isSafeModuleEnabled",
      "outputs": [
        {
          "internalType": "bool",
          "name": "",
          "type": "bool"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "uint256",
          "name": "",
          "type": "uint256"
        }
      ],
      "name": "isTransferLocked",
      "outputs": [
        {
          "internalType": "bool",
          "name": "",
          "type": "bool"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "memberToken",
      "outputs": [
        {
          "internalType": "contract IMemberToken",
          "name": "",
          "type": "address"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "uint256",
          "name": "_podId",
          "type": "uint256"
        },
        {
          "internalType": "address",
          "name": "_newController",
          "type": "address"
        },
        {
          "internalType": "address",
          "name": "_prevModule",
          "type": "address"
        }
      ],
      "name": "migratePodController",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "owner",
      "outputs": [
        {
          "internalType": "address",
          "name": "",
          "type": "address"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "uint256",
          "name": "",
          "type": "uint256"
        }
      ],
      "name": "podAdmin",
      "outputs": [
        {
          "internalType": "address",
          "name": "",
          "type": "address"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "podEnsRegistrar",
      "outputs": [
        {
          "internalType": "contract IPodEnsRegistrar",
          "name": "",
          "type": "address"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "uint256",
          "name": "",
          "type": "uint256"
        }
      ],
      "name": "podIdToSafe",
      "outputs": [
        {
          "internalType": "address",
          "name": "",
          "type": "address"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "proxyFactoryAddress",
      "outputs": [
        {
          "internalType": "address",
          "name": "",
          "type": "address"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address[]",
          "name": "members",
          "type": "address[]"
        },
        {
          "internalType": "uint256",
          "name": "threshold",
          "type": "uint256"
        },
        {
          "internalType": "uint256",
          "name": "podId",
          "type": "uint256"
        }
      ],
      "name": "recoverSafe",
      "outputs": [
        {
          "internalType": "address",
          "name": "",
          "type": "address"
        }
      ],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [],
      "name": "renounceOwnership",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "",
          "type": "address"
        }
      ],
      "name": "safeToPodId",
      "outputs": [
        {
          "internalType": "uint256",
          "name": "",
          "type": "uint256"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "uint256",
          "name": "_podId",
          "type": "uint256"
        },
        {
          "internalType": "bool",
          "name": "_isLocked",
          "type": "bool"
        }
      ],
      "name": "setPodModuleLock",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "uint256",
          "name": "_podId",
          "type": "uint256"
        },
        {
          "internalType": "bool",
          "name": "_isTransferLocked",
          "type": "bool"
        }
      ],
      "name": "setPodTransferLock",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "bytes4",
          "name": "interfaceId",
          "type": "bytes4"
        }
      ],
      "name": "supportsInterface",
      "outputs": [
        {
          "internalType": "bool",
          "name": "",
          "type": "bool"
        }
      ],
      "stateMutability": "view",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "newOwner",
          "type": "address"
        }
      ],
      "name": "transferOwnership",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "uint256",
          "name": "_podId",
          "type": "uint256"
        },
        {
          "internalType": "address",
          "name": "_newAdmin",
          "type": "address"
        }
      ],
      "name": "updatePodAdmin",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "address",
          "name": "_podEnsRegistrar",
          "type": "address"
        }
      ],
      "name": "updatePodEnsRegistrar",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    },
    {
      "inputs": [
        {
          "internalType": "uint256",
          "name": "_podId",
          "type": "uint256"
        },
        {
          "internalType": "address",
          "name": "_podAdmin",
          "type": "address"
        },
        {
          "internalType": "address",
          "name": "_safeAddress",
          "type": "address"
        }
      ],
      "name": "updatePodState",
      "outputs": [],
      "stateMutability": "nonpayable",
      "type": "function"
    }
  ],
  "transactionHash": "0x5d4a0a98eaa78fa6e15fa4c21e332aa56a00ac172d096535ad1d8aa3ab4f5777",
  "receipt": {
    "to": "0x4e59b44847b379578588920cA78FbF26c0B4956C",
    "from": "0x2149A222feD42fefc3A120B3DdA34482190fC666",
    "contractAddress": null,
    "transactionIndex": 4,
    "gasUsed": "4426290",
    "logsBloom": "0x00000000000000000000000000000000000000000000000000800000000000000000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000001000000000000000000000000000000000000021000000000000000000800000000000000000000000000000000400800000000000000000000000000000000000000001000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000000000000000800000000000000000010000000000000000020000000000000080000000000000000000080000000000000000000000000000000",
    "blockHash": "0x18fbe31bfd07fe1f7f43eaab25a44cd00d6862e396f85e23a6c7a311ca2bf7fb",
    "transactionHash": "0x5d4a0a98eaa78fa6e15fa4c21e332aa56a00ac172d096535ad1d8aa3ab4f5777",
    "logs": [
      {
        "transactionIndex": 4,
        "blockNumber": 15360683,
        "transactionHash": "0x5d4a0a98eaa78fa6e15fa4c21e332aa56a00ac172d096535ad1d8aa3ab4f5777",
        "address": "0x4C98aF741e352C6551BfF9509b3f8ca9Dd4E6397",
        "topics": [
          "0x8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0",
          "0x0000000000000000000000000000000000000000000000000000000000000000",
          "0x0000000000000000000000004e59b44847b379578588920ca78fbf26c0b4956c"
        ],
        "data": "0x",
        "logIndex": 43,
        "blockHash": "0x18fbe31bfd07fe1f7f43eaab25a44cd00d6862e396f85e23a6c7a311ca2bf7fb"
      },
      {
        "transactionIndex": 4,
        "blockNumber": 15360683,
        "transactionHash": "0x5d4a0a98eaa78fa6e15fa4c21e332aa56a00ac172d096535ad1d8aa3ab4f5777",
        "address": "0x4C98aF741e352C6551BfF9509b3f8ca9Dd4E6397",
        "topics": [
          "0x8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0",
          "0x0000000000000000000000004e59b44847b379578588920ca78fbf26c0b4956c",
          "0x0000000000000000000000002149a222fed42fefc3a120b3dda34482190fc666"
        ],
        "data": "0x",
        "logIndex": 44,
        "blockHash": "0x18fbe31bfd07fe1f7f43eaab25a44cd00d6862e396f85e23a6c7a311ca2bf7fb"
      }
    ],
    "blockNumber": 15360683,
    "cumulativeGasUsed": "5840060",
    "status": 1,
    "byzantium": true
  },
  "args": [
    "0x2149A222feD42fefc3A120B3DdA34482190fC666",
    "0x0762aA185b6ed2dCA77945Ebe92De705e0C37AE3",
    "0x0d97643EE1051B523E4e3b66Df3640bBA6C0F79f",
    "0xa6B71E26C5e0845f74c812102Ca7114b6a896AB2",
    "0xd9Db270c1B5E3Bd161E8c8503c55cEABeE709552",
    "0x6a0d1d55CBCc107D4665e05346f5BE4dDE4C3A80",
    "0xf48f2B2d2a534e402487b3ee7C18c33Aec0Fe5e4"
  ],
  "numDeployments": 1,
  "solcInputHash": "c1fce53a706e8c2dc5575755f0e954da",
  "metadata": "{\"compiler\":{\"version\":\"0.8.7+commit.e28d00a7\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_owner\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_memberToken\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_controllerRegistry\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_proxyFactoryAddress\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_gnosisMasterAddress\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_podEnsRegistrar\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_fallbackHandlerAddress\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"podId\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"safe\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"string\",\"name\":\"ensName\",\"type\":\"string\"}],\"name\":\"CreatePod\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"podId\",\"type\":\"uint256\"}],\"name\":\"DeregisterPod\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"previousOwner\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"newOwner\",\"type\":\"address\"}],\"name\":\"OwnershipTransferred\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"podId\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"}],\"name\":\"UpdatePodAdmin\",\"type\":\"event\"},{\"inputs\":[],\"name\":\"ENCODED_SIG_ADD_OWNER\",\"outputs\":[{\"internalType\":\"bytes4\",\"name\":\"\",\"type\":\"bytes4\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"ENCODED_SIG_DISABLE_MOD\",\"outputs\":[{\"internalType\":\"bytes4\",\"name\":\"\",\"type\":\"bytes4\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"ENCODED_SIG_ENABLE_MOD\",\"outputs\":[{\"internalType\":\"bytes4\",\"name\":\"\",\"type\":\"bytes4\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"ENCODED_SIG_REMOVE_OWNER\",\"outputs\":[{\"internalType\":\"bytes4\",\"name\":\"\",\"type\":\"bytes4\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"ENCODED_SIG_SET_GUARD\",\"outputs\":[{\"internalType\":\"bytes4\",\"name\":\"\",\"type\":\"bytes4\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"ENCODED_SIG_SWAP_OWNER\",\"outputs\":[{\"internalType\":\"bytes4\",\"name\":\"\",\"type\":\"bytes4\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"FUNCTION_SIG_ENABLE\",\"outputs\":[{\"internalType\":\"string\",\"name\":\"\",\"type\":\"string\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"FUNCTION_SIG_EXEC\",\"outputs\":[{\"internalType\":\"string\",\"name\":\"\",\"type\":\"string\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"FUNCTION_SIG_SETUP\",\"outputs\":[{\"internalType\":\"string\",\"name\":\"\",\"type\":\"string\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"VERSION\",\"outputs\":[{\"internalType\":\"string\",\"name\":\"\",\"type\":\"string\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"areModulesLocked\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_podId\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"_mintMembers\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"_burnMembers\",\"type\":\"address[]\"}],\"name\":\"batchMintAndBurn\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"operator\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"from\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"},{\"internalType\":\"uint256[]\",\"name\":\"ids\",\"type\":\"uint256[]\"},{\"internalType\":\"uint256[]\",\"name\":\"\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes\",\"name\":\"data\",\"type\":\"bytes\"}],\"name\":\"beforeTokenTransfer\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"\",\"type\":\"bytes32\"},{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"name\":\"checkAfterExecution\",\"outputs\":[],\"stateMutability\":\"pure\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"bytes\",\"name\":\"data\",\"type\":\"bytes\"},{\"internalType\":\"enum Enum.Operation\",\"name\":\"\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"\",\"type\":\"bytes\"},{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"checkTransaction\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"controllerRegistry\",\"outputs\":[{\"internalType\":\"contract IControllerRegistry\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_members\",\"type\":\"address[]\"},{\"internalType\":\"uint256\",\"name\":\"threshold\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"_admin\",\"type\":\"address\"},{\"internalType\":\"bytes32\",\"name\":\"_label\",\"type\":\"bytes32\"},{\"internalType\":\"string\",\"name\":\"_ensString\",\"type\":\"string\"},{\"internalType\":\"uint256\",\"name\":\"expectedPodId\",\"type\":\"uint256\"},{\"internalType\":\"string\",\"name\":\"_imageUrl\",\"type\":\"string\"}],\"name\":\"createPod\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_admin\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_safe\",\"type\":\"address\"},{\"internalType\":\"bytes32\",\"name\":\"_label\",\"type\":\"bytes32\"},{\"internalType\":\"string\",\"name\":\"_ensString\",\"type\":\"string\"},{\"internalType\":\"uint256\",\"name\":\"expectedPodId\",\"type\":\"uint256\"},{\"internalType\":\"string\",\"name\":\"_imageUrl\",\"type\":\"string\"}],\"name\":\"createPodWithSafe\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_context\",\"type\":\"address\"}],\"name\":\"delegateSetup\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"podId\",\"type\":\"uint256\"},{\"internalType\":\"bytes32\",\"name\":\"label\",\"type\":\"bytes32\"},{\"internalType\":\"address\",\"name\":\"previousModule\",\"type\":\"address\"}],\"name\":\"ejectSafe\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"module\",\"type\":\"address\"}],\"name\":\"enableModule\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"fallbackHandlerAddress\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"safe\",\"type\":\"address\"}],\"name\":\"getSafeMembers\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"gnosisMasterAddress\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"safe\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"member\",\"type\":\"address\"}],\"name\":\"isSafeMember\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"safe\",\"type\":\"address\"}],\"name\":\"isSafeModuleEnabled\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"isTransferLocked\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"memberToken\",\"outputs\":[{\"internalType\":\"contract IMemberToken\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_podId\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"_newController\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_prevModule\",\"type\":\"address\"}],\"name\":\"migratePodController\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"owner\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"podAdmin\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"podEnsRegistrar\",\"outputs\":[{\"internalType\":\"contract IPodEnsRegistrar\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"podIdToSafe\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"proxyFactoryAddress\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"members\",\"type\":\"address[]\"},{\"internalType\":\"uint256\",\"name\":\"threshold\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"podId\",\"type\":\"uint256\"}],\"name\":\"recoverSafe\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"renounceOwnership\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"safeToPodId\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_podId\",\"type\":\"uint256\"},{\"internalType\":\"bool\",\"name\":\"_isLocked\",\"type\":\"bool\"}],\"name\":\"setPodModuleLock\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_podId\",\"type\":\"uint256\"},{\"internalType\":\"bool\",\"name\":\"_isTransferLocked\",\"type\":\"bool\"}],\"name\":\"setPodTransferLock\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"interfaceId\",\"type\":\"bytes4\"}],\"name\":\"supportsInterface\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newOwner\",\"type\":\"address\"}],\"name\":\"transferOwnership\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_podId\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"_newAdmin\",\"type\":\"address\"}],\"name\":\"updatePodAdmin\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_podEnsRegistrar\",\"type\":\"address\"}],\"name\":\"updatePodEnsRegistrar\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_podId\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"_podAdmin\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_safeAddress\",\"type\":\"address\"}],\"name\":\"updatePodState\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"}],\"devdoc\":{\"kind\":\"dev\",\"methods\":{\"beforeTokenTransfer(address,address,address,uint256[],uint256[],bytes)\":{\"params\":{\"data\":\"Passes a flag for an initial creation event\",\"from\":\"The address sending the membership token\",\"ids\":\"An array of membership token ids to be transfered\",\"operator\":\"The address that initiated the action\",\"to\":\"The address recieveing the membership token\"}},\"checkTransaction(address,uint256,bytes,uint8,uint256,uint256,uint256,address,address,bytes,address)\":{\"details\":\"This will be called by the safe at execution time time _param to Destination address of Safe transaction. _param value Ether value of Safe transaction.\",\"params\":{\"data\":\"Data payload of Safe transaction. _param operation Operation type of Safe transaction. _param safeTxGas Gas that should be used for the Safe transaction. _param baseGas Gas costs that are independent of the transaction execution(e.g. base transaction fee, signature check, payment of the refund) _param gasPrice Gas price that should be used for the payment calculation. _param gasToken Token address (or 0 if ETH) that is used for the payment. _param refundReceiver Address of receiver of gas payment (or 0 if tx.origin). _param signatures Packed signature data ({bytes32 r}{bytes32 s}{uint8 v}) _param msgSender Account executing safe transaction\"}},\"constructor\":{\"details\":\"Will instantiate safe teller with gnosis master and proxy addresses\",\"params\":{\"_controllerRegistry\":\"The address of the ControllerRegistry contract\",\"_gnosisMasterAddress\":\"The gnosis master address\",\"_memberToken\":\"The address of the MemberToken contract\",\"_proxyFactoryAddress\":\"The proxy factory address\"}},\"createPod(address[],uint256,address,bytes32,string,uint256,string)\":{\"params\":{\"_admin\":\"The address of the pod admin\",\"_ensString\":\"string of pod ens name (i.e.'mypod.pod.xyz')\",\"_label\":\"label hash of pod name (i.e labelhash('mypod'))\",\"_members\":\"The addresses of the members of the pod\",\"threshold\":\"The number of members that are required to sign a transaction\"}},\"createPodWithSafe(address,address,bytes32,string,uint256,string)\":{\"details\":\"Used to create a pod with an existing safeWill automatically distribute membership NFTs to current safe members\",\"params\":{\"_admin\":\"The address of the pod admin\",\"_ensString\":\"string of pod ens name (i.e.'mypod.pod.xyz')\",\"_label\":\"label hash of pod name (i.e labelhash('mypod'))\",\"_safe\":\"The address of existing safe\"}},\"ejectSafe(uint256,bytes32,address)\":{\"params\":{\"label\":\"- labelhash of pod ENS name, i.e., `labelhash(\\\"mypod\\\")`\",\"podId\":\"- ID of pod being ejected\",\"previousModule\":\"- previous module\"}},\"migratePodController(uint256,address,address)\":{\"details\":\"This will nullify all pod state on this controllerUpdate state on _newControllerUpdate controller to _newController in Safe and MemberToken\",\"params\":{\"_newController\":\"The address of the new pod controller\",\"_podId\":\"The id number of the pod\",\"_prevModule\":\"The module that points to the orca module in the safe's ModuleManager linked list\"}},\"owner()\":{\"details\":\"Returns the address of the current owner.\"},\"recoverSafe(address[],uint256,uint256)\":{\"params\":{\"members\":\"The addresses of the members of the pod as it was originally created.\",\"podId\":\"- Pod ID of safe you are trying to recreate\",\"threshold\":\"The number of members that are required to sign a transaction\"}},\"renounceOwnership()\":{\"details\":\"Leaves the contract without owner. It will not be possible to call `onlyOwner` functions anymore. Can only be called by the current owner. NOTE: Renouncing ownership will leave the contract without an owner, thereby removing any functionality that is only available to the owner.\"},\"setPodModuleLock(uint256,bool)\":{\"details\":\"Allows admin to unlock the safe modules and allow them to be edited by members\",\"params\":{\"_isLocked\":\"true - pod modules cannot be added/removed\",\"_podId\":\"The id number of the pod\"}},\"setPodTransferLock(uint256,bool)\":{\"params\":{\"_isTransferLocked\":\"The address of the new pod admin\",\"_podId\":\"The id number of the pod\"}},\"supportsInterface(bytes4)\":{\"details\":\"Returns true if this contract implements the interface defined by `interfaceId`. See the corresponding https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section] to learn more about how these ids are created. This function call must use less than 30 000 gas.\"},\"transferOwnership(address)\":{\"details\":\"Transfers ownership of the contract to a new account (`newOwner`). Can only be called by the current owner.\"},\"updatePodAdmin(uint256,address)\":{\"params\":{\"_newAdmin\":\"The address of the new pod admin\",\"_podId\":\"The id number of the pod\"}},\"updatePodState(uint256,address,address)\":{\"details\":\"This is called by another version of controller to migrate a pod to this versionWill only accept calls from registered controllersCan only be called once.\",\"params\":{\"_podAdmin\":\"The address of the pod admin\",\"_podId\":\"The id number of the pod\",\"_safeAddress\":\"The address of the safe\"}}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{\"ejectSafe(uint256,bytes32,address)\":{\"notice\":\"Ejects a safe from the Orca ecosystem. Also handles clean up for safes that have already been ejected. Note that the reverse registry entry cannot be cleaned up if the safe has already been ejected.\"},\"recoverSafe(address[],uint256,uint256)\":{\"notice\":\"Uses CREATE2 to replicate a given safe on a new network.\"}},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ControllerV1.sol\":\"ControllerV1\"},\"evmVersion\":\"london\",\"libraries\":{\":__CACHE_BREAKER__\":\"0x0000000000000031363630373636303437353134\"},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":1000},\"remappings\":[]},\"sources\":{\"contracts/ControllerV1.sol\":{\"content\":\"pragma solidity ^0.8.7;\\n\\nimport \\\"lib/ens-contracts/contracts/registry/ENS.sol\\\";\\nimport \\\"lib/ens-contracts/contracts/registry/ReverseRegistrar.sol\\\";\\nimport \\\"lib/ens-contracts/contracts/resolvers/Resolver.sol\\\";\\nimport \\\"lib/openzeppelin-contracts/contracts/access/Ownable.sol\\\";\\nimport \\\"lib/openzeppelin-contracts/contracts/utils/Strings.sol\\\";\\nimport \\\"./interfaces/IControllerV1.sol\\\";\\nimport \\\"./interfaces/IMemberToken.sol\\\";\\nimport \\\"./interfaces/IControllerRegistry.sol\\\";\\nimport \\\"./SafeTeller.sol\\\";\\nimport \\\"./MemberTeller.sol\\\";\\nimport \\\"./ens/IPodEnsRegistrar.sol\\\";\\nimport {BaseGuard, Enum} from \\\"lib/safe-contracts/contracts/base/GuardManager.sol\\\";\\n\\ncontract ControllerV1 is\\n    IControllerV1,\\n    SafeTeller,\\n    MemberTeller,\\n    BaseGuard,\\n    Ownable\\n{\\n    event CreatePod(uint256 podId, address safe, address admin, string ensName);\\n    event UpdatePodAdmin(uint256 podId, address admin);\\n    event DeregisterPod(uint256 podId);\\n\\n    IControllerRegistry public immutable controllerRegistry;\\n    IPodEnsRegistrar public podEnsRegistrar;\\n\\n    string public constant VERSION = \\\"1.3.0\\\";\\n\\n    mapping(address => uint256) public safeToPodId;\\n    mapping(uint256 => address) public override podIdToSafe;\\n    mapping(uint256 => address) public podAdmin;\\n    mapping(uint256 => bool) public isTransferLocked;\\n\\n    uint8 internal constant CREATE_EVENT = 0x01;\\n\\n    /**\\n     * @dev Will instantiate safe teller with gnosis master and proxy addresses\\n     * @param _memberToken The address of the MemberToken contract\\n     * @param _controllerRegistry The address of the ControllerRegistry contract\\n     * @param _proxyFactoryAddress The proxy factory address\\n     * @param _gnosisMasterAddress The gnosis master address\\n     */\\n    constructor(\\n        address _owner,\\n        address _memberToken,\\n        address _controllerRegistry,\\n        address _proxyFactoryAddress,\\n        address _gnosisMasterAddress,\\n        address _podEnsRegistrar,\\n        address _fallbackHandlerAddress\\n    )\\n        SafeTeller(\\n            _proxyFactoryAddress,\\n            _gnosisMasterAddress,\\n            _fallbackHandlerAddress\\n        )\\n        MemberTeller(_memberToken)\\n    {\\n        require(_owner != address(0), \\\"Invalid address\\\");\\n        require(_memberToken != address(0), \\\"Invalid address\\\");\\n        require(_controllerRegistry != address(0), \\\"Invalid address\\\");\\n        require(_proxyFactoryAddress != address(0), \\\"Invalid address\\\");\\n        require(_gnosisMasterAddress != address(0), \\\"Invalid address\\\");\\n        require(_podEnsRegistrar != address(0), \\\"Invalid address\\\");\\n        require(_fallbackHandlerAddress != address(0), \\\"Invalid address\\\");\\n\\n        // Set owner separately from msg.sender.\\n        transferOwnership(_owner);\\n\\n        controllerRegistry = IControllerRegistry(_controllerRegistry);\\n        podEnsRegistrar = IPodEnsRegistrar(_podEnsRegistrar);\\n    }\\n\\n    function updatePodEnsRegistrar(address _podEnsRegistrar)\\n        external\\n        override\\n        onlyOwner\\n    {\\n        require(_podEnsRegistrar != address(0), \\\"Invalid address\\\");\\n        podEnsRegistrar = IPodEnsRegistrar(_podEnsRegistrar);\\n    }\\n\\n    /**\\n     * @param _members The addresses of the members of the pod\\n     * @param threshold The number of members that are required to sign a transaction\\n     * @param _admin The address of the pod admin\\n     * @param _label label hash of pod name (i.e labelhash('mypod'))\\n     * @param _ensString string of pod ens name (i.e.'mypod.pod.xyz')\\n     */\\n    function createPod(\\n        address[] memory _members,\\n        uint256 threshold,\\n        address _admin,\\n        bytes32 _label,\\n        string memory _ensString,\\n        uint256 expectedPodId,\\n        string memory _imageUrl\\n    ) external override {\\n        address safe = createSafe(_members, threshold, expectedPodId);\\n\\n        _createPod(\\n            _members,\\n            safe,\\n            _admin,\\n            _label,\\n            _ensString,\\n            expectedPodId,\\n            _imageUrl\\n        );\\n    }\\n\\n    /**\\n     * @dev Used to create a pod with an existing safe\\n     * @dev Will automatically distribute membership NFTs to current safe members\\n     * @param _admin The address of the pod admin\\n     * @param _safe The address of existing safe\\n     * @param _label label hash of pod name (i.e labelhash('mypod'))\\n     * @param _ensString string of pod ens name (i.e.'mypod.pod.xyz')\\n     */\\n    function createPodWithSafe(\\n        address _admin,\\n        address _safe,\\n        bytes32 _label,\\n        string memory _ensString,\\n        uint256 expectedPodId,\\n        string memory _imageUrl\\n    ) external override {\\n        require(_safe != address(0), \\\"invalid safe address\\\");\\n        // safe must have zero'd pod id\\n        if (safeToPodId[_safe] == 0) {\\n            // if safe has zero pod id make sure its not set at pod id zero\\n            require(_safe != podIdToSafe[0], \\\"safe already in use\\\");\\n        } else {\\n            revert(\\\"safe already in use\\\");\\n        }\\n        require(safeToPodId[_safe] == 0, \\\"safe already in use\\\");\\n        require(isSafeModuleEnabled(_safe), \\\"safe module must be enabled\\\");\\n        require(\\n            isSafeMember(_safe, msg.sender) || msg.sender == _safe,\\n            \\\"caller must be safe or member\\\"\\n        );\\n\\n        address[] memory members = getSafeMembers(_safe);\\n\\n        _createPod(\\n            members,\\n            _safe,\\n            _admin,\\n            _label,\\n            _ensString,\\n            expectedPodId,\\n            _imageUrl\\n        );\\n    }\\n\\n    /**\\n     * @param _members The addresses of the members of the pod\\n     * @param _admin The address of the pod admin\\n     * @param _safe The address of existing safe\\n     * @param _label label hash of pod name (i.e labelhash('mypod'))\\n     * @param _ensString string of pod ens name (i.e.'mypod.pod.xyz')\\n     */\\n    function _createPod(\\n        address[] memory _members,\\n        address _safe,\\n        address _admin,\\n        bytes32 _label,\\n        string memory _ensString,\\n        uint256 expectedPodId,\\n        string memory _imageUrl\\n    ) internal {\\n        // add create event flag to token data\\n        bytes memory data = new bytes(1);\\n        data[0] = bytes1(uint8(CREATE_EVENT));\\n\\n        uint256 podId = memberToken.createPod(_members, data);\\n        // The imageUrl has an expected pod ID, but we need to make sure it aligns with the actual pod ID\\n        require(podId == expectedPodId, \\\"pod id didn't match, try again\\\");\\n\\n        emit CreatePod(podId, _safe, _admin, _ensString);\\n        emit UpdatePodAdmin(podId, _admin);\\n\\n        // add controller as guard\\n        setSafeGuard(_safe, address(this));\\n        if (_admin != address(0)) {\\n            // will lock safe modules if admin exists\\n            setModuleLock(_safe, true);\\n            podAdmin[podId] = _admin;\\n        }\\n        podIdToSafe[podId] = _safe;\\n        safeToPodId[_safe] = podId;\\n\\n        // setup pod ENS\\n        address reverseRegistrar = podEnsRegistrar.registerPod(\\n            _label,\\n            _safe,\\n            msg.sender\\n        );\\n        setupSafeReverseResolver(_safe, reverseRegistrar, _ensString);\\n\\n        // Node is how ENS identifies names, we need that to setText\\n        bytes32 node = podEnsRegistrar.getEnsNode(_label);\\n        podEnsRegistrar.setText(node, \\\"avatar\\\", _imageUrl);\\n        podEnsRegistrar.setText(node, \\\"podId\\\", Strings.toString(podId));\\n    }\\n\\n    /**\\n     * @dev Allows admin to unlock the safe modules and allow them to be edited by members\\n     * @param _podId The id number of the pod\\n     * @param _isLocked true - pod modules cannot be added/removed\\n     */\\n    function setPodModuleLock(uint256 _podId, bool _isLocked)\\n        external\\n        override\\n    {\\n        require(\\n            msg.sender == podAdmin[_podId],\\n            \\\"Must be admin to set module lock\\\"\\n        );\\n        setModuleLock(podIdToSafe[_podId], _isLocked);\\n    }\\n\\n    /**\\n     * @param _podId The id number of the pod\\n     * @param _newAdmin The address of the new pod admin\\n     */\\n    function updatePodAdmin(uint256 _podId, address _newAdmin)\\n        external\\n        override\\n    {\\n        address admin = podAdmin[_podId];\\n        address safe = podIdToSafe[_podId];\\n\\n        require(safe != address(0), \\\"Pod doesn't exist\\\");\\n\\n        // if there is no admin it can only be added by safe\\n        if (admin == address(0)) {\\n            require(msg.sender == safe, \\\"Only safe can add new admin\\\");\\n        } else {\\n            require(msg.sender == admin, \\\"Only admin can update admin\\\");\\n        }\\n        // set module lock to true for non zero _newAdmin\\n        setModuleLock(safe, _newAdmin != address(0));\\n\\n        podAdmin[_podId] = _newAdmin;\\n\\n        emit UpdatePodAdmin(_podId, _newAdmin);\\n    }\\n\\n    /**\\n     * @param _podId The id number of the pod\\n     * @param _isTransferLocked The address of the new pod admin\\n     */\\n    function setPodTransferLock(uint256 _podId, bool _isTransferLocked)\\n        external\\n        override\\n    {\\n        address admin = podAdmin[_podId];\\n        address safe = podIdToSafe[_podId];\\n\\n        // if no pod admin it can only be set by safe\\n        if (admin == address(0)) {\\n            require(msg.sender == safe, \\\"Only safe can set transfer lock\\\");\\n        } else {\\n            // if admin then it can be set by admin or safe\\n            require(\\n                msg.sender == admin || msg.sender == safe,\\n                \\\"Only admin or safe can set transfer lock\\\"\\n            );\\n        }\\n\\n        // set podid to transfer lock bool\\n        isTransferLocked[_podId] = _isTransferLocked;\\n    }\\n\\n    /**\\n     * @dev This will nullify all pod state on this controller\\n     * @dev Update state on _newController\\n     * @dev Update controller to _newController in Safe and MemberToken\\n     * @param _podId The id number of the pod\\n     * @param _newController The address of the new pod controller\\n     * @param _prevModule The module that points to the orca module in the safe's ModuleManager linked list\\n     */\\n    function migratePodController(\\n        uint256 _podId,\\n        address _newController,\\n        address _prevModule\\n    ) external override {\\n        require(_newController != address(0), \\\"Invalid address\\\");\\n        require(\\n            _newController != address(this),\\n            \\\"Cannot migrate to same controller\\\"\\n        );\\n        require(\\n            controllerRegistry.isRegistered(_newController),\\n            \\\"Controller not registered\\\"\\n        );\\n\\n        address admin = podAdmin[_podId];\\n        address safe = podIdToSafe[_podId];\\n\\n        require(\\n            msg.sender == admin || msg.sender == safe,\\n            \\\"User not authorized\\\"\\n        );\\n\\n        IControllerBase newController = IControllerBase(_newController);\\n\\n        // nullify current pod state\\n        podAdmin[_podId] = address(0);\\n        podIdToSafe[_podId] = address(0);\\n        safeToPodId[safe] = 0;\\n        // update controller in MemberToken\\n        memberToken.migrateMemberController(_podId, _newController);\\n        // update safe module to _newController\\n        migrateSafeTeller(safe, _newController, _prevModule);\\n        // update pod state in _newController\\n        newController.updatePodState(_podId, admin, safe);\\n    }\\n\\n    /**\\n     * @dev This is called by another version of controller to migrate a pod to this version\\n     * @dev Will only accept calls from registered controllers\\n     * @dev Can only be called once.\\n     * @param _podId The id number of the pod\\n     * @param _podAdmin The address of the pod admin\\n     * @param _safeAddress The address of the safe\\n     */\\n    function updatePodState(\\n        uint256 _podId,\\n        address _podAdmin,\\n        address _safeAddress\\n    ) external override {\\n        require(_safeAddress != address(0), \\\"Invalid address\\\");\\n        require(\\n            controllerRegistry.isRegistered(msg.sender),\\n            \\\"Controller not registered\\\"\\n        );\\n        require(\\n            podAdmin[_podId] == address(0) &&\\n                podIdToSafe[_podId] == address(0) &&\\n                safeToPodId[_safeAddress] == 0,\\n            \\\"Pod already exists\\\"\\n        );\\n        // if there is a pod admin, set state and lock modules\\n        if (_podAdmin != address(0)) {\\n            podAdmin[_podId] = _podAdmin;\\n            setModuleLock(_safeAddress, true);\\n        }\\n        podIdToSafe[_podId] = _safeAddress;\\n        safeToPodId[_safeAddress] = _podId;\\n\\n        // add controller as guard\\n        setSafeGuard(_safeAddress, address(this));\\n\\n        emit UpdatePodAdmin(_podId, _podAdmin);\\n    }\\n\\n    /**\\n     * Ejects a safe from the Orca ecosystem. Also handles clean up for safes\\n     * that have already been ejected.\\n     * Note that the reverse registry entry cannot be cleaned up if the safe has already been ejected.\\n     * @param podId - ID of pod being ejected\\n     * @param label - labelhash of pod ENS name, i.e., `labelhash(\\\"mypod\\\")`\\n     * @param previousModule - previous module\\n     */\\n    function ejectSafe(\\n        uint256 podId,\\n        bytes32 label,\\n        address previousModule\\n    ) external override {\\n        address safe = podIdToSafe[podId];\\n        address admin = podAdmin[podId];\\n\\n        require(safe != address(0), \\\"pod not registered\\\");\\n\\n        if (admin != address(0)) {\\n            require(msg.sender == admin, \\\"must be admin\\\");\\n            setModuleLock(safe, false);\\n        } else {\\n            require(msg.sender == safe, \\\"tx must be sent from safe\\\");\\n        }\\n\\n        Resolver resolver = Resolver(podEnsRegistrar.resolver());\\n        bytes32 node = podEnsRegistrar.getEnsNode(label);\\n        address addr = resolver.addr(node);\\n        require(addr == safe, \\\"safe and label didn't match\\\");\\n        podEnsRegistrar.setText(node, \\\"avatar\\\", \\\"\\\");\\n        podEnsRegistrar.setText(node, \\\"podId\\\", \\\"\\\");\\n        podEnsRegistrar.setAddr(node, address(0));\\n        podEnsRegistrar.register(label, address(0));\\n\\n        // if module is already disabled, the safe must unset these manually\\n        if (isSafeModuleEnabled(safe)) {\\n            // remove controller as guard\\n            setSafeGuard(safe, address(0));\\n            // remove module and handle reverse registration clearing.\\n            disableModule(\\n                safe,\\n                podEnsRegistrar.reverseRegistrar(),\\n                previousModule\\n            );\\n        }\\n\\n        // This needs to happen before the burn to skip the transfer check.\\n        podAdmin[podId] = address(0);\\n        podIdToSafe[podId] = address(0);\\n        safeToPodId[safe] = 0;\\n\\n        // Burn member tokens\\n        address[] memory members = this.getSafeMembers(safe);\\n        memberToken.burnSingleBatch(members, podId);\\n\\n        emit DeregisterPod(podId);\\n    }\\n\\n    function batchMintAndBurn(\\n        uint256 _podId,\\n        address[] memory _mintMembers,\\n        address[] memory _burnMembers\\n    ) external {\\n        address safe = podIdToSafe[_podId];\\n        require(\\n            msg.sender == safe || msg.sender == podAdmin[_podId],\\n            \\\"not authorized\\\"\\n        );\\n        memberToken.mintSingleBatch(_mintMembers, _podId, bytes(\\\" \\\"));\\n        memberToken.burnSingleBatch(_burnMembers, _podId);\\n    }\\n\\n    /**\\n     * @param operator The address that initiated the action\\n     * @param from The address sending the membership token\\n     * @param to The address recieveing the membership token\\n     * @param ids An array of membership token ids to be transfered\\n     * @param data Passes a flag for an initial creation event\\n     */\\n    function beforeTokenTransfer(\\n        address operator,\\n        address from,\\n        address to,\\n        uint256[] memory ids,\\n        uint256[] memory,\\n        bytes memory data\\n    ) external override {\\n        require(msg.sender == address(memberToken), \\\"Not Authorized\\\");\\n\\n        // only recognise data flags from this controller\\n        if (operator == address(this)) {\\n            // if create or sync event than side effects have been pre-handled\\n            if (data.length > 0) {\\n                if (uint8(data[0]) == CREATE_EVENT) return;\\n                if (uint8(data[0]) == SYNC_EVENT) return;\\n            }\\n            // because 1155 burn doesn't allow data we use a burn sync flag to skip side effects\\n            if (BURN_SYNC_FLAG == true) {\\n                setBurnSyncFlag(false);\\n                return;\\n            }\\n        }\\n\\n        for (uint256 i = 0; i < ids.length; i += 1) {\\n            uint256 podId = ids[i];\\n            address safe = podIdToSafe[podId];\\n            address admin = podAdmin[podId];\\n\\n            // If safe is 0'd, it means we're deregistering the pod, so we can skip check\\n            if (safe == address(0) && to == address(0)) return;\\n\\n            if (from == address(0)) {\\n                // mint event\\n\\n                // there are no rules operator must be admin, safe or controller\\n                require(\\n                    operator == safe ||\\n                        operator == admin ||\\n                        operator == address(this),\\n                    \\\"No Rules Set\\\"\\n                );\\n\\n                onMint(to, safe);\\n            } else if (to == address(0)) {\\n                // burn event\\n\\n                // there are no rules  operator must be admin, safe or controller\\n                require(\\n                    operator == safe ||\\n                        operator == admin ||\\n                        operator == address(this),\\n                    \\\"No Rules Set\\\"\\n                );\\n\\n                onBurn(from, safe);\\n            } else {\\n                // pod cannot be locked\\n                require(\\n                    isTransferLocked[podId] == false,\\n                    \\\"Pod Is Transfer Locked\\\"\\n                );\\n                // transfer event\\n                onTransfer(from, to, safe);\\n            }\\n        }\\n    }\\n\\n    /**\\n     * @dev This will be called by the safe at execution time time\\n     * _param to Destination address of Safe transaction.\\n     * _param value Ether value of Safe transaction.\\n     * @param data Data payload of Safe transaction.\\n     * _param operation Operation type of Safe transaction.\\n     * _param safeTxGas Gas that should be used for the Safe transaction.\\n     * _param baseGas Gas costs that are independent of the transaction execution(e.g. base transaction fee, signature check, payment of the refund)\\n     * _param gasPrice Gas price that should be used for the payment calculation.\\n     * _param gasToken Token address (or 0 if ETH) that is used for the payment.\\n     * _param refundReceiver Address of receiver of gas payment (or 0 if tx.origin).\\n     * _param signatures Packed signature data ({bytes32 r}{bytes32 s}{uint8 v})\\n     * _param msgSender Account executing safe transaction\\n     */\\n    function checkTransaction(\\n        address,\\n        uint256,\\n        bytes memory data,\\n        Enum.Operation,\\n        uint256,\\n        uint256,\\n        uint256,\\n        address,\\n        address payable,\\n        bytes memory,\\n        address\\n    ) external override {\\n        uint256 podId = safeToPodId[msg.sender];\\n\\n        if (podId == 0) {\\n            address safe = podIdToSafe[podId];\\n            // if safe is 0 its deregistered and we can skip check to allow cleanup\\n            if (safe == address(0)) return;\\n            // else require podId zero is calling from safe\\n            require(safe == msg.sender, \\\"Not Authorized\\\");\\n        }\\n\\n        if (data.length >= 4) {\\n            // if safe modules are locked perform safe check\\n            if (areModulesLocked[msg.sender]) {\\n                safeTellerCheck(data);\\n            }\\n            memberTellerCheck(podId, data);\\n        }\\n    }\\n\\n    function checkAfterExecution(bytes32, bool) external pure override {\\n        return;\\n    }\\n}\\n\",\"keccak256\":\"0xf99476a2c750b30fb88448cdfb159ee0c704db57580bc4db89eed34c93c1c96d\"},\"contracts/MemberTeller.sol\":{\"content\":\"pragma solidity ^0.8.7;\\nimport \\\"./interfaces/IMemberToken.sol\\\";\\n\\ncontract MemberTeller {\\n    IMemberToken public immutable memberToken;\\n\\n    bytes4 public constant ENCODED_SIG_ADD_OWNER =\\n        bytes4(keccak256(\\\"addOwnerWithThreshold(address,uint256)\\\"));\\n    bytes4 public constant ENCODED_SIG_REMOVE_OWNER =\\n        bytes4(keccak256(\\\"removeOwner(address,address,uint256)\\\"));\\n    bytes4 public constant ENCODED_SIG_SWAP_OWNER =\\n        bytes4(keccak256(\\\"swapOwner(address,address,address)\\\"));\\n\\n    uint8 internal constant SYNC_EVENT = 0x02;\\n\\n    constructor(address _memberToken) {\\n        memberToken = IMemberToken(_memberToken);\\n    }\\n\\n    function getSyncData() internal pure returns (bytes memory) {\\n        bytes memory data = new bytes(1);\\n        data[0] = bytes1(uint8(SYNC_EVENT));\\n        return data;\\n    }\\n\\n    // we use burn sync flag to let the controller know to skip side effects\\n    // controller will reset flag in beforeTokenTransfer\\n    bool internal BURN_SYNC_FLAG = false;\\n\\n    function setBurnSyncFlag(bool flag) internal {\\n        BURN_SYNC_FLAG = flag;\\n    }\\n\\n    function memberTellerCheck(uint256 podId, bytes memory data) internal {\\n        if (bytes4(data) == ENCODED_SIG_ADD_OWNER) {\\n            address mintMember;\\n            assembly {\\n                // shift 0x4 for the sig + 0x20 padding\\n                mintMember := mload(add(data, 0x24))\\n            }\\n            memberToken.mint(mintMember, podId, getSyncData());\\n        }\\n        if (bytes4(data) == ENCODED_SIG_REMOVE_OWNER) {\\n            address burnMember;\\n            assembly {\\n                // note: consecutive addresses are packed into a single memory slot\\n                // shift 0x4 for the sig, 0x40 for prev address and padding\\n                burnMember := mload(add(data, 0x44))\\n            }\\n            setBurnSyncFlag(true);\\n            memberToken.burn(burnMember, podId);\\n        }\\n        if (bytes4(data) == ENCODED_SIG_SWAP_OWNER) {\\n            address burnMember;\\n            address mintMember;\\n            assembly {\\n                // note: consecutive addresses are packed into a single memory slot\\n                // shift 0x4 for the sig + 0x40 for prev address and padding\\n                burnMember := mload(add(data, 0x44))\\n                // shift 0x4 for the sig + 0x40 for prev address and padding + 0x20 for the new address\\n                mintMember := mload(add(data, 0x64))\\n            }\\n            memberToken.mint(mintMember, podId, getSyncData());\\n            setBurnSyncFlag(true);\\n            memberToken.burn(burnMember, podId);\\n        }\\n    }\\n}\\n\",\"keccak256\":\"0x92b5593d7dd120b62bfd4887bf79a23f86b7c06660d9084e4f5b5e15fee0d318\"},\"contracts/SafeTeller.sol\":{\"content\":\"pragma solidity ^0.8.7;\\n\\nimport \\\"lib/openzeppelin-contracts/contracts/utils/Address.sol\\\";\\nimport \\\"./interfaces/IGnosisSafe.sol\\\";\\nimport \\\"./interfaces/IGnosisSafeProxyFactory.sol\\\";\\n\\ncontract SafeTeller {\\n    using Address for address;\\n\\n    // mainnet: 0x76E2cFc1F5Fa8F6a5b3fC4c8F4788F0116861F9B;\\n    address public immutable proxyFactoryAddress;\\n\\n    // mainnet: 0x34CfAC646f301356fAa8B21e94227e3583Fe3F5F;\\n    address public immutable gnosisMasterAddress;\\n    address public immutable fallbackHandlerAddress;\\n\\n    string public constant FUNCTION_SIG_SETUP =\\n        \\\"setup(address[],uint256,address,bytes,address,address,uint256,address)\\\";\\n    string public constant FUNCTION_SIG_EXEC =\\n        \\\"execTransaction(address,uint256,bytes,uint8,uint256,uint256,uint256,address,address,bytes)\\\";\\n\\n    string public constant FUNCTION_SIG_ENABLE = \\\"delegateSetup(address)\\\";\\n\\n    bytes4 public constant ENCODED_SIG_ENABLE_MOD =\\n        bytes4(keccak256(\\\"enableModule(address)\\\"));\\n    bytes4 public constant ENCODED_SIG_DISABLE_MOD =\\n        bytes4(keccak256(\\\"disableModule(address,address)\\\"));\\n    bytes4 public constant ENCODED_SIG_SET_GUARD =\\n        bytes4(keccak256(\\\"setGuard(address)\\\"));\\n\\n    address internal constant SENTINEL = address(0x1);\\n\\n    // pods with admin have modules locked by default\\n    mapping(address => bool) public areModulesLocked;\\n\\n    /**\\n     * @param _proxyFactoryAddress The proxy factory address\\n     * @param _gnosisMasterAddress The gnosis master address\\n     */\\n    constructor(\\n        address _proxyFactoryAddress,\\n        address _gnosisMasterAddress,\\n        address _fallbackHanderAddress\\n    ) {\\n        proxyFactoryAddress = _proxyFactoryAddress;\\n        gnosisMasterAddress = _gnosisMasterAddress;\\n        fallbackHandlerAddress = _fallbackHanderAddress;\\n    }\\n\\n    /**\\n     * @param _safe The address of the safe\\n     * @param _newSafeTeller The address of the new safe teller contract\\n     */\\n    function migrateSafeTeller(\\n        address _safe,\\n        address _newSafeTeller,\\n        address _prevModule\\n    ) internal {\\n        // add new safeTeller\\n        bytes memory enableData = abi.encodeWithSignature(\\n            \\\"enableModule(address)\\\",\\n            _newSafeTeller\\n        );\\n\\n        bool enableSuccess = IGnosisSafe(_safe).execTransactionFromModule(\\n            _safe,\\n            0,\\n            enableData,\\n            IGnosisSafe.Operation.Call\\n        );\\n        require(enableSuccess, \\\"Migration failed on enable\\\");\\n\\n        // validate prevModule of current safe teller\\n        (address[] memory moduleBuffer, ) = IGnosisSafe(_safe)\\n            .getModulesPaginated(_prevModule, 1);\\n        require(moduleBuffer[0] == address(this), \\\"incorrect prevModule\\\");\\n\\n        // disable current safeTeller\\n        bytes memory disableData = abi.encodeWithSignature(\\n            \\\"disableModule(address,address)\\\",\\n            _prevModule,\\n            address(this)\\n        );\\n\\n        bool disableSuccess = IGnosisSafe(_safe).execTransactionFromModule(\\n            _safe,\\n            0,\\n            disableData,\\n            IGnosisSafe.Operation.Call\\n        );\\n        require(disableSuccess, \\\"Migration failed on disable\\\");\\n    }\\n\\n    /**\\n     * @dev sets the safeteller as safe guard, called after migration\\n     * @param _safe The address of the safe\\n     */\\n    function setSafeGuard(address _safe, address guard) internal {\\n        bytes memory transferData = abi.encodeWithSignature(\\n            \\\"setGuard(address)\\\",\\n            guard\\n        );\\n\\n        bool guardSuccess = IGnosisSafe(_safe).execTransactionFromModule(\\n            _safe,\\n            0,\\n            transferData,\\n            IGnosisSafe.Operation.Call\\n        );\\n        require(guardSuccess, \\\"Could not set guard\\\");\\n    }\\n\\n    function getSafeMembers(address safe)\\n        public\\n        view\\n        returns (address[] memory)\\n    {\\n        return IGnosisSafe(safe).getOwners();\\n    }\\n\\n    function isSafeModuleEnabled(address safe) public view returns (bool) {\\n        return IGnosisSafe(safe).isModuleEnabled(address(this));\\n    }\\n\\n    function isSafeMember(address safe, address member)\\n        public\\n        view\\n        returns (bool)\\n    {\\n        return IGnosisSafe(safe).isOwner(member);\\n    }\\n\\n    /**\\n     * @param _owners The  addresses to be owners of the safe\\n     * @param _threshold The number of owners that are required to sign a transaciton\\n     * @return safeAddress The address of the new safe\\n     */\\n    function createSafe(\\n        address[] memory _owners,\\n        uint256 _threshold,\\n        uint256 _salt\\n    ) internal returns (address safeAddress) {\\n        bytes memory data = abi.encodeWithSignature(\\n            FUNCTION_SIG_ENABLE,\\n            address(this)\\n        );\\n\\n        // encode the setup call that will be called on the new proxy safe\\n        // from the proxy factory\\n        bytes memory setupData = abi.encodeWithSignature(\\n            FUNCTION_SIG_SETUP,\\n            _owners,\\n            _threshold,\\n            this,\\n            data,\\n            fallbackHandlerAddress,\\n            address(0),\\n            uint256(0),\\n            address(0)\\n        );\\n\\n        try\\n            IGnosisSafeProxyFactory(proxyFactoryAddress).createProxyWithNonce(\\n                gnosisMasterAddress,\\n                setupData,\\n                _salt\\n            )\\n        returns (address newSafeAddress) {\\n            return newSafeAddress;\\n        } catch (bytes memory) {\\n            revert(\\\"Create Proxy With Data Failed\\\");\\n        }\\n    }\\n\\n    /**\\n     * Uses CREATE2 to replicate a given safe on a new network.\\n     * @param members The addresses of the members of the pod as it was originally created.\\n     * @param threshold The number of members that are required to sign a transaction\\n     * @param podId - Pod ID of safe you are trying to recreate\\n     */\\n    function recoverSafe(\\n        address[] calldata members,\\n        uint256 threshold,\\n        uint256 podId\\n    ) external returns (address) {\\n        return createSafe(members, threshold, podId);\\n    }\\n\\n    /**\\n     * @param to The account address to add as an owner\\n     * @param safe The address of the safe\\n     */\\n    function onMint(address to, address safe) internal {\\n        uint256 threshold = IGnosisSafe(safe).getThreshold();\\n\\n        bytes memory data = abi.encodeWithSignature(\\n            \\\"addOwnerWithThreshold(address,uint256)\\\",\\n            to,\\n            threshold\\n        );\\n\\n        bool success = IGnosisSafe(safe).execTransactionFromModule(\\n            safe,\\n            0,\\n            data,\\n            IGnosisSafe.Operation.Call\\n        );\\n\\n        require(success, \\\"Module Transaction Failed\\\");\\n    }\\n\\n    /**\\n     * @param from The address to be removed as an owner\\n     * @param safe The address of the safe\\n     */\\n    function onBurn(address from, address safe) internal {\\n        uint256 threshold = IGnosisSafe(safe).getThreshold();\\n        address[] memory owners = IGnosisSafe(safe).getOwners();\\n\\n        //look for the address pointing to address from\\n        address prevFrom = address(0);\\n        for (uint256 i = 0; i < owners.length; i++) {\\n            if (owners[i] == from) {\\n                if (i == 0) {\\n                    prevFrom = SENTINEL;\\n                } else {\\n                    prevFrom = owners[i - 1];\\n                }\\n            }\\n        }\\n        if (owners.length - 1 < threshold) threshold -= 1;\\n        bytes memory data = abi.encodeWithSignature(\\n            \\\"removeOwner(address,address,uint256)\\\",\\n            prevFrom,\\n            from,\\n            threshold\\n        );\\n\\n        bool success = IGnosisSafe(safe).execTransactionFromModule(\\n            safe,\\n            0,\\n            data,\\n            IGnosisSafe.Operation.Call\\n        );\\n        require(success, \\\"Module Transaction Failed\\\");\\n    }\\n\\n    /**\\n     * @param from The address being removed as an owner\\n     * @param to The address being added as an owner\\n     * @param safe The address of the safe\\n     */\\n    function onTransfer(\\n        address from,\\n        address to,\\n        address safe\\n    ) internal {\\n        address[] memory owners = IGnosisSafe(safe).getOwners();\\n\\n        //look for the address pointing to address from\\n        address prevFrom;\\n        for (uint256 i = 0; i < owners.length; i++) {\\n            if (owners[i] == from) {\\n                if (i == 0) {\\n                    prevFrom = SENTINEL;\\n                } else {\\n                    prevFrom = owners[i - 1];\\n                }\\n            }\\n        }\\n\\n        bytes memory data = abi.encodeWithSignature(\\n            \\\"swapOwner(address,address,address)\\\",\\n            prevFrom,\\n            from,\\n            to\\n        );\\n\\n        bool success = IGnosisSafe(safe).execTransactionFromModule(\\n            safe,\\n            0,\\n            data,\\n            IGnosisSafe.Operation.Call\\n        );\\n        require(success, \\\"Module Transaction Failed\\\");\\n    }\\n\\n    /**\\n     * @dev This will execute a tx from the safe that will update the safe's ENS in the reverse resolver\\n     * @param safe safe address\\n     * @param reverseRegistrar The ENS default reverseRegistar\\n     * @param _ensString string of pod ens name (i.e.'mypod.pod.xyz')\\n     */\\n    function setupSafeReverseResolver(\\n        address safe,\\n        address reverseRegistrar,\\n        string memory _ensString\\n    ) internal virtual {\\n        bytes memory data = abi.encodeWithSignature(\\n            \\\"setName(string)\\\",\\n            _ensString\\n        );\\n\\n        bool success = IGnosisSafe(safe).execTransactionFromModule(\\n            reverseRegistrar,\\n            0,\\n            data,\\n            IGnosisSafe.Operation.Call\\n        );\\n        require(success, \\\"Module Transaction Failed\\\");\\n    }\\n\\n    /**\\n     * @dev This will be called by the safe at tx time and prevent module disable on pods with admins\\n     * @param safe safe address\\n     * @param isLocked safe address\\n     */\\n    function setModuleLock(address safe, bool isLocked) internal {\\n        areModulesLocked[safe] = isLocked;\\n    }\\n\\n    function safeTellerCheck(bytes memory data) internal pure {\\n        require(\\n            bytes4(data) != ENCODED_SIG_ENABLE_MOD,\\n            \\\"Cannot Enable Modules\\\"\\n        );\\n        require(\\n            bytes4(data) != ENCODED_SIG_DISABLE_MOD,\\n            \\\"Cannot Disable Modules\\\"\\n        );\\n        require(bytes4(data) != ENCODED_SIG_SET_GUARD, \\\"Cannot Change Guard\\\");\\n    }\\n\\n    /**\\n     * Removes the reverse registrar entry and disables module.\\n     * Intended as clean up during the safe ejection process.\\n     * Note that an already ejected safe cannot clear the reverse registry entry.\\n     */\\n    function disableModule(\\n        address safe,\\n        address reverseRegistrar,\\n        address previousModule\\n    ) internal {\\n        IGnosisSafe safeContract = IGnosisSafe(safe);\\n\\n        // Note that you cannot clear the reverse registry entry of an already ejected safe.\\n        bytes memory nameData = abi.encodeWithSignature(\\\"setName(string)\\\", \\\"\\\");\\n        safeContract.execTransactionFromModule(\\n            reverseRegistrar,\\n            0,\\n            nameData,\\n            IGnosisSafe.Operation.Call\\n        );\\n\\n        // remove controller as guard\\n        bytes memory guardData = abi.encodeWithSignature(\\n            \\\"setGuard(address)\\\",\\n            address(0)\\n        );\\n\\n        safeContract.execTransactionFromModule(\\n            safe,\\n            0,\\n            guardData,\\n            IGnosisSafe.Operation.Call\\n        );\\n\\n        // disable module\\n        bytes memory moduleData = abi.encodeWithSignature(\\n            \\\"disableModule(address,address)\\\",\\n            previousModule,\\n            address(this)\\n        );\\n\\n        safeContract.execTransactionFromModule(\\n            safe,\\n            0,\\n            moduleData,\\n            IGnosisSafe.Operation.Call\\n        );\\n    }\\n\\n    // TODO: move to library\\n    // Used in a delegate call to enable module add on setup\\n    function enableModule(address module) external {\\n        require(module == address(0));\\n    }\\n\\n    function delegateSetup(address _context) external {\\n        this.enableModule(_context);\\n    }\\n}\\n\",\"keccak256\":\"0x058905dfbdc57601c6c8b49439dc81675488b6304f15141c47b887458abc2fd7\"},\"contracts/ens/IPodEnsRegistrar.sol\":{\"content\":\"pragma solidity ^0.8.7;\\n\\ninterface IPodEnsRegistrar {\\n    function ens() external view returns (address);\\n\\n    function resolver() external view returns (address);\\n\\n    function reverseRegistrar() external view returns (address);\\n\\n    function getRootNode() external view returns (bytes32);\\n\\n    function registerPod(\\n        bytes32 label,\\n        address podSafe,\\n        address podCreator\\n    ) external returns (address);\\n\\n    function register(bytes32 label, address owner) external;\\n\\n    function deregister(address safe, bytes32 label) external;\\n\\n    function setText(\\n        bytes32 node,\\n        string calldata key,\\n        string calldata value\\n    ) external;\\n\\n    function setAddr(bytes32 node, address newAddress) external;\\n\\n    function addressToNode(address input) external returns (bytes32);\\n\\n    function getEnsNode(bytes32 label) external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x74e485a9d6508af2c8b8141c10adf6224b0edc8a78671584b222d18da40a70f9\"},\"contracts/interfaces/IControllerBase.sol\":{\"content\":\"pragma solidity ^0.8.7;\\n\\ninterface IControllerBase {\\n    /**\\n     * @param operator The account address that initiated the action\\n     * @param from The account address sending the membership token\\n     * @param to The account address recieving the membership token\\n     * @param ids An array of membership token ids to be transfered\\n     * @param amounts The amount of each membership token type to transfer\\n     * @param data Arbitrary data\\n     */\\n    function beforeTokenTransfer(\\n        address operator,\\n        address from,\\n        address to,\\n        uint256[] memory ids,\\n        uint256[] memory amounts,\\n        bytes memory data\\n    ) external;\\n\\n    function updatePodState(\\n        uint256 _podId,\\n        address _podAdmin,\\n        address _safeAddress\\n    ) external;\\n}\\n\",\"keccak256\":\"0xe5742d76ed6922a5d1cae269adf46b2da542bbe54d34bb62af77d81f9ce512e0\"},\"contracts/interfaces/IControllerRegistry.sol\":{\"content\":\"pragma solidity ^0.8.7;\\n\\n\\ninterface IControllerRegistry{\\n\\n    /**\\n     * @param _controller Address to check if registered as a controller\\n     * @return Boolean representing if the address is a registered as a controller\\n     */\\n    function isRegistered(address _controller) external view returns (bool);\\n\\n}\\n\",\"keccak256\":\"0x040c34638ad2095660cb546d9821c52ac020372fedc9067ffc59e47fc3523924\"},\"contracts/interfaces/IControllerV1.sol\":{\"content\":\"pragma solidity ^0.8.7;\\n\\nimport \\\"./IControllerBase.sol\\\";\\n\\ninterface IControllerV1 is IControllerBase {\\n    function updatePodEnsRegistrar(address _podEnsRegistrar) external;\\n\\n    /**\\n     * @param _members The addresses of the members of the pod\\n     * @param threshold The number of members that are required to sign a transaction\\n     * @param _admin The address of the pod admin\\n     * @param _label label hash of pod name (i.e labelhash('mypod'))\\n     * @param _ensString string of pod ens name (i.e.'mypod.pod.xyz')\\n     */\\n    function createPod(\\n        address[] memory _members,\\n        uint256 threshold,\\n        address _admin,\\n        bytes32 _label,\\n        string memory _ensString,\\n        uint256 expectedPodId,\\n        string memory _imageUrl\\n    ) external;\\n\\n    /**\\n     * @dev Used to create a pod with an existing safe\\n     * @dev Will automatically distribute membership NFTs to current safe members\\n     * @param _admin The address of the pod admin\\n     * @param _safe The address of existing safe\\n     * @param _label label hash of pod name (i.e labelhash('mypod'))\\n     * @param _ensString string of pod ens name (i.e.'mypod.pod.xyz')\\n     */\\n    function createPodWithSafe(\\n        address _admin,\\n        address _safe,\\n        bytes32 _label,\\n        string memory _ensString,\\n        uint256 expectedPodId,\\n        string memory _imageUrl\\n    ) external;\\n\\n    function podIdToSafe(uint256 _podId) external view returns (address);\\n\\n    /**\\n     * @dev Allows admin to unlock the safe modules and allow them to be edited by members\\n     * @param _podId The id number of the pod\\n     * @param _isLocked true - pod modules cannot be added/removed\\n     */\\n    function setPodModuleLock(uint256 _podId, bool _isLocked) external;\\n\\n    /**\\n     * @param _podId The id number of the pod\\n     * @param _isTransferLocked The address of the new pod admin\\n     */\\n    function setPodTransferLock(uint256 _podId, bool _isTransferLocked)\\n        external;\\n\\n    /**\\n     * @param _podId The id number of the pod\\n     * @param _newAdmin The address of the new pod admin\\n     */\\n    function updatePodAdmin(uint256 _podId, address _newAdmin) external;\\n\\n    /**\\n     * @dev This will nullify all pod state on this controller\\n     * @dev Update state on _newController\\n     * @dev Update controller to _newController in Safe and MemberToken\\n     * @param _podId The id number of the pod\\n     * @param _newController The address of the new pod controller\\n     * @param _prevModule The module that points to the orca module in the safe's ModuleManager linked list\\n     */\\n    function migratePodController(\\n        uint256 _podId,\\n        address _newController,\\n        address _prevModule\\n    ) external;\\n\\n    function ejectSafe(\\n        uint256 podId,\\n        bytes32 label,\\n        address previousModule\\n    ) external;\\n}\\n\",\"keccak256\":\"0x04a6cd222810362108bec320004d9695ecaa8fea81d8df1e301b0d0d2a36a695\"},\"contracts/interfaces/IGnosisSafe.sol\":{\"content\":\"pragma solidity ^0.8.7;\\n\\ninterface IGnosisSafe {\\n    enum Operation {\\n        Call,\\n        DelegateCall\\n    }\\n\\n    /// @dev Allows a Module to execute a Safe transaction without any further confirmations.\\n    /// @param to Destination address of module transaction.\\n    /// @param value Ether value of module transaction.\\n    /// @param data Data payload of module transaction.\\n    /// @param operation Operation type of module transaction.\\n    function execTransactionFromModule(\\n        address to,\\n        uint256 value,\\n        bytes calldata data,\\n        Operation operation\\n    ) external returns (bool success);\\n\\n    /// @dev Returns array of owners.\\n    /// @return Array of Safe owners.\\n    function getOwners() external view returns (address[] memory);\\n\\n    function isOwner(address owner) external view returns (bool);\\n\\n    function getThreshold() external returns (uint256);\\n\\n    /// @dev Returns array of modules.\\n    /// @param start Start of the page.\\n    /// @param pageSize Maximum number of modules that should be returned.\\n    /// @return array Array of modules.\\n    /// @return next Start of the next page.\\n    function getModulesPaginated(address start, uint256 pageSize)\\n        external\\n        view\\n        returns (address[] memory array, address next);\\n\\n    /// @dev Returns if an module is enabled\\n    /// @return True if the module is enabled\\n    function isModuleEnabled(address module) external view returns (bool);\\n\\n    /// @dev Set a guard that checks transactions before execution\\n    /// @param guard The address of the guard to be used or the 0 address to disable the guard\\n    function setGuard(address guard) external;\\n\\n    function disableModule(address prevModule, address module) external;\\n}\\n\",\"keccak256\":\"0x57553ab3f120222c2451bc2740c1e682f575539225c9b4d348d505ae299302d0\"},\"contracts/interfaces/IGnosisSafeProxyFactory.sol\":{\"content\":\"pragma solidity ^0.8.7;\\n\\ninterface IGnosisSafeProxyFactory {\\n    /// @dev Allows to create new proxy contact and execute a message call to the new proxy within one transaction.\\n    /// @param singleton Address of singleton contract.\\n    /// @param data Payload for message call sent to new proxy contract.\\n    function createProxy(address singleton, bytes memory data)\\n        external\\n        returns (address);\\n\\n    function createProxyWithNonce(\\n        address _singleton,\\n        bytes memory initializer,\\n        uint256 saltNonce\\n    ) external returns (address);\\n}\\n\",\"keccak256\":\"0xb79f0b1760238376e9a40dd70c889497b9d9e4a162d1fc405587164a72d47077\"},\"contracts/interfaces/IMemberToken.sol\":{\"content\":\"pragma solidity ^0.8.7;\\n\\nimport \\\"lib/openzeppelin-contracts/contracts/token/ERC1155/IERC1155.sol\\\";\\n\\ninterface IMemberToken is IERC1155 {\\n    /**\\n     * @dev Total amount of tokens in with a given id.\\n     */\\n    function totalSupply(uint256 id) external view returns (uint256);\\n\\n    /**\\n     * @dev Indicates weither any token exist with a given id, or not.\\n     */\\n    function exists(uint256 id) external view returns (bool);\\n\\n    function getNextAvailablePodId() external view returns (uint256);\\n\\n    /**\\n     * @param _podId The pod id number\\n     * @param _newController The address of the new controller\\n     */\\n    function migrateMemberController(uint256 _podId, address _newController)\\n        external;\\n\\n    /**\\n     * @param _account The account address to transfer the membership token to\\n     * @param _id The membership token id to mint\\n     * @param data Arbitrary data\\n     */\\n    function mint(\\n        address _account,\\n        uint256 _id,\\n        bytes memory data\\n    ) external;\\n\\n    /**\\n     * @param _accounts The account addresses to transfer the membership tokens to\\n     * @param _id The membership token id to mint\\n     * @param data Arbitrary data\\n     */\\n    function mintSingleBatch(\\n        address[] memory _accounts,\\n        uint256 _id,\\n        bytes memory data\\n    ) external;\\n\\n    /**\\n     * @param _account The account address holding the membership token to destroy\\n     * @param _id The id of the membership token to destroy\\n     */\\n    function burn(address _account, uint256 _id) external;\\n\\n    function burnSingleBatch(address[] memory _accounts, uint256 _id) external;\\n\\n    function createPod(address[] memory _accounts, bytes memory data)\\n        external\\n        returns (uint256);\\n}\\n\",\"keccak256\":\"0xc84f47034f342b2ed8f777c06d746ce0d287c418bf1ee4c5ab8449de27dffebf\"},\"lib/ens-contracts/contracts/registry/ENS.sol\":{\"content\":\"pragma solidity >=0.8.4;\\n\\ninterface ENS {\\n    // Logged when the owner of a node assigns a new owner to a subnode.\\n    event NewOwner(bytes32 indexed node, bytes32 indexed label, address owner);\\n\\n    // Logged when the owner of a node transfers ownership to a new account.\\n    event Transfer(bytes32 indexed node, address owner);\\n\\n    // Logged when the resolver for a node changes.\\n    event NewResolver(bytes32 indexed node, address resolver);\\n\\n    // Logged when the TTL of a node changes\\n    event NewTTL(bytes32 indexed node, uint64 ttl);\\n\\n    // Logged when an operator is added or removed.\\n    event ApprovalForAll(\\n        address indexed owner,\\n        address indexed operator,\\n        bool approved\\n    );\\n\\n    function setRecord(\\n        bytes32 node,\\n        address owner,\\n        address resolver,\\n        uint64 ttl\\n    ) external;\\n\\n    function setSubnodeRecord(\\n        bytes32 node,\\n        bytes32 label,\\n        address owner,\\n        address resolver,\\n        uint64 ttl\\n    ) external;\\n\\n    function setSubnodeOwner(\\n        bytes32 node,\\n        bytes32 label,\\n        address owner\\n    ) external returns (bytes32);\\n\\n    function setResolver(bytes32 node, address resolver) external;\\n\\n    function setOwner(bytes32 node, address owner) external;\\n\\n    function setTTL(bytes32 node, uint64 ttl) external;\\n\\n    function setApprovalForAll(address operator, bool approved) external;\\n\\n    function owner(bytes32 node) external view returns (address);\\n\\n    function resolver(bytes32 node) external view returns (address);\\n\\n    function ttl(bytes32 node) external view returns (uint64);\\n\\n    function recordExists(bytes32 node) external view returns (bool);\\n\\n    function isApprovedForAll(address owner, address operator)\\n        external\\n        view\\n        returns (bool);\\n}\\n\",\"keccak256\":\"0xf79be82c1a2eb0a77fba4e0972221912e803309081ca460fd2cf61653e55758a\"},\"lib/ens-contracts/contracts/registry/IReverseRegistrar.sol\":{\"content\":\"pragma solidity >=0.8.4;\\n\\ninterface IReverseRegistrar {\\n    function setDefaultResolver(address resolver) external;\\n\\n    function claim(address owner) external returns (bytes32);\\n\\n    function claimForAddr(\\n        address addr,\\n        address owner,\\n        address resolver\\n    ) external returns (bytes32);\\n\\n    function claimWithResolver(address owner, address resolver)\\n        external\\n        returns (bytes32);\\n\\n    function setName(string memory name) external returns (bytes32);\\n\\n    function setNameForAddr(\\n        address addr,\\n        address owner,\\n        address resolver,\\n        string memory name\\n    ) external returns (bytes32);\\n\\n    function node(address addr) external pure returns (bytes32);\\n}\\n\",\"keccak256\":\"0xd6ba83973ffbab31dec17a716af3bb5703844d16dceb5078583fb2c509f8bcc2\"},\"lib/ens-contracts/contracts/registry/ReverseRegistrar.sol\":{\"content\":\"pragma solidity >=0.8.4;\\n\\nimport \\\"./ENS.sol\\\";\\nimport \\\"./IReverseRegistrar.sol\\\";\\nimport \\\"lib/openzeppelin-contracts/contracts/access/Ownable.sol\\\";\\nimport \\\"../root/Controllable.sol\\\";\\n\\nabstract contract NameResolver {\\n    function setName(bytes32 node, string memory name) public virtual;\\n}\\n\\nbytes32 constant lookup = 0x3031323334353637383961626364656600000000000000000000000000000000;\\n\\nbytes32 constant ADDR_REVERSE_NODE = 0x91d1777781884d03a6757a803996e38de2a42967fb37eeaca72729271025a9e2;\\n\\n// namehash('addr.reverse')\\n\\ncontract ReverseRegistrar is Ownable, Controllable, IReverseRegistrar {\\n    ENS public immutable ens;\\n    NameResolver public defaultResolver;\\n\\n    event ReverseClaimed(address indexed addr, bytes32 indexed node);\\n\\n    /**\\n     * @dev Constructor\\n     * @param ensAddr The address of the ENS registry.\\n     */\\n    constructor(ENS ensAddr) {\\n        ens = ensAddr;\\n\\n        // Assign ownership of the reverse record to our deployer\\n        ReverseRegistrar oldRegistrar = ReverseRegistrar(\\n            ensAddr.owner(ADDR_REVERSE_NODE)\\n        );\\n        if (address(oldRegistrar) != address(0x0)) {\\n            oldRegistrar.claim(msg.sender);\\n        }\\n    }\\n\\n    modifier authorised(address addr) {\\n        require(\\n            addr == msg.sender ||\\n                controllers[msg.sender] ||\\n                ens.isApprovedForAll(addr, msg.sender) ||\\n                ownsContract(addr),\\n            \\\"ReverseRegistrar: Caller is not a controller or authorised by address or the address itself\\\"\\n        );\\n        _;\\n    }\\n\\n    function setDefaultResolver(address resolver) public override onlyOwner {\\n        require(\\n            address(resolver) != address(0),\\n            \\\"ReverseRegistrar: Resolver address must not be 0\\\"\\n        );\\n        defaultResolver = NameResolver(resolver);\\n    }\\n\\n    /**\\n     * @dev Transfers ownership of the reverse ENS record associated with the\\n     *      calling account.\\n     * @param owner The address to set as the owner of the reverse record in ENS.\\n     * @return The ENS node hash of the reverse record.\\n     */\\n    function claim(address owner) public override returns (bytes32) {\\n        return claimForAddr(msg.sender, owner, address(defaultResolver));\\n    }\\n\\n    /**\\n     * @dev Transfers ownership of the reverse ENS record associated with the\\n     *      calling account.\\n     * @param addr The reverse record to set\\n     * @param owner The address to set as the owner of the reverse record in ENS.\\n     * @return The ENS node hash of the reverse record.\\n     */\\n    function claimForAddr(\\n        address addr,\\n        address owner,\\n        address resolver\\n    ) public override authorised(addr) returns (bytes32) {\\n        bytes32 labelHash = sha3HexAddress(addr);\\n        bytes32 reverseNode = keccak256(\\n            abi.encodePacked(ADDR_REVERSE_NODE, labelHash)\\n        );\\n        emit ReverseClaimed(addr, reverseNode);\\n        ens.setSubnodeRecord(ADDR_REVERSE_NODE, labelHash, owner, resolver, 0);\\n        return reverseNode;\\n    }\\n\\n    /**\\n     * @dev Transfers ownership of the reverse ENS record associated with the\\n     *      calling account.\\n     * @param owner The address to set as the owner of the reverse record in ENS.\\n     * @param resolver The address of the resolver to set; 0 to leave unchanged.\\n     * @return The ENS node hash of the reverse record.\\n     */\\n    function claimWithResolver(address owner, address resolver)\\n        public\\n        override\\n        returns (bytes32)\\n    {\\n        return claimForAddr(msg.sender, owner, resolver);\\n    }\\n\\n    /**\\n     * @dev Sets the `name()` record for the reverse ENS record associated with\\n     * the calling account. First updates the resolver to the default reverse\\n     * resolver if necessary.\\n     * @param name The name to set for this address.\\n     * @return The ENS node hash of the reverse record.\\n     */\\n    function setName(string memory name) public override returns (bytes32) {\\n        return\\n            setNameForAddr(\\n                msg.sender,\\n                msg.sender,\\n                address(defaultResolver),\\n                name\\n            );\\n    }\\n\\n    /**\\n     * @dev Sets the `name()` record for the reverse ENS record associated with\\n     * the account provided. First updates the resolver to the default reverse\\n     * resolver if necessary.\\n     * Only callable by controllers and authorised users\\n     * @param addr The reverse record to set\\n     * @param owner The owner of the reverse node\\n     * @param name The name to set for this address.\\n     * @return The ENS node hash of the reverse record.\\n     */\\n    function setNameForAddr(\\n        address addr,\\n        address owner,\\n        address resolver,\\n        string memory name\\n    ) public override returns (bytes32) {\\n        bytes32 node = claimForAddr(addr, owner, resolver);\\n        NameResolver(resolver).setName(node, name);\\n        return node;\\n    }\\n\\n    /**\\n     * @dev Returns the node hash for a given account's reverse records.\\n     * @param addr The address to hash\\n     * @return The ENS node hash.\\n     */\\n    function node(address addr) public pure override returns (bytes32) {\\n        return\\n            keccak256(\\n                abi.encodePacked(ADDR_REVERSE_NODE, sha3HexAddress(addr))\\n            );\\n    }\\n\\n    /**\\n     * @dev An optimised function to compute the sha3 of the lower-case\\n     *      hexadecimal representation of an Ethereum address.\\n     * @param addr The address to hash\\n     * @return ret The SHA3 hash of the lower-case hexadecimal encoding of the\\n     *         input address.\\n     */\\n    function sha3HexAddress(address addr) private pure returns (bytes32 ret) {\\n        assembly {\\n            for {\\n                let i := 40\\n            } gt(i, 0) {\\n\\n            } {\\n                i := sub(i, 1)\\n                mstore8(i, byte(and(addr, 0xf), lookup))\\n                addr := div(addr, 0x10)\\n                i := sub(i, 1)\\n                mstore8(i, byte(and(addr, 0xf), lookup))\\n                addr := div(addr, 0x10)\\n            }\\n\\n            ret := keccak256(0, 40)\\n        }\\n    }\\n\\n    function ownsContract(address addr) internal view returns (bool) {\\n        try Ownable(addr).owner() returns (address owner) {\\n            return owner == msg.sender;\\n        } catch {\\n            return false;\\n        }\\n    }\\n}\\n\",\"keccak256\":\"0xee1b81673ada526eac74312ba72bbde6140e07b49434e800e3fb1110eeb8a7d4\"},\"lib/ens-contracts/contracts/resolvers/Resolver.sol\":{\"content\":\"//SPDX-License-Identifier: MIT\\npragma solidity >=0.8.4;\\n\\nimport \\\"lib/openzeppelin-contracts/contracts/utils/introspection/IERC165.sol\\\";\\nimport \\\"./profiles/IABIResolver.sol\\\";\\nimport \\\"./profiles/IAddressResolver.sol\\\";\\nimport \\\"./profiles/IAddrResolver.sol\\\";\\nimport \\\"./profiles/IContentHashResolver.sol\\\";\\nimport \\\"./profiles/IDNSRecordResolver.sol\\\";\\nimport \\\"./profiles/IDNSZoneResolver.sol\\\";\\nimport \\\"./profiles/IInterfaceResolver.sol\\\";\\nimport \\\"./profiles/INameResolver.sol\\\";\\nimport \\\"./profiles/IPubkeyResolver.sol\\\";\\nimport \\\"./profiles/ITextResolver.sol\\\";\\nimport \\\"./profiles/IExtendedResolver.sol\\\";\\n\\n/**\\n * A generic resolver interface which includes all the functions including the ones deprecated\\n */\\ninterface Resolver is\\n    IERC165,\\n    IABIResolver,\\n    IAddressResolver,\\n    IAddrResolver,\\n    IContentHashResolver,\\n    IDNSRecordResolver,\\n    IDNSZoneResolver,\\n    IInterfaceResolver,\\n    INameResolver,\\n    IPubkeyResolver,\\n    ITextResolver,\\n    IExtendedResolver\\n{\\n    /* Deprecated events */\\n    event ContentChanged(bytes32 indexed node, bytes32 hash);\\n\\n    function setABI(\\n        bytes32 node,\\n        uint256 contentType,\\n        bytes calldata data\\n    ) external;\\n\\n    function setAddr(bytes32 node, address addr) external;\\n\\n    function setAddr(\\n        bytes32 node,\\n        uint256 coinType,\\n        bytes calldata a\\n    ) external;\\n\\n    function setContenthash(bytes32 node, bytes calldata hash) external;\\n\\n    function setDnsrr(bytes32 node, bytes calldata data) external;\\n\\n    function setName(bytes32 node, string calldata _name) external;\\n\\n    function setPubkey(\\n        bytes32 node,\\n        bytes32 x,\\n        bytes32 y\\n    ) external;\\n\\n    function setText(\\n        bytes32 node,\\n        string calldata key,\\n        string calldata value\\n    ) external;\\n\\n    function setInterface(\\n        bytes32 node,\\n        bytes4 interfaceID,\\n        address implementer\\n    ) external;\\n\\n    function multicall(bytes[] calldata data)\\n        external\\n        returns (bytes[] memory results);\\n\\n    /* Deprecated functions */\\n    function content(bytes32 node) external view returns (bytes32);\\n\\n    function multihash(bytes32 node) external view returns (bytes memory);\\n\\n    function setContent(bytes32 node, bytes32 hash) external;\\n\\n    function setMultihash(bytes32 node, bytes calldata hash) external;\\n}\\n\",\"keccak256\":\"0x52333f81a618c966f2983d23111f3fb7061ebaa0493e896b9868208dde06ffdf\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/resolvers/ResolverBase.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity >=0.8.4;\\n\\nimport \\\"lib/openzeppelin-contracts/contracts/utils/introspection/ERC165.sol\\\";\\n\\nabstract contract ResolverBase is ERC165 {\\n    function isAuthorised(bytes32 node) internal virtual view returns(bool);\\n\\n    modifier authorised(bytes32 node) {\\n        require(isAuthorised(node));\\n        _;\\n    }\\n}\\n\",\"keccak256\":\"0xda95c503bb8d3ad8ebd5c77eac75487d732858c84678eda57e30c72e63d216bf\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/resolvers/profiles/IABIResolver.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity >=0.8.4;\\n\\nimport \\\"./IABIResolver.sol\\\";\\nimport \\\"../ResolverBase.sol\\\";\\n\\ninterface IABIResolver {\\n    event ABIChanged(bytes32 indexed node, uint256 indexed contentType);\\n    /**\\n     * Returns the ABI associated with an ENS node.\\n     * Defined in EIP205.\\n     * @param node The ENS node to query\\n     * @param contentTypes A bitwise OR of the ABI formats accepted by the caller.\\n     * @return contentType The content type of the return value\\n     * @return data The ABI data\\n     */\\n    function ABI(bytes32 node, uint256 contentTypes) external view returns (uint256, bytes memory);\\n}\\n\",\"keccak256\":\"0x37d037dd1cb59d7406ccd07d69e7206470c0aa3331c0efb92001769389bf4f2d\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/resolvers/profiles/IAddrResolver.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity >=0.8.4;\\n\\n/**\\n * Interface for the legacy (ETH-only) addr function.\\n */\\ninterface IAddrResolver {\\n    event AddrChanged(bytes32 indexed node, address a);\\n\\n    /**\\n     * Returns the address associated with an ENS node.\\n     * @param node The ENS node to query.\\n     * @return The associated address.\\n     */\\n    function addr(bytes32 node) external view returns (address payable);\\n}\\n\",\"keccak256\":\"0x2ad7f2fc60ebe0f93745fe70247f6a854f66af732483fda2a3c5e055614445e8\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/resolvers/profiles/IAddressResolver.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity >=0.8.4;\\n\\n/**\\n * Interface for the new (multicoin) addr function.\\n */\\ninterface IAddressResolver {\\n    event AddressChanged(bytes32 indexed node, uint coinType, bytes newAddress);\\n\\n    function addr(bytes32 node, uint coinType) external view returns(bytes memory);\\n}\\n\",\"keccak256\":\"0x20717682fa28eb1755a3b6ade738c8e0239c1cc393579058d4c3ffaca238c04b\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/resolvers/profiles/IContentHashResolver.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity >=0.8.4;\\n\\ninterface IContentHashResolver {\\n    event ContenthashChanged(bytes32 indexed node, bytes hash);\\n\\n    /**\\n     * Returns the contenthash associated with an ENS node.\\n     * @param node The ENS node to query.\\n     * @return The associated contenthash.\\n     */\\n    function contenthash(bytes32 node) external view returns (bytes memory);\\n}\\n\",\"keccak256\":\"0xd95cd77684ba5752c428d7dceb4ecc6506ac94f4fbb910489637eb68dcd8e366\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/resolvers/profiles/IDNSRecordResolver.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity >=0.8.4;\\n\\ninterface IDNSRecordResolver {\\n    // DNSRecordChanged is emitted whenever a given node/name/resource's RRSET is updated.\\n    event DNSRecordChanged(bytes32 indexed node, bytes name, uint16 resource, bytes record);\\n    // DNSRecordDeleted is emitted whenever a given node/name/resource's RRSET is deleted.\\n    event DNSRecordDeleted(bytes32 indexed node, bytes name, uint16 resource);\\n    // DNSZoneCleared is emitted whenever a given node's zone information is cleared.\\n    event DNSZoneCleared(bytes32 indexed node);\\n\\n    /**\\n     * Obtain a DNS record.\\n     * @param node the namehash of the node for which to fetch the record\\n     * @param name the keccak-256 hash of the fully-qualified name for which to fetch the record\\n     * @param resource the ID of the resource as per https://en.wikipedia.org/wiki/List_of_DNS_record_types\\n     * @return the DNS record in wire format if present, otherwise empty\\n     */\\n    function dnsRecord(bytes32 node, bytes32 name, uint16 resource) external view returns (bytes memory);\\n}\\n\",\"keccak256\":\"0x640992fd5ad915a67712e2343ea0b8c5c0b88ea2646ff6bb713d448bef6ebfb5\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/resolvers/profiles/IDNSZoneResolver.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity >=0.8.4;\\n\\ninterface IDNSZoneResolver {\\n    // DNSZonehashChanged is emitted whenever a given node's zone hash is updated.\\n    event DNSZonehashChanged(bytes32 indexed node, bytes lastzonehash, bytes zonehash);\\n\\n    /**\\n     * zonehash obtains the hash for the zone.\\n     * @param node The ENS node to query.\\n     * @return The associated contenthash.\\n     */\\n    function zonehash(bytes32 node) external view returns (bytes memory);\\n}\\n\",\"keccak256\":\"0x3b3ca51ab4dcc4eee417bf1ffa54e10d9cf6a30d8f0e3722915965b06355ecb4\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/resolvers/profiles/IExtendedResolver.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.4;\\n\\ninterface IExtendedResolver {\\n    function resolve(bytes memory name, bytes memory data)\\n        external\\n        view\\n        returns (bytes memory, address);\\n}\\n\",\"keccak256\":\"0x0a586a1725cdc5f90f2e302c620a4a033adfc87e49bbcc5a43604ba579bce7a7\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/resolvers/profiles/IInterfaceResolver.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity >=0.8.4;\\n\\ninterface IInterfaceResolver {\\n    event InterfaceChanged(bytes32 indexed node, bytes4 indexed interfaceID, address implementer);\\n\\n    /**\\n     * Returns the address of a contract that implements the specified interface for this name.\\n     * If an implementer has not been set for this interfaceID and name, the resolver will query\\n     * the contract at `addr()`. If `addr()` is set, a contract exists at that address, and that\\n     * contract implements EIP165 and returns `true` for the specified interfaceID, its address\\n     * will be returned.\\n     * @param node The ENS node to query.\\n     * @param interfaceID The EIP 165 interface ID to check for.\\n     * @return The address that implements this interface, or 0 if the interface is unsupported.\\n     */\\n    function interfaceImplementer(bytes32 node, bytes4 interfaceID) external view returns (address);\\n}\\n\",\"keccak256\":\"0xc2673ebfb678b4c2730bff0434daf3a974d9ee0696c4adf533b41802f291745d\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/resolvers/profiles/INameResolver.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity >=0.8.4;\\n\\ninterface INameResolver {\\n    event NameChanged(bytes32 indexed node, string name);\\n\\n    /**\\n     * Returns the name associated with an ENS node, for reverse records.\\n     * Defined in EIP181.\\n     * @param node The ENS node to query.\\n     * @return The associated name.\\n     */\\n    function name(bytes32 node) external view returns (string memory);\\n}\\n\",\"keccak256\":\"0x9ec392b612447b1acbdc01114f2da2837a658d3f3157f60a99c5269f0b623346\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/resolvers/profiles/IPubkeyResolver.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity >=0.8.4;\\n\\ninterface IPubkeyResolver {\\n    event PubkeyChanged(bytes32 indexed node, bytes32 x, bytes32 y);\\n\\n    /**\\n     * Returns the SECP256k1 public key associated with an ENS node.\\n     * Defined in EIP 619.\\n     * @param node The ENS node to query\\n     * @return x The X coordinate of the curve point for the public key.\\n     * @return y The Y coordinate of the curve point for the public key.\\n     */\\n    function pubkey(bytes32 node) external view returns (bytes32 x, bytes32 y);\\n}\\n\",\"keccak256\":\"0x69748947093dd2fda9ddcebd0adf19a6d1e7600df1d4b1462a0417156caddca7\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/resolvers/profiles/ITextResolver.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity >=0.8.4;\\n\\ninterface ITextResolver {\\n    event TextChanged(bytes32 indexed node, string indexed indexedKey, string key);\\n\\n    /**\\n     * Returns the text data associated with an ENS node and key.\\n     * @param node The ENS node to query.\\n     * @param key The text data key to query.\\n     * @return The associated text data.\\n     */\\n    function text(bytes32 node, string calldata key) external view returns (string memory);\\n}\\n\",\"keccak256\":\"0x36a6602f2d76f373c5e1dcded0c87e1d3ab5180dbbbea7aa2a8d0e9a36273e38\",\"license\":\"MIT\"},\"lib/ens-contracts/contracts/root/Controllable.sol\":{\"content\":\"pragma solidity ^0.8.4;\\n\\nimport \\\"lib/openzeppelin-contracts/contracts/access/Ownable.sol\\\";\\n\\ncontract Controllable is Ownable {\\n    mapping(address => bool) public controllers;\\n\\n    event ControllerChanged(address indexed controller, bool enabled);\\n\\n    modifier onlyController {\\n        require(\\n            controllers[msg.sender],\\n            \\\"Controllable: Caller is not a controller\\\"\\n        );\\n        _;\\n    }\\n\\n    function setController(address controller, bool enabled) public onlyOwner {\\n        controllers[controller] = enabled;\\n        emit ControllerChanged(controller, enabled);\\n    }\\n}\\n\",\"keccak256\":\"0x6b3f2e56e5ad1f72b32a0bd4edbfabe0c14160df307b2bb4a64e3af99623dc96\"},\"lib/openzeppelin-contracts/contracts/access/Ownable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (access/Ownable.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../utils/Context.sol\\\";\\n\\n/**\\n * @dev Contract module which provides a basic access control mechanism, where\\n * there is an account (an owner) that can be granted exclusive access to\\n * specific functions.\\n *\\n * By default, the owner account will be the one that deploys the contract. This\\n * can later be changed with {transferOwnership}.\\n *\\n * This module is used through inheritance. It will make available the modifier\\n * `onlyOwner`, which can be applied to your functions to restrict their use to\\n * the owner.\\n */\\nabstract contract Ownable is Context {\\n    address private _owner;\\n\\n    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);\\n\\n    /**\\n     * @dev Initializes the contract setting the deployer as the initial owner.\\n     */\\n    constructor() {\\n        _transferOwnership(_msgSender());\\n    }\\n\\n    /**\\n     * @dev Throws if called by any account other than the owner.\\n     */\\n    modifier onlyOwner() {\\n        _checkOwner();\\n        _;\\n    }\\n\\n    /**\\n     * @dev Returns the address of the current owner.\\n     */\\n    function owner() public view virtual returns (address) {\\n        return _owner;\\n    }\\n\\n    /**\\n     * @dev Throws if the sender is not the owner.\\n     */\\n    function _checkOwner() internal view virtual {\\n        require(owner() == _msgSender(), \\\"Ownable: caller is not the owner\\\");\\n    }\\n\\n    /**\\n     * @dev Leaves the contract without owner. It will not be possible to call\\n     * `onlyOwner` functions anymore. Can only be called by the current owner.\\n     *\\n     * NOTE: Renouncing ownership will leave the contract without an owner,\\n     * thereby removing any functionality that is only available to the owner.\\n     */\\n    function renounceOwnership() public virtual onlyOwner {\\n        _transferOwnership(address(0));\\n    }\\n\\n    /**\\n     * @dev Transfers ownership of the contract to a new account (`newOwner`).\\n     * Can only be called by the current owner.\\n     */\\n    function transferOwnership(address newOwner) public virtual onlyOwner {\\n        require(newOwner != address(0), \\\"Ownable: new owner is the zero address\\\");\\n        _transferOwnership(newOwner);\\n    }\\n\\n    /**\\n     * @dev Transfers ownership of the contract to a new account (`newOwner`).\\n     * Internal function without access restriction.\\n     */\\n    function _transferOwnership(address newOwner) internal virtual {\\n        address oldOwner = _owner;\\n        _owner = newOwner;\\n        emit OwnershipTransferred(oldOwner, newOwner);\\n    }\\n}\\n\",\"keccak256\":\"0x9ceac6c134cbbeac2d7c1e004f633bf1fefbb153038fe14528f333d0b274ec19\",\"license\":\"MIT\"},\"lib/openzeppelin-contracts/contracts/token/ERC1155/IERC1155.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (token/ERC1155/IERC1155.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../../utils/introspection/IERC165.sol\\\";\\n\\n/**\\n * @dev Required interface of an ERC1155 compliant contract, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-1155[EIP].\\n *\\n * _Available since v3.1._\\n */\\ninterface IERC1155 is IERC165 {\\n    /**\\n     * @dev Emitted when `value` tokens of token type `id` are transferred from `from` to `to` by `operator`.\\n     */\\n    event TransferSingle(address indexed operator, address indexed from, address indexed to, uint256 id, uint256 value);\\n\\n    /**\\n     * @dev Equivalent to multiple {TransferSingle} events, where `operator`, `from` and `to` are the same for all\\n     * transfers.\\n     */\\n    event TransferBatch(\\n        address indexed operator,\\n        address indexed from,\\n        address indexed to,\\n        uint256[] ids,\\n        uint256[] values\\n    );\\n\\n    /**\\n     * @dev Emitted when `account` grants or revokes permission to `operator` to transfer their tokens, according to\\n     * `approved`.\\n     */\\n    event ApprovalForAll(address indexed account, address indexed operator, bool approved);\\n\\n    /**\\n     * @dev Emitted when the URI for token type `id` changes to `value`, if it is a non-programmatic URI.\\n     *\\n     * If an {URI} event was emitted for `id`, the standard\\n     * https://eips.ethereum.org/EIPS/eip-1155#metadata-extensions[guarantees] that `value` will equal the value\\n     * returned by {IERC1155MetadataURI-uri}.\\n     */\\n    event URI(string value, uint256 indexed id);\\n\\n    /**\\n     * @dev Returns the amount of tokens of token type `id` owned by `account`.\\n     *\\n     * Requirements:\\n     *\\n     * - `account` cannot be the zero address.\\n     */\\n    function balanceOf(address account, uint256 id) external view returns (uint256);\\n\\n    /**\\n     * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {balanceOf}.\\n     *\\n     * Requirements:\\n     *\\n     * - `accounts` and `ids` must have the same length.\\n     */\\n    function balanceOfBatch(address[] calldata accounts, uint256[] calldata ids)\\n        external\\n        view\\n        returns (uint256[] memory);\\n\\n    /**\\n     * @dev Grants or revokes permission to `operator` to transfer the caller's tokens, according to `approved`,\\n     *\\n     * Emits an {ApprovalForAll} event.\\n     *\\n     * Requirements:\\n     *\\n     * - `operator` cannot be the caller.\\n     */\\n    function setApprovalForAll(address operator, bool approved) external;\\n\\n    /**\\n     * @dev Returns true if `operator` is approved to transfer ``account``'s tokens.\\n     *\\n     * See {setApprovalForAll}.\\n     */\\n    function isApprovedForAll(address account, address operator) external view returns (bool);\\n\\n    /**\\n     * @dev Transfers `amount` tokens of token type `id` from `from` to `to`.\\n     *\\n     * Emits a {TransferSingle} event.\\n     *\\n     * Requirements:\\n     *\\n     * - `to` cannot be the zero address.\\n     * - If the caller is not `from`, it must have been approved to spend ``from``'s tokens via {setApprovalForAll}.\\n     * - `from` must have a balance of tokens of type `id` of at least `amount`.\\n     * - If `to` refers to a smart contract, it must implement {IERC1155Receiver-onERC1155Received} and return the\\n     * acceptance magic value.\\n     */\\n    function safeTransferFrom(\\n        address from,\\n        address to,\\n        uint256 id,\\n        uint256 amount,\\n        bytes calldata data\\n    ) external;\\n\\n    /**\\n     * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {safeTransferFrom}.\\n     *\\n     * Emits a {TransferBatch} event.\\n     *\\n     * Requirements:\\n     *\\n     * - `ids` and `amounts` must have the same length.\\n     * - If `to` refers to a smart contract, it must implement {IERC1155Receiver-onERC1155BatchReceived} and return the\\n     * acceptance magic value.\\n     */\\n    function safeBatchTransferFrom(\\n        address from,\\n        address to,\\n        uint256[] calldata ids,\\n        uint256[] calldata amounts,\\n        bytes calldata data\\n    ) external;\\n}\\n\",\"keccak256\":\"0x2d8cce2900ea5e213b5728ac6d02c139a5be5a112b12b9a187e042fc1134f560\",\"license\":\"MIT\"},\"lib/openzeppelin-contracts/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n    /**\\n     * @dev Returns true if `account` is a contract.\\n     *\\n     * [IMPORTANT]\\n     * ====\\n     * It is unsafe to assume that an address for which this function returns\\n     * false is an externally-owned account (EOA) and not a contract.\\n     *\\n     * Among others, `isContract` will return false for the following\\n     * types of addresses:\\n     *\\n     *  - an externally-owned account\\n     *  - a contract in construction\\n     *  - an address where a contract will be created\\n     *  - an address where a contract lived, but was destroyed\\n     * ====\\n     *\\n     * [IMPORTANT]\\n     * ====\\n     * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n     *\\n     * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n     * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n     * constructor.\\n     * ====\\n     */\\n    function isContract(address account) internal view returns (bool) {\\n        // This method relies on extcodesize/address.code.length, which returns 0\\n        // for contracts in construction, since the code is only stored at the end\\n        // of the constructor execution.\\n\\n        return account.code.length > 0;\\n    }\\n\\n    /**\\n     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n     * `recipient`, forwarding all available gas and reverting on errors.\\n     *\\n     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n     * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n     * imposed by `transfer`, making them unable to receive funds via\\n     * `transfer`. {sendValue} removes this limitation.\\n     *\\n     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n     *\\n     * IMPORTANT: because control is transferred to `recipient`, care must be\\n     * taken to not create reentrancy vulnerabilities. Consider using\\n     * {ReentrancyGuard} or the\\n     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n     */\\n    function sendValue(address payable recipient, uint256 amount) internal {\\n        require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n        (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n        require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n    }\\n\\n    /**\\n     * @dev Performs a Solidity function call using a low level `call`. A\\n     * plain `call` is an unsafe replacement for a function call: use this\\n     * function instead.\\n     *\\n     * If `target` reverts with a revert reason, it is bubbled up by this\\n     * function (like regular Solidity function calls).\\n     *\\n     * Returns the raw returned data. To convert to the expected return value,\\n     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n     *\\n     * Requirements:\\n     *\\n     * - `target` must be a contract.\\n     * - calling `target` with `data` must not revert.\\n     *\\n     * _Available since v3.1._\\n     */\\n    function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n        return functionCallWithValue(target, data, 0, \\\"Address: low-level call failed\\\");\\n    }\\n\\n    /**\\n     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n     * `errorMessage` as a fallback revert reason when `target` reverts.\\n     *\\n     * _Available since v3.1._\\n     */\\n    function functionCall(\\n        address target,\\n        bytes memory data,\\n        string memory errorMessage\\n    ) internal returns (bytes memory) {\\n        return functionCallWithValue(target, data, 0, errorMessage);\\n    }\\n\\n    /**\\n     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n     * but also transferring `value` wei to `target`.\\n     *\\n     * Requirements:\\n     *\\n     * - the calling contract must have an ETH balance of at least `value`.\\n     * - the called Solidity function must be `payable`.\\n     *\\n     * _Available since v3.1._\\n     */\\n    function functionCallWithValue(\\n        address target,\\n        bytes memory data,\\n        uint256 value\\n    ) internal returns (bytes memory) {\\n        return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n    }\\n\\n    /**\\n     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n     * with `errorMessage` as a fallback revert reason when `target` reverts.\\n     *\\n     * _Available since v3.1._\\n     */\\n    function functionCallWithValue(\\n        address target,\\n        bytes memory data,\\n        uint256 value,\\n        string memory errorMessage\\n    ) internal returns (bytes memory) {\\n        require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n        (bool success, bytes memory returndata) = target.call{value: value}(data);\\n        return verifyCallResultFromTarget(target, success, returndata, errorMessage);\\n    }\\n\\n    /**\\n     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n     * but performing a static call.\\n     *\\n     * _Available since v3.3._\\n     */\\n    function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n        return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n    }\\n\\n    /**\\n     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n     * but performing a static call.\\n     *\\n     * _Available since v3.3._\\n     */\\n    function functionStaticCall(\\n        address target,\\n        bytes memory data,\\n        string memory errorMessage\\n    ) internal view returns (bytes memory) {\\n        (bool success, bytes memory returndata) = target.staticcall(data);\\n        return verifyCallResultFromTarget(target, success, returndata, errorMessage);\\n    }\\n\\n    /**\\n     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n     * but performing a delegate call.\\n     *\\n     * _Available since v3.4._\\n     */\\n    function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n        return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n    }\\n\\n    /**\\n     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n     * but performing a delegate call.\\n     *\\n     * _Available since v3.4._\\n     */\\n    function functionDelegateCall(\\n        address target,\\n        bytes memory data,\\n        string memory errorMessage\\n    ) internal returns (bytes memory) {\\n        (bool success, bytes memory returndata) = target.delegatecall(data);\\n        return verifyCallResultFromTarget(target, success, returndata, errorMessage);\\n    }\\n\\n    /**\\n     * @dev Tool to verify that a low level call to smart-contract was successful, and revert (either by bubbling\\n     * the revert reason or using the provided one) in case of unsuccessful call or if target was not a contract.\\n     *\\n     * _Available since v4.8._\\n     */\\n    function verifyCallResultFromTarget(\\n        address target,\\n        bool success,\\n        bytes memory returndata,\\n        string memory errorMessage\\n    ) internal view returns (bytes memory) {\\n        if (success) {\\n            if (returndata.length == 0) {\\n                // only check isContract if the call was successful and the return data is empty\\n                // otherwise we already know that it was a contract\\n                require(isContract(target), \\\"Address: call to non-contract\\\");\\n            }\\n            return returndata;\\n        } else {\\n            _revert(returndata, errorMessage);\\n        }\\n    }\\n\\n    /**\\n     * @dev Tool to verify that a low level call was successful, and revert if it wasn't, either by bubbling the\\n     * revert reason or using the provided one.\\n     *\\n     * _Available since v4.3._\\n     */\\n    function verifyCallResult(\\n        bool success,\\n        bytes memory returndata,\\n        string memory errorMessage\\n    ) internal pure returns (bytes memory) {\\n        if (success) {\\n            return returndata;\\n        } else {\\n            _revert(returndata, errorMessage);\\n        }\\n    }\\n\\n    function _revert(bytes memory returndata, string memory errorMessage) private pure {\\n        // Look for revert reason and bubble it up if present\\n        if (returndata.length > 0) {\\n            // The easiest way to bubble the revert reason is using memory via assembly\\n            /// @solidity memory-safe-assembly\\n            assembly {\\n                let returndata_size := mload(returndata)\\n                revert(add(32, returndata), returndata_size)\\n            }\\n        } else {\\n            revert(errorMessage);\\n        }\\n    }\\n}\\n\",\"keccak256\":\"0x17cd2011df84b69e70740bbfe6f3a4a80850186782db26c8ffa701b0b50f2526\",\"license\":\"MIT\"},\"lib/openzeppelin-contracts/contracts/utils/Context.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Provides information about the current execution context, including the\\n * sender of the transaction and its data. While these are generally available\\n * via msg.sender and msg.data, they should not be accessed in such a direct\\n * manner, since when dealing with meta-transactions the account sending and\\n * paying for execution may not be the actual sender (as far as an application\\n * is concerned).\\n *\\n * This contract is only required for intermediate, library-like contracts.\\n */\\nabstract contract Context {\\n    function _msgSender() internal view virtual returns (address) {\\n        return msg.sender;\\n    }\\n\\n    function _msgData() internal view virtual returns (bytes calldata) {\\n        return msg.data;\\n    }\\n}\\n\",\"keccak256\":\"0xe2e337e6dde9ef6b680e07338c493ebea1b5fd09b43424112868e9cc1706bca7\",\"license\":\"MIT\"},\"lib/openzeppelin-contracts/contracts/utils/Strings.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/Strings.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev String operations.\\n */\\nlibrary Strings {\\n    bytes16 private constant _HEX_SYMBOLS = \\\"0123456789abcdef\\\";\\n    uint8 private constant _ADDRESS_LENGTH = 20;\\n\\n    /**\\n     * @dev Converts a `uint256` to its ASCII `string` decimal representation.\\n     */\\n    function toString(uint256 value) internal pure returns (string memory) {\\n        // Inspired by OraclizeAPI's implementation - MIT licence\\n        // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\\n\\n        if (value == 0) {\\n            return \\\"0\\\";\\n        }\\n        uint256 temp = value;\\n        uint256 digits;\\n        while (temp != 0) {\\n            digits++;\\n            temp /= 10;\\n        }\\n        bytes memory buffer = new bytes(digits);\\n        while (value != 0) {\\n            digits -= 1;\\n            buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\\n            value /= 10;\\n        }\\n        return string(buffer);\\n    }\\n\\n    /**\\n     * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\\n     */\\n    function toHexString(uint256 value) internal pure returns (string memory) {\\n        if (value == 0) {\\n            return \\\"0x00\\\";\\n        }\\n        uint256 temp = value;\\n        uint256 length = 0;\\n        while (temp != 0) {\\n            length++;\\n            temp >>= 8;\\n        }\\n        return toHexString(value, length);\\n    }\\n\\n    /**\\n     * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\\n     */\\n    function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\\n        bytes memory buffer = new bytes(2 * length + 2);\\n        buffer[0] = \\\"0\\\";\\n        buffer[1] = \\\"x\\\";\\n        for (uint256 i = 2 * length + 1; i > 1; --i) {\\n            buffer[i] = _HEX_SYMBOLS[value & 0xf];\\n            value >>= 4;\\n        }\\n        require(value == 0, \\\"Strings: hex length insufficient\\\");\\n        return string(buffer);\\n    }\\n\\n    /**\\n     * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\\n     */\\n    function toHexString(address addr) internal pure returns (string memory) {\\n        return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\\n    }\\n}\\n\",\"keccak256\":\"0xca92905e1626e8567483de21bc1208284865ed7be71d54ca320a140ac25fd290\",\"license\":\"MIT\"},\"lib/openzeppelin-contracts/contracts/utils/introspection/ERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"./IERC165.sol\\\";\\n\\n/**\\n * @dev Implementation of the {IERC165} interface.\\n *\\n * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check\\n * for the additional interface id that will be supported. For example:\\n *\\n * ```solidity\\n * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\\n *     return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);\\n * }\\n * ```\\n *\\n * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.\\n */\\nabstract contract ERC165 is IERC165 {\\n    /**\\n     * @dev See {IERC165-supportsInterface}.\\n     */\\n    function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\\n        return interfaceId == type(IERC165).interfaceId;\\n    }\\n}\\n\",\"keccak256\":\"0xd10975de010d89fd1c78dc5e8a9a7e7f496198085c151648f20cba166b32582b\",\"license\":\"MIT\"},\"lib/openzeppelin-contracts/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n    /**\\n     * @dev Returns true if this contract implements the interface defined by\\n     * `interfaceId`. See the corresponding\\n     * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n     * to learn more about how these ids are created.\\n     *\\n     * This function call must use less than 30 000 gas.\\n     */\\n    function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"lib/safe-contracts/contracts/base/GuardManager.sol\":{\"content\":\"// SPDX-License-Identifier: LGPL-3.0-only\\npragma solidity >=0.7.0 <0.9.0;\\n\\nimport \\\"../common/Enum.sol\\\";\\nimport \\\"../common/SelfAuthorized.sol\\\";\\nimport \\\"../interfaces/IERC165.sol\\\";\\n\\ninterface Guard is IERC165 {\\n    function checkTransaction(\\n        address to,\\n        uint256 value,\\n        bytes memory data,\\n        Enum.Operation operation,\\n        uint256 safeTxGas,\\n        uint256 baseGas,\\n        uint256 gasPrice,\\n        address gasToken,\\n        address payable refundReceiver,\\n        bytes memory signatures,\\n        address msgSender\\n    ) external;\\n\\n    function checkAfterExecution(bytes32 txHash, bool success) external;\\n}\\n\\nabstract contract BaseGuard is Guard {\\n    function supportsInterface(bytes4 interfaceId) external view virtual override returns (bool) {\\n        return\\n            interfaceId == type(Guard).interfaceId || // 0xe6d7a83a\\n            interfaceId == type(IERC165).interfaceId; // 0x01ffc9a7\\n    }\\n}\\n\\n/// @title Fallback Manager - A contract that manages fallback calls made to this contract\\n/// @author Richard Meissner - <richard@gnosis.pm>\\ncontract GuardManager is SelfAuthorized {\\n    event ChangedGuard(address guard);\\n    // keccak256(\\\"guard_manager.guard.address\\\")\\n    bytes32 internal constant GUARD_STORAGE_SLOT = 0x4a204f620c8c5ccdca3fd54d003badd85ba500436a431f0cbda4f558c93c34c8;\\n\\n    /// @dev Set a guard that checks transactions before execution\\n    /// @param guard The address of the guard to be used or the 0 address to disable the guard\\n    function setGuard(address guard) external authorized {\\n        if (guard != address(0)) {\\n            require(Guard(guard).supportsInterface(type(Guard).interfaceId), \\\"GS300\\\");\\n        }\\n        bytes32 slot = GUARD_STORAGE_SLOT;\\n        // solhint-disable-next-line no-inline-assembly\\n        assembly {\\n            sstore(slot, guard)\\n        }\\n        emit ChangedGuard(guard);\\n    }\\n\\n    function getGuard() internal view returns (address guard) {\\n        bytes32 slot = GUARD_STORAGE_SLOT;\\n        // solhint-disable-next-line no-inline-assembly\\n        assembly {\\n            guard := sload(slot)\\n        }\\n    }\\n}\\n\",\"keccak256\":\"0x7496e28d7fb5b729f68f95db2ec9c54352ade263d51a3dcc7d2ac13edcae5508\",\"license\":\"LGPL-3.0-only\"},\"lib/safe-contracts/contracts/common/Enum.sol\":{\"content\":\"// SPDX-License-Identifier: LGPL-3.0-only\\npragma solidity >=0.7.0 <0.9.0;\\n\\n/// @title Enum - Collection of enums\\n/// @author Richard Meissner - <richard@gnosis.pm>\\ncontract Enum {\\n    enum Operation {Call, DelegateCall}\\n}\\n\",\"keccak256\":\"0x473e45b1a5cc47be494b0e123c9127f0c11c1e0992a321ae5a644c0bfdb2c14f\",\"license\":\"LGPL-3.0-only\"},\"lib/safe-contracts/contracts/common/SelfAuthorized.sol\":{\"content\":\"// SPDX-License-Identifier: LGPL-3.0-only\\npragma solidity >=0.7.0 <0.9.0;\\n\\n/// @title SelfAuthorized - authorizes current contract to perform actions\\n/// @author Richard Meissner - <richard@gnosis.pm>\\ncontract SelfAuthorized {\\n    function requireSelfCall() private view {\\n        require(msg.sender == address(this), \\\"GS031\\\");\\n    }\\n\\n    modifier authorized() {\\n        // This is a function call as it minimized the bytecode size\\n        requireSelfCall();\\n        _;\\n    }\\n}\\n\",\"keccak256\":\"0x59d36efca578b75541a776f62a0d0ef03712fc27b6647c3915c14b572106d7bc\",\"license\":\"LGPL-3.0-only\"},\"lib/safe-contracts/contracts/interfaces/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: LGPL-3.0-only\\npragma solidity >=0.7.0 <0.9.0;\\n\\n/// @notice More details at https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/utils/introspection/IERC165.sol\\ninterface IERC165 {\\n    /**\\n     * @dev Returns true if this contract implements the interface defined by\\n     * `interfaceId`. See the corresponding\\n     * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n     * to learn more about how these ids are created.\\n     *\\n     * This function call must use less than 30 000 gas.\\n     */\\n    function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x5c64c2e071245db8fe3ea8b94f73c5a8de236933858ae240348d502433a9d178\",\"license\":\"LGPL-3.0-only\"}},\"version\":1}",
  "bytecode": "0x6101206040526001805460ff191690553480156200001c57600080fd5b506040516200537b3803806200537b8339810160408190526200003f9162000414565b6001600160601b0319606085811b821660805284811b821660a05282811b821660c05287901b1660e0526200007b620000753390565b620002ba565b6001600160a01b038716620000c65760405162461bcd60e51b815260206004820152600f60248201526000805160206200535b83398151915260448201526064015b60405180910390fd5b6001600160a01b0386166200010d5760405162461bcd60e51b815260206004820152600f60248201526000805160206200535b8339815191526044820152606401620000bd565b6001600160a01b038516620001545760405162461bcd60e51b815260206004820152600f60248201526000805160206200535b8339815191526044820152606401620000bd565b6001600160a01b0384166200019b5760405162461bcd60e51b815260206004820152600f60248201526000805160206200535b8339815191526044820152606401620000bd565b6001600160a01b038316620001e25760405162461bcd60e51b815260206004820152600f60248201526000805160206200535b8339815191526044820152606401620000bd565b6001600160a01b038216620002295760405162461bcd60e51b815260206004820152600f60248201526000805160206200535b8339815191526044820152606401620000bd565b6001600160a01b038116620002705760405162461bcd60e51b815260206004820152600f60248201526000805160206200535b8339815191526044820152606401620000bd565b6200027b8762000314565b5060609390931b6001600160601b031916610100525050600280546001600160a01b0319166001600160a01b0390921691909117905550620004a99050565b600180546001600160a01b03838116610100818102610100600160a81b031985161790945560405193909204169182907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6200031e62000393565b6001600160a01b038116620003855760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401620000bd565b6200039081620002ba565b50565b6001546001600160a01b03610100909104163314620003f55760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401620000bd565b565b80516001600160a01b03811681146200040f57600080fd5b919050565b600080600080600080600060e0888a0312156200043057600080fd5b6200043b88620003f7565b96506200044b60208901620003f7565b95506200045b60408901620003f7565b94506200046b60608901620003f7565b93506200047b60808901620003f7565b92506200048b60a08901620003f7565b91506200049b60c08901620003f7565b905092959891949750929550565b60805160601c60a05160601c60c05160601c60e05160601c6101005160601c614df56200056660003960008181610640015281816110ce0152611f0c01526000818161048701528181610aaa01528181610b2901528181611c6e015281816120dd015281816121dc0152818161293c0152818161309001528181613169015281816131fc01526132b30152600081816106fa01526126dd0152600081816105f201526127bd01526000818161066701526127900152614df56000f3fe608060405234801561001057600080fd5b50600436106102f45760003560e01c806392c5961a11610191578063d5a84491116100e3578063e402256411610097578063f2fde38b11610071578063f2fde38b146107b3578063fe258da7146107c6578063ffa1ad74146107d957600080fd5b8063e402256414610752578063e866465414610779578063f0f39f5d146107a057600080fd5b8063e1004045116100c8578063e1004045146106f5578063e1fc2cc11461071c578063e365490f1461072f57600080fd5b8063d5a84491146106cf578063dd9f4e63146106e257600080fd5b8063b557d5e111610145578063c7e2a4fc1161011f578063c7e2a4fc14610689578063cf00cec91461069c578063d2cd157a146106bc57600080fd5b8063b557d5e114610614578063bbc4541b1461063b578063be5405d21461066257600080fd5b80639913627f116101765780639913627f146105b7578063afe5c8ff146105da578063b06a4120146105ed57600080fd5b806392c5961a1461057e57806393271368146105a557600080fd5b80635cb543841161024a57806374d4f6d0116101fe578063827be3cc116101d8578063827be3cc146105375780638d092f5d1461053f5780638da5cb5b1461056857600080fd5b806374d4f6d0146104fe57806375f0bb52146105115780637d49f1db1461052457600080fd5b806362067cd11161022f57806362067cd1146104bc578063682474a2146104cf578063715018a6146104f657600080fd5b80635cb5438414610482578063610b5925146104a957600080fd5b806336890e51116102ac578063436f8d0311610286578063436f8d0314610411578063457c75de1461043a5780634a9b5db71461047a57600080fd5b806336890e51146103a557806337c591fa146103d05780633ef3a75c146103fe57600080fd5b8063232ba758116102dd578063232ba7581461033657806326a13d3014610349578063346e5c481461039257600080fd5b806301ffc9a7146102f9578063146c436114610321575b600080fd5b61030c6103073660046146e1565b610815565b60405190151581526020015b60405180910390f35b61033461032f3660046146bc565b61087e565b005b61033461034436600461478b565b6109c0565b6103856040518060400160405280601681526020017f64656c656761746553657475702861646472657373290000000000000000000081525081565b6040516103189190614b34565b6103346103a0366004614724565b610b9a565b6103b86103b33660046144ce565b610d64565b6040516001600160a01b039091168152602001610318565b6103f06103de366004614236565b60036020526000908152604090205481565b604051908152602001610318565b61033461040c366004614368565b610daf565b6103b861041f36600461470b565b6005602052600090815260409020546001600160a01b031681565b6104617fe318b52b9bee2870ac7ee0af86866eb2e8f9569b34de6028eb487e7983ba6df881565b6040516001600160e01b03199091168152602001610318565b61038561103e565b6103b87f000000000000000000000000000000000000000000000000000000000000000081565b6103346104b7366004614236565b61105a565b6103346104ca366004614749565b611071565b6104617f0d582f13d757778d349075a68bf5d92ef44d17aa3b3ca38da8eb82cb56c41c9081565b610334611321565b61033461050c366004614236565b611335565b61033461051f3660046143e9565b611391565b6103346105323660046145cc565b611467565b610385611485565b6103b861054d36600461470b565b6004602052600090815260409020546001600160a01b031681565b60015461010090046001600160a01b03166103b8565b6104617fe009cfde76304ae4f68fc946b1f438cd7befba1599b95737584c332ee622b62981565b6103346105b33660046146bc565b5050565b61030c6105c536600461470b565b60066020526000908152604090205460ff1681565b6002546103b8906001600160a01b031681565b6103b87f000000000000000000000000000000000000000000000000000000000000000081565b6104617ff8dc5dd91c83c64a09d4878e686963ef56fde408d6dfdfe8047e612cc3e3702b81565b6103b87f000000000000000000000000000000000000000000000000000000000000000081565b6103b87f000000000000000000000000000000000000000000000000000000000000000081565b61030c610697366004614236565b6114a1565b6106af6106aa366004614236565b611534565b6040516103189190614963565b6103346106ca3660046147f8565b6115ab565b6103346106dd366004614236565b611d1b565b6103346106f03660046146bc565b611d8d565b6103b87f000000000000000000000000000000000000000000000000000000000000000081565b61033461072a366004614749565b611e26565b61030c61073d366004614236565b60006020819052908152604090205460ff1681565b6104617fe19a9dd9915bcd0262210387ba8f90d343aab4a5989aaae0ed7f2b6edddaff1a81565b6104617f610b5925afff994a89367f36d1195efacee9e03780fb400aacb2ff998042ec3581565b6103346107ae3660046142a9565b6121d1565b6103346107c1366004614236565b612507565b61030c6107d4366004614270565b612594565b6103856040518060400160405280600581526020017f312e332e3000000000000000000000000000000000000000000000000000000081525081565b60006001600160e01b031982167fe6d7a83a00000000000000000000000000000000000000000000000000000000148061087857506001600160e01b031982167f01ffc9a700000000000000000000000000000000000000000000000000000000145b92915050565b6000828152600560209081526040808320546004909252909120546001600160a01b0391821691168161090d57336001600160a01b038216146109085760405162461bcd60e51b815260206004820152601f60248201527f4f6e6c7920736166652063616e20736574207472616e73666572206c6f636b0060448201526064015b60405180910390fd5b61099e565b336001600160a01b038316148061092c5750336001600160a01b038216145b61099e5760405162461bcd60e51b815260206004820152602860248201527f4f6e6c792061646d696e206f7220736166652063616e20736574207472616e7360448201527f666572206c6f636b00000000000000000000000000000000000000000000000060648201526084016108ff565b5050600091825260066020526040909120805460ff1916911515919091179055565b6000838152600460205260409020546001600160a01b0316338114806109fc57506000848152600560205260409020546001600160a01b031633145b610a485760405162461bcd60e51b815260206004820152600e60248201527f6e6f7420617574686f72697a656400000000000000000000000000000000000060448201526064016108ff565b604080518082018252600181527f2000000000000000000000000000000000000000000000000000000000000000602082015290517fdb609ada0000000000000000000000000000000000000000000000000000000081526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169163db609ada91610ae29187918991906004016149bd565b600060405180830381600087803b158015610afc57600080fd5b505af1158015610b10573d6000803e3d6000fd5b505060405163b898410d60e01b81526001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016925063b898410d9150610b62908590889060040161499b565b600060405180830381600087803b158015610b7c57600080fd5b505af1158015610b90573d6000803e3d6000fd5b5050505050505050565b6000828152600560209081526040808320546004909252909120546001600160a01b03918216911680610c0f5760405162461bcd60e51b815260206004820152601160248201527f506f6420646f65736e277420657869737400000000000000000000000000000060448201526064016108ff565b6001600160a01b038216610c7a57336001600160a01b03821614610c755760405162461bcd60e51b815260206004820152601b60248201527f4f6e6c7920736166652063616e20616464206e65772061646d696e000000000060448201526064016108ff565b610cd2565b336001600160a01b03831614610cd25760405162461bcd60e51b815260206004820152601b60248201527f4f6e6c792061646d696e2063616e207570646174652061646d696e000000000060448201526064016108ff565b6001600160a01b038082166000908152602081905260409020805460ff1916918516151591909117905560008481526005602090815260409182902080546001600160a01b0319166001600160a01b0387169081179091558251878152918201527ffef38cfc44da305e6203142455e0a2b129109e8fd7b40914acff6874f170e3df910160405180910390a150505050565b6000610da68585808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152508792508691506126319050565b95945050505050565b6001600160a01b038516610e055760405162461bcd60e51b815260206004820152601460248201527f696e76616c69642073616665206164647265737300000000000000000000000060448201526064016108ff565b6001600160a01b038516600090815260036020526040902054610ead576000805260046020527f17ef568e3e12ab5b9c7254a8d58478811de00f9e6eb34345acd53bf8fd09d3ec546001600160a01b0386811691161415610ea85760405162461bcd60e51b815260206004820152601360248201527f7361666520616c726561647920696e207573650000000000000000000000000060448201526064016108ff565b610ef5565b60405162461bcd60e51b815260206004820152601360248201527f7361666520616c726561647920696e207573650000000000000000000000000060448201526064016108ff565b6001600160a01b03851660009081526003602052604090205415610f5b5760405162461bcd60e51b815260206004820152601360248201527f7361666520616c726561647920696e207573650000000000000000000000000060448201526064016108ff565b610f64856114a1565b610fb05760405162461bcd60e51b815260206004820152601b60248201527f73616665206d6f64756c65206d75737420626520656e61626c6564000000000060448201526064016108ff565b610fba8533612594565b80610fcd5750336001600160a01b038616145b6110195760405162461bcd60e51b815260206004820152601d60248201527f63616c6c6572206d7573742062652073616665206f72206d656d62657200000060448201526064016108ff565b600061102486611534565b9050611035818789888888886128b9565b50505050505050565b6040518060800160405280605a8152602001614d20605a913981565b6001600160a01b0381161561106e57600080fd5b50565b6001600160a01b0381166110b95760405162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b60448201526064016108ff565b60405163c3c5a54760e01b81523360048201527f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03169063c3c5a5479060240160206040518083038186803b15801561111857600080fd5b505afa15801561112c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111509190614686565b61119c5760405162461bcd60e51b815260206004820152601960248201527f436f6e74726f6c6c6572206e6f7420726567697374657265640000000000000060448201526064016108ff565b6000838152600560205260409020546001600160a01b03161580156111d657506000838152600460205260409020546001600160a01b0316155b80156111f857506001600160a01b038116600090815260036020526040902054155b6112445760405162461bcd60e51b815260206004820152601260248201527f506f6420616c726561647920657869737473000000000000000000000000000060448201526064016108ff565b6001600160a01b0382161561129857600083815260056020908152604080832080546001600160a01b0319166001600160a01b038781169190911790915584168352908290529020805460ff191660011790555b600083815260046020908152604080832080546001600160a01b0319166001600160a01b0386169081179091558352600390915290208390556112db8130612d35565b604080518481526001600160a01b03841660208201527ffef38cfc44da305e6203142455e0a2b129109e8fd7b40914acff6874f170e3df910160405180910390a1505050565b611329612e54565b6113336000612eb4565b565b60405163610b592560e01b81526001600160a01b0382166004820152309063610b592590602401600060405180830381600087803b15801561137657600080fd5b505af115801561138a573d6000803e3d6000fd5b5050505050565b3360009081526003602052604090205480611424576000818152600460205260409020546001600160a01b0316806113ca57505061145a565b6001600160a01b03811633146114225760405162461bcd60e51b815260206004820152600e60248201527f4e6f7420417574686f72697a656400000000000000000000000000000000000060448201526064016108ff565b505b60048a5110611458573360009081526020819052604090205460ff161561144e5761144e8a612f25565b611458818b613060565b505b5050505050505050505050565b6000611474888885612631565b9050610b90888288888888886128b9565b604051806080016040528060468152602001614d7a6046913981565b6040517f2d9ad53d0000000000000000000000000000000000000000000000000000000081523060048201526000906001600160a01b03831690632d9ad53d9060240160206040518083038186803b1580156114fc57600080fd5b505afa158015611510573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108789190614686565b6060816001600160a01b031663a0e67e2b6040518163ffffffff1660e01b815260040160006040518083038186803b15801561156f57600080fd5b505afa158015611583573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526108789190810190614550565b6000838152600460209081526040808320546005909252909120546001600160a01b039182169116816116205760405162461bcd60e51b815260206004820152601260248201527f706f64206e6f742072656769737465726564000000000000000000000000000060448201526064016108ff565b6001600160a01b038116156116ac57336001600160a01b038216146116875760405162461bcd60e51b815260206004820152600d60248201527f6d7573742062652061646d696e0000000000000000000000000000000000000060448201526064016108ff565b6001600160a01b0382166000908152602081905260409020805460ff19169055611704565b336001600160a01b038316146117045760405162461bcd60e51b815260206004820152601960248201527f7478206d7573742062652073656e742066726f6d20736166650000000000000060448201526064016108ff565b600254604080517f04f3bcec00000000000000000000000000000000000000000000000000000000815290516000926001600160a01b0316916304f3bcec916004808301926020929190829003018186803b15801561176257600080fd5b505afa158015611776573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061179a9190614253565b60025460405163cfeac6a560e01b8152600481018890529192506000916001600160a01b039091169063cfeac6a59060240160206040518083038186803b1580156117e457600080fd5b505afa1580156117f8573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061181c91906146a3565b6040517f3b3b57de000000000000000000000000000000000000000000000000000000008152600481018290529091506000906001600160a01b03841690633b3b57de9060240160206040518083038186803b15801561187b57600080fd5b505afa15801561188f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906118b39190614253565b9050846001600160a01b0316816001600160a01b0316146119165760405162461bcd60e51b815260206004820152601b60248201527f7361666520616e64206c6162656c206469646e2774206d61746368000000000060448201526064016108ff565b60025460405163043c4ea360e21b81526001600160a01b03909116906310f13a8c90611946908590600401614a99565b600060405180830381600087803b15801561196057600080fd5b505af1158015611974573d6000803e3d6000fd5b505060025460405163043c4ea360e21b81526001600160a01b0390911692506310f13a8c91506119a8908590600401614b09565b600060405180830381600087803b1580156119c257600080fd5b505af11580156119d6573d6000803e3d6000fd5b50506002546040517fd5fa2b0000000000000000000000000000000000000000000000000000000000815260048101869052600060248201526001600160a01b03909116925063d5fa2b009150604401600060405180830381600087803b158015611a4057600080fd5b505af1158015611a54573d6000803e3d6000fd5b50506002546040517fd22057a9000000000000000000000000000000000000000000000000000000008152600481018b9052600060248201526001600160a01b03909116925063d22057a99150604401600060405180830381600087803b158015611abe57600080fd5b505af1158015611ad2573d6000803e3d6000fd5b50505050611adf856114a1565b15611b7f57611aef856000612d35565b611b7f85600260009054906101000a90046001600160a01b03166001600160a01b031663808698536040518163ffffffff1660e01b815260040160206040518083038186803b158015611b4157600080fd5b505afa158015611b55573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611b799190614253565b886132e2565b600088815260056020908152604080832080546001600160a01b0319908116909155600480845282852080549092169091556001600160a01b038916808552600390935281842084905590517fcf00cec900000000000000000000000000000000000000000000000000000000815290810191909152309063cf00cec99060240160006040518083038186803b158015611c1857600080fd5b505afa158015611c2c573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052611c549190810190614550565b60405163b898410d60e01b81529091506001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063b898410d90611ca59084908d9060040161499b565b600060405180830381600087803b158015611cbf57600080fd5b505af1158015611cd3573d6000803e3d6000fd5b505050507fbf40bbc71e7cad18fa06345bce0dcaecb93fb664d0808f5afe28904c1d1b25da89604051611d0891815260200190565b60405180910390a1505050505050505050565b611d23612e54565b6001600160a01b038116611d6b5760405162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b60448201526064016108ff565b600280546001600160a01b0319166001600160a01b0392909216919091179055565b6000828152600560205260409020546001600160a01b03163314611df35760405162461bcd60e51b815260206004820181905260248201527f4d7573742062652061646d696e20746f20736574206d6f64756c65206c6f636b60448201526064016108ff565b6000828152600460209081526040808320546001600160a01b03168352908290529020805460ff19168215151790555050565b6001600160a01b038216611e6e5760405162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b60448201526064016108ff565b6001600160a01b038216301415611eed5760405162461bcd60e51b815260206004820152602160248201527f43616e6e6f74206d69677261746520746f2073616d6520636f6e74726f6c6c6560448201527f720000000000000000000000000000000000000000000000000000000000000060648201526084016108ff565b60405163c3c5a54760e01b81526001600160a01b0383811660048301527f0000000000000000000000000000000000000000000000000000000000000000169063c3c5a5479060240160206040518083038186803b158015611f4e57600080fd5b505afa158015611f62573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611f869190614686565b611fd25760405162461bcd60e51b815260206004820152601960248201527f436f6e74726f6c6c6572206e6f7420726567697374657265640000000000000060448201526064016108ff565b6000838152600560209081526040808320546004909252909120546001600160a01b039182169116338214806120105750336001600160a01b038216145b61205c5760405162461bcd60e51b815260206004820152601360248201527f55736572206e6f7420617574686f72697a65640000000000000000000000000060448201526064016108ff565b600085815260056020908152604080832080546001600160a01b0319908116909155600480845282852080549092169091556001600160a01b038581168552600390935281842093909355517f82786654000000000000000000000000000000000000000000000000000000008152918201879052858116602483015285917f000000000000000000000000000000000000000000000000000000000000000090911690638278665490604401600060405180830381600087803b15801561212357600080fd5b505af1158015612137573d6000803e3d6000fd5b5050505061214682868661353a565b6040517f62067cd1000000000000000000000000000000000000000000000000000000008152600481018790526001600160a01b03848116602483015283811660448301528216906362067cd190606401600060405180830381600087803b1580156121b157600080fd5b505af11580156121c5573d6000803e3d6000fd5b50505050505050505050565b336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016146122495760405162461bcd60e51b815260206004820152600e60248201527f4e6f7420417574686f72697a656400000000000000000000000000000000000060448201526064016108ff565b6001600160a01b0386163014156122d5578051156122b757600160ff168160008151811061227957612279614cd0565b016020015160f81c141561228c576124ff565b600260ff16816000815181106122a4576122a4614cd0565b016020015160f81c14156122b7576124ff565b6001805460ff16151514156122d5576001805460ff191690556124ff565b60005b83518110156110355760008482815181106122f5576122f5614cd0565b60209081029190910181015160008181526004835260408082205460059094529020549092506001600160a01b0391821691168115801561233d57506001600160a01b038816155b1561234b57505050506124ff565b6001600160a01b0389166123e757816001600160a01b03168a6001600160a01b0316148061238a5750806001600160a01b03168a6001600160a01b0316145b8061239d57506001600160a01b038a1630145b6123d85760405162461bcd60e51b815260206004820152600c60248201526b139bc8149d5b195cc814d95d60a21b60448201526064016108ff565b6123e28883613891565b6124e8565b6001600160a01b03881661247e57816001600160a01b03168a6001600160a01b031614806124265750806001600160a01b03168a6001600160a01b0316145b8061243957506001600160a01b038a1630145b6124745760405162461bcd60e51b815260206004820152600c60248201526b139bc8149d5b195cc814d95d60a21b60448201526064016108ff565b6123e28983613a29565b60008381526006602052604090205460ff16156124dd5760405162461bcd60e51b815260206004820152601660248201527f506f64204973205472616e73666572204c6f636b65640000000000000000000060448201526064016108ff565b6124e8898984613cec565b5050506001816124f89190614bce565b90506122d8565b505050505050565b61250f612e54565b6001600160a01b03811661258b5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201527f646472657373000000000000000000000000000000000000000000000000000060648201526084016108ff565b61106e81612eb4565b6040517f2f54bf6e0000000000000000000000000000000000000000000000000000000081526001600160a01b03828116600483015260009190841690632f54bf6e9060240160206040518083038186803b1580156125f257600080fd5b505afa158015612606573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061262a9190614686565b9392505050565b604080518082018252601681527f64656c656761746553657475702861646472657373290000000000000000000060208201529051306024820152600091829160440160408051601f19818403018152908290529161268f91614896565b60405180910390206001600160e01b0319166020820180516001600160e01b03838183161783525050505090506000604051806080016040528060468152602001614d7a60469139868630857f000000000000000000000000000000000000000000000000000000000000000060008060006040516024016127189897969594939291906149f2565b60408051601f19818403018152908290529161273391614896565b60408051918290039091206020830180516001600160e01b03166001600160e01b0319909216919091179052517f1688f0b90000000000000000000000000000000000000000000000000000000081529091506001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001690631688f0b9906127e9907f000000000000000000000000000000000000000000000000000000000000000090859089906004016148b2565b602060405180830381600087803b15801561280357600080fd5b505af1925050508015612833575060408051601f3d908101601f1916820190925261283091810190614253565b60015b6128af573d808015612861576040519150601f19603f3d011682016040523d82523d6000602084013e612866565b606091505b5060405162461bcd60e51b815260206004820152601d60248201527f4372656174652050726f787920576974682044617461204661696c656400000060448201526064016108ff565b925061262a915050565b604080516001808252818301909252600091602082018180368337019050509050600160f81b816000815181106128f2576128f2614cd0565b60200101906001600160f81b031916908160001a9053506040517f9aa0055e0000000000000000000000000000000000000000000000000000000081526000906001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001690639aa0055e90612973908c908690600401614976565b602060405180830381600087803b15801561298d57600080fd5b505af11580156129a1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906129c591906146a3565b9050838114612a165760405162461bcd60e51b815260206004820152601e60248201527f706f64206964206469646e2774206d617463682c2074727920616761696e000060448201526064016108ff565b7fb298a97e1ae845f4ac62f176cde255ccfe5ac42197eae12459c99761bad66a4881898988604051612a4b9493929190614b47565b60405180910390a1604080518281526001600160a01b03891660208201527ffef38cfc44da305e6203142455e0a2b129109e8fd7b40914acff6874f170e3df910160405180910390a1612a9e8830612d35565b6001600160a01b03871615612af8576001600160a01b0388166000908152602081905260409020805460ff19166001179055600081815260056020526040902080546001600160a01b0319166001600160a01b0389161790555b600081815260046020818152604080842080546001600160a01b0319166001600160a01b038e8116918217909255808652600390935281852086905560025491517f98eed3e90000000000000000000000000000000000000000000000000000000081529384018b9052602484019290925233604484015216906398eed3e990606401602060405180830381600087803b158015612b9557600080fd5b505af1158015612ba9573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612bcd9190614253565b9050612bda898288613e75565b60025460405163cfeac6a560e01b8152600481018990526000916001600160a01b03169063cfeac6a59060240160206040518083038186803b158015612c1f57600080fd5b505afa158015612c33573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612c5791906146a3565b60025460405163043c4ea360e21b81529192506001600160a01b0316906310f13a8c90612c8a9084908990600401614a5b565b600060405180830381600087803b158015612ca457600080fd5b505af1158015612cb8573d6000803e3d6000fd5b50506002546001600160a01b031691506310f13a8c905082612cd986613ee8565b6040518363ffffffff1660e01b8152600401612cf6929190614ade565b600060405180830381600087803b158015612d1057600080fd5b505af1158015612d24573d6000803e3d6000fd5b505050505050505050505050505050565b6040516001600160a01b038216602482015260009060440160408051601f198184030181529181526020820180516001600160e01b031663e19a9dd960e01b1790525163468721a760e01b81529091506000906001600160a01b0385169063468721a790612dad9087908590879082906004016148e4565b602060405180830381600087803b158015612dc757600080fd5b505af1158015612ddb573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612dff9190614686565b905080612e4e5760405162461bcd60e51b815260206004820152601360248201527f436f756c64206e6f74207365742067756172640000000000000000000000000060448201526064016108ff565b50505050565b6001546001600160a01b036101009091041633146113335760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016108ff565b600180546001600160a01b038381166101008181027fffffffffffffffffffffff0000000000000000000000000000000000000000ff85161790945560405193909204169182907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b63610b592560e01b612f3682614c11565b6001600160e01b0319161415612f8e5760405162461bcd60e51b815260206004820152601560248201527f43616e6e6f7420456e61626c65204d6f64756c6573000000000000000000000060448201526064016108ff565b637004e7ef60e11b612f9f82614c11565b6001600160e01b0319161415612ff75760405162461bcd60e51b815260206004820152601660248201527f43616e6e6f742044697361626c65204d6f64756c65730000000000000000000060448201526064016108ff565b63e19a9dd960e01b61300882614c11565b6001600160e01b031916141561106e5760405162461bcd60e51b815260206004820152601360248201527f43616e6e6f74204368616e67652047756172640000000000000000000000000060448201526064016108ff565b630d582f1360e01b61307182614c11565b6001600160e01b03191614156131115760248101516001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000166394d008ef82856130bf61400a565b6040518463ffffffff1660e01b81526004016130dd9392919061493b565b600060405180830381600087803b1580156130f757600080fd5b505af115801561310b573d6000803e3d6000fd5b50505050505b63f8dc5dd960e01b61312282614c11565b6001600160e01b03191614156131c75760448101516001805460ff191681179055604051632770a7eb60e21b81526001600160a01b038281166004830152602482018590527f00000000000000000000000000000000000000000000000000000000000000001690639dc29fac90604401600060405180830381600087803b1580156131ad57600080fd5b505af11580156131c1573d6000803e3d6000fd5b50505050505b63e318b52b60e01b6131d882614c11565b6001600160e01b03191614156105b357604481015160648201516001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000166394d008ef828661322b61400a565b6040518463ffffffff1660e01b81526004016132499392919061493b565b600060405180830381600087803b15801561326357600080fd5b505af1158015613277573d6000803e3d6000fd5b50506001805460ff1916811790555061328d9050565b604051632770a7eb60e21b81526001600160a01b038381166004830152602482018690527f00000000000000000000000000000000000000000000000000000000000000001690639dc29fac90604401610b62565b60405160206024820152600060448201819052849160640160408051601f198184030181529181526020820180516001600160e01b031663c47f002760e01b1790525163468721a760e01b81529091506001600160a01b0383169063468721a790613358908790600090869082906004016148e4565b602060405180830381600087803b15801561337257600080fd5b505af1158015613386573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906133aa9190614686565b506040516000602482018190529060440160408051601f198184030181529181526020820180516001600160e01b031663e19a9dd960e01b1790525163468721a760e01b81529091506001600160a01b0384169063468721a790613419908990600090869082906004016148e4565b602060405180830381600087803b15801561343357600080fd5b505af1158015613447573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061346b9190614686565b506040516001600160a01b038516602482015230604482015260009060640160408051601f198184030181529181526020820180516001600160e01b0316637004e7ef60e11b1790525163468721a760e01b81529091506001600160a01b0385169063468721a7906134e8908a90600090869082906004016148e4565b602060405180830381600087803b15801561350257600080fd5b505af1158015613516573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b909190614686565b6040516001600160a01b038316602482015260009060440160408051601f198184030181529181526020820180516001600160e01b031663610b592560e01b1790525163468721a760e01b81529091506000906001600160a01b0386169063468721a7906135b29088908590879082906004016148e4565b602060405180830381600087803b1580156135cc57600080fd5b505af11580156135e0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906136049190614686565b9050806136535760405162461bcd60e51b815260206004820152601a60248201527f4d6967726174696f6e206661696c6564206f6e20656e61626c6500000000000060448201526064016108ff565b6040517fcc2f84520000000000000000000000000000000000000000000000000000000081526001600160a01b038481166004830152600160248301526000919087169063cc2f84529060440160006040518083038186803b1580156136b857600080fd5b505afa1580156136cc573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526136f49190810190614585565b509050306001600160a01b03168160008151811061371457613714614cd0565b60200260200101516001600160a01b0316146137725760405162461bcd60e51b815260206004820152601460248201527f696e636f727265637420707265764d6f64756c6500000000000000000000000060448201526064016108ff565b6040516001600160a01b038516602482015230604482015260009060640160408051601f198184030181529181526020820180516001600160e01b0316637004e7ef60e11b1790525163468721a760e01b81529091506000906001600160a01b0389169063468721a7906137f0908b908590879082906004016148e4565b602060405180830381600087803b15801561380a57600080fd5b505af115801561381e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906138429190614686565b905080610b905760405162461bcd60e51b815260206004820152601b60248201527f4d6967726174696f6e206661696c6564206f6e2064697361626c65000000000060448201526064016108ff565b6000816001600160a01b031663e75235b86040518163ffffffff1660e01b8152600401602060405180830381600087803b1580156138ce57600080fd5b505af11580156138e2573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061390691906146a3565b6040516001600160a01b03851660248201526044810182905290915060009060640160408051601f198184030181529181526020820180516001600160e01b0316630d582f1360e01b1790525163468721a760e01b81529091506000906001600160a01b0385169063468721a7906139889087908590879082906004016148e4565b602060405180830381600087803b1580156139a257600080fd5b505af11580156139b6573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906139da9190614686565b90508061138a5760405162461bcd60e51b815260206004820152601960248201527f4d6f64756c65205472616e73616374696f6e204661696c65640000000000000060448201526064016108ff565b6000816001600160a01b031663e75235b86040518163ffffffff1660e01b8152600401602060405180830381600087803b158015613a6657600080fd5b505af1158015613a7a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613a9e91906146a3565b90506000826001600160a01b031663a0e67e2b6040518163ffffffff1660e01b815260040160006040518083038186803b158015613adb57600080fd5b505afa158015613aef573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052613b179190810190614550565b90506000805b8251811015613ba057856001600160a01b0316838281518110613b4257613b42614cd0565b60200260200101516001600160a01b03161415613b8e5780613b675760019150613b8e565b82613b73600183614bfa565b81518110613b8357613b83614cd0565b602002602001015191505b80613b9881614c75565b915050613b1d565b508260018351613bb09190614bfa565b1015613bc457613bc1600184614bfa565b92505b6040516001600160a01b038083166024830152861660448201526064810184905260009060840160408051601f198184030181529181526020820180516001600160e01b031663f8dc5dd960e01b1790525163468721a760e01b81529091506000906001600160a01b0387169063468721a790613c4b9089908590879082906004016148e4565b602060405180830381600087803b158015613c6557600080fd5b505af1158015613c79573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613c9d9190614686565b9050806110355760405162461bcd60e51b815260206004820152601960248201527f4d6f64756c65205472616e73616374696f6e204661696c65640000000000000060448201526064016108ff565b6000816001600160a01b031663a0e67e2b6040518163ffffffff1660e01b815260040160006040518083038186803b158015613d2757600080fd5b505afa158015613d3b573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052613d639190810190614550565b90506000805b8251811015613dec57856001600160a01b0316838281518110613d8e57613d8e614cd0565b60200260200101516001600160a01b03161415613dda5780613db35760019150613dda565b82613dbf600183614bfa565b81518110613dcf57613dcf614cd0565b602002602001015191505b80613de481614c75565b915050613d69565b506040516001600160a01b03808316602483015280871660448301528516606482015260009060840160408051601f198184030181529181526020820180516001600160e01b031663e318b52b60e01b1790525163468721a760e01b81529091506000906001600160a01b0386169063468721a790613c4b9088908590879082906004016148e4565b600081604051602401613e889190614b34565b60408051601f198184030181529181526020820180516001600160e01b031663c47f002760e01b1790525163468721a760e01b81529091506000906001600160a01b0386169063468721a7906139889087908590879082906004016148e4565b606081613f2857505060408051808201909152600181527f3000000000000000000000000000000000000000000000000000000000000000602082015290565b8160005b8115613f525780613f3c81614c75565b9150613f4b9050600a83614be6565b9150613f2c565b60008167ffffffffffffffff811115613f6d57613f6d614ce6565b6040519080825280601f01601f191660200182016040528015613f97576020820181803683370190505b5090505b841561400257613fac600183614bfa565b9150613fb9600a86614c90565b613fc4906030614bce565b60f81b818381518110613fd957613fd9614cd0565b60200101906001600160f81b031916908160001a905350613ffb600a86614be6565b9450613f9b565b949350505050565b60408051600180825281830190925260609160009190602082018180368337019050509050600260f81b8160008151811061404757614047614cd0565b60200101906001600160f81b031916908160001a905350919050565b803561406e81614cfc565b919050565b600082601f83011261408457600080fd5b8135602061409961409483614baa565b614b79565b80838252828201915082860187848660051b89010111156140b957600080fd5b60005b858110156140e15781356140cf81614cfc565b845292840192908401906001016140bc565b5090979650505050505050565b600082601f8301126140ff57600080fd5b8151602061410f61409483614baa565b80838252828201915082860187848660051b890101111561412f57600080fd5b60005b858110156140e157815161414581614cfc565b84529284019290840190600101614132565b600082601f83011261416857600080fd5b8135602061417861409483614baa565b80838252828201915082860187848660051b890101111561419857600080fd5b60005b858110156140e15781358452928401929084019060010161419b565b600082601f8301126141c857600080fd5b813567ffffffffffffffff8111156141e2576141e2614ce6565b6141f5601f8201601f1916602001614b79565b81815284602083860101111561420a57600080fd5b816020850160208301376000918101602001919091529392505050565b80356002811061406e57600080fd5b60006020828403121561424857600080fd5b813561262a81614cfc565b60006020828403121561426557600080fd5b815161262a81614cfc565b6000806040838503121561428357600080fd5b823561428e81614cfc565b9150602083013561429e81614cfc565b809150509250929050565b60008060008060008060c087890312156142c257600080fd5b86356142cd81614cfc565b955060208701356142dd81614cfc565b945060408701356142ed81614cfc565b9350606087013567ffffffffffffffff8082111561430a57600080fd5b6143168a838b01614157565b9450608089013591508082111561432c57600080fd5b6143388a838b01614157565b935060a089013591508082111561434e57600080fd5b5061435b89828a016141b7565b9150509295509295509295565b60008060008060008060c0878903121561438157600080fd5b863561438c81614cfc565b9550602087013561439c81614cfc565b945060408701359350606087013567ffffffffffffffff808211156143c057600080fd5b6143cc8a838b016141b7565b94506080890135935060a089013591508082111561434e57600080fd5b60008060008060008060008060008060006101608c8e03121561440b57600080fd5b6144148c614063565b9a5060208c0135995067ffffffffffffffff8060408e0135111561443757600080fd5b6144478e60408f01358f016141b7565b995061445560608e01614227565b985060808d0135975060a08d0135965060c08d0135955061447860e08e01614063565b94506144876101008e01614063565b9350806101208e0135111561449b57600080fd5b506144ad8d6101208e01358e016141b7565b91506144bc6101408d01614063565b90509295989b509295989b9093969950565b600080600080606085870312156144e457600080fd5b843567ffffffffffffffff808211156144fc57600080fd5b818701915087601f83011261451057600080fd5b81358181111561451f57600080fd5b8860208260051b850101111561453457600080fd5b6020928301999098509187013596604001359550909350505050565b60006020828403121561456257600080fd5b815167ffffffffffffffff81111561457957600080fd5b614002848285016140ee565b6000806040838503121561459857600080fd5b825167ffffffffffffffff8111156145af57600080fd5b6145bb858286016140ee565b925050602083015161429e81614cfc565b600080600080600080600060e0888a0312156145e757600080fd5b873567ffffffffffffffff808211156145ff57600080fd5b61460b8b838c01614073565b985060208a0135975060408a0135915061462482614cfc565b909550606089013594506080890135908082111561464157600080fd5b61464d8b838c016141b7565b945060a08a0135935060c08a013591508082111561466a57600080fd5b506146778a828b016141b7565b91505092959891949750929550565b60006020828403121561469857600080fd5b815161262a81614d11565b6000602082840312156146b557600080fd5b5051919050565b600080604083850312156146cf57600080fd5b82359150602083013561429e81614d11565b6000602082840312156146f357600080fd5b81356001600160e01b03198116811461262a57600080fd5b60006020828403121561471d57600080fd5b5035919050565b6000806040838503121561473757600080fd5b82359150602083013561429e81614cfc565b60008060006060848603121561475e57600080fd5b83359250602084013561477081614cfc565b9150604084013561478081614cfc565b809150509250925092565b6000806000606084860312156147a057600080fd5b83359250602084013567ffffffffffffffff808211156147bf57600080fd5b6147cb87838801614073565b935060408601359150808211156147e157600080fd5b506147ee86828701614073565b9150509250925092565b60008060006060848603121561480d57600080fd5b8335925060208401359150604084013561478081614cfc565b600081518084526020808501945080840160005b8381101561485f5781516001600160a01b03168752958201959082019060010161483a565b509495945050505050565b60008151808452614882816020860160208601614c49565b601f01601f19169290920160200192915050565b600082516148a8818460208701614c49565b9190910192915050565b6001600160a01b03841681526060602082015260006148d4606083018561486a565b9050826040830152949350505050565b6001600160a01b038516815283602082015260806040820152600061490c608083018561486a565b90506002831061492c57634e487b7160e01b600052602160045260246000fd5b82606083015295945050505050565b6001600160a01b0384168152826020820152606060408201526000610da6606083018461486a565b60208152600061262a6020830184614826565b6040815260006149896040830185614826565b8281036020840152610da6818561486a565b6040815260006149ae6040830185614826565b90508260208301529392505050565b6060815260006149d06060830186614826565b84602084015282810360408401526149e8818561486a565b9695505050505050565b6000610100808352614a068184018c614826565b90508960208401526001600160a01b03808a1660408501528382036060850152614a30828a61486a565b978116608085015295861660a0840152505060c081019290925290911660e090910152949350505050565b828152606060208201526000614a8760608301600681526530bb30ba30b960d11b602082015260400190565b8281036040840152610da6818561486a565b818152606060208201526000614ac560608301600681526530bb30ba30b960d11b602082015260400190565b8281036040840152600081526020810191505092915050565b828152606060208201526000614a876060830160058152641c1bd9125960da1b602082015260400190565b818152606060208201526000614ac56060830160058152641c1bd9125960da1b602082015260400190565b60208152600061262a602083018461486a565b84815260006001600160a01b038086166020840152808516604084015250608060608301526149e8608083018461486a565b604051601f8201601f1916810167ffffffffffffffff81118282101715614ba257614ba2614ce6565b604052919050565b600067ffffffffffffffff821115614bc457614bc4614ce6565b5060051b60200190565b60008219821115614be157614be1614ca4565b500190565b600082614bf557614bf5614cba565b500490565b600082821015614c0c57614c0c614ca4565b500390565b6000815160208301516001600160e01b031980821693506004831015614c415780818460040360031b1b83161693505b505050919050565b60005b83811015614c64578181015183820152602001614c4c565b83811115612e4e5750506000910152565b6000600019821415614c8957614c89614ca4565b5060010190565b600082614c9f57614c9f614cba565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b038116811461106e57600080fd5b801515811461106e57600080fdfe657865635472616e73616374696f6e28616464726573732c75696e743235362c62797465732c75696e74382c75696e743235362c75696e743235362c75696e743235362c616464726573732c616464726573732c627974657329736574757028616464726573735b5d2c75696e743235362c616464726573732c62797465732c616464726573732c616464726573732c75696e743235362c6164647265737329a264697066735822122085553cca2517c1a743cea40c8b66968899ae115b4a9eec97cce0375a1d31780564736f6c63430008070033496e76616c696420616464726573730000000000000000000000000000000000",
  "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106102f45760003560e01c806392c5961a11610191578063d5a84491116100e3578063e402256411610097578063f2fde38b11610071578063f2fde38b146107b3578063fe258da7146107c6578063ffa1ad74146107d957600080fd5b8063e402256414610752578063e866465414610779578063f0f39f5d146107a057600080fd5b8063e1004045116100c8578063e1004045146106f5578063e1fc2cc11461071c578063e365490f1461072f57600080fd5b8063d5a84491146106cf578063dd9f4e63146106e257600080fd5b8063b557d5e111610145578063c7e2a4fc1161011f578063c7e2a4fc14610689578063cf00cec91461069c578063d2cd157a146106bc57600080fd5b8063b557d5e114610614578063bbc4541b1461063b578063be5405d21461066257600080fd5b80639913627f116101765780639913627f146105b7578063afe5c8ff146105da578063b06a4120146105ed57600080fd5b806392c5961a1461057e57806393271368146105a557600080fd5b80635cb543841161024a57806374d4f6d0116101fe578063827be3cc116101d8578063827be3cc146105375780638d092f5d1461053f5780638da5cb5b1461056857600080fd5b806374d4f6d0146104fe57806375f0bb52146105115780637d49f1db1461052457600080fd5b806362067cd11161022f57806362067cd1146104bc578063682474a2146104cf578063715018a6146104f657600080fd5b80635cb5438414610482578063610b5925146104a957600080fd5b806336890e51116102ac578063436f8d0311610286578063436f8d0314610411578063457c75de1461043a5780634a9b5db71461047a57600080fd5b806336890e51146103a557806337c591fa146103d05780633ef3a75c146103fe57600080fd5b8063232ba758116102dd578063232ba7581461033657806326a13d3014610349578063346e5c481461039257600080fd5b806301ffc9a7146102f9578063146c436114610321575b600080fd5b61030c6103073660046146e1565b610815565b60405190151581526020015b60405180910390f35b61033461032f3660046146bc565b61087e565b005b61033461034436600461478b565b6109c0565b6103856040518060400160405280601681526020017f64656c656761746553657475702861646472657373290000000000000000000081525081565b6040516103189190614b34565b6103346103a0366004614724565b610b9a565b6103b86103b33660046144ce565b610d64565b6040516001600160a01b039091168152602001610318565b6103f06103de366004614236565b60036020526000908152604090205481565b604051908152602001610318565b61033461040c366004614368565b610daf565b6103b861041f36600461470b565b6005602052600090815260409020546001600160a01b031681565b6104617fe318b52b9bee2870ac7ee0af86866eb2e8f9569b34de6028eb487e7983ba6df881565b6040516001600160e01b03199091168152602001610318565b61038561103e565b6103b87f000000000000000000000000000000000000000000000000000000000000000081565b6103346104b7366004614236565b61105a565b6103346104ca366004614749565b611071565b6104617f0d582f13d757778d349075a68bf5d92ef44d17aa3b3ca38da8eb82cb56c41c9081565b610334611321565b61033461050c366004614236565b611335565b61033461051f3660046143e9565b611391565b6103346105323660046145cc565b611467565b610385611485565b6103b861054d36600461470b565b6004602052600090815260409020546001600160a01b031681565b60015461010090046001600160a01b03166103b8565b6104617fe009cfde76304ae4f68fc946b1f438cd7befba1599b95737584c332ee622b62981565b6103346105b33660046146bc565b5050565b61030c6105c536600461470b565b60066020526000908152604090205460ff1681565b6002546103b8906001600160a01b031681565b6103b87f000000000000000000000000000000000000000000000000000000000000000081565b6104617ff8dc5dd91c83c64a09d4878e686963ef56fde408d6dfdfe8047e612cc3e3702b81565b6103b87f000000000000000000000000000000000000000000000000000000000000000081565b6103b87f000000000000000000000000000000000000000000000000000000000000000081565b61030c610697366004614236565b6114a1565b6106af6106aa366004614236565b611534565b6040516103189190614963565b6103346106ca3660046147f8565b6115ab565b6103346106dd366004614236565b611d1b565b6103346106f03660046146bc565b611d8d565b6103b87f000000000000000000000000000000000000000000000000000000000000000081565b61033461072a366004614749565b611e26565b61030c61073d366004614236565b60006020819052908152604090205460ff1681565b6104617fe19a9dd9915bcd0262210387ba8f90d343aab4a5989aaae0ed7f2b6edddaff1a81565b6104617f610b5925afff994a89367f36d1195efacee9e03780fb400aacb2ff998042ec3581565b6103346107ae3660046142a9565b6121d1565b6103346107c1366004614236565b612507565b61030c6107d4366004614270565b612594565b6103856040518060400160405280600581526020017f312e332e3000000000000000000000000000000000000000000000000000000081525081565b60006001600160e01b031982167fe6d7a83a00000000000000000000000000000000000000000000000000000000148061087857506001600160e01b031982167f01ffc9a700000000000000000000000000000000000000000000000000000000145b92915050565b6000828152600560209081526040808320546004909252909120546001600160a01b0391821691168161090d57336001600160a01b038216146109085760405162461bcd60e51b815260206004820152601f60248201527f4f6e6c7920736166652063616e20736574207472616e73666572206c6f636b0060448201526064015b60405180910390fd5b61099e565b336001600160a01b038316148061092c5750336001600160a01b038216145b61099e5760405162461bcd60e51b815260206004820152602860248201527f4f6e6c792061646d696e206f7220736166652063616e20736574207472616e7360448201527f666572206c6f636b00000000000000000000000000000000000000000000000060648201526084016108ff565b5050600091825260066020526040909120805460ff1916911515919091179055565b6000838152600460205260409020546001600160a01b0316338114806109fc57506000848152600560205260409020546001600160a01b031633145b610a485760405162461bcd60e51b815260206004820152600e60248201527f6e6f7420617574686f72697a656400000000000000000000000000000000000060448201526064016108ff565b604080518082018252600181527f2000000000000000000000000000000000000000000000000000000000000000602082015290517fdb609ada0000000000000000000000000000000000000000000000000000000081526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169163db609ada91610ae29187918991906004016149bd565b600060405180830381600087803b158015610afc57600080fd5b505af1158015610b10573d6000803e3d6000fd5b505060405163b898410d60e01b81526001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016925063b898410d9150610b62908590889060040161499b565b600060405180830381600087803b158015610b7c57600080fd5b505af1158015610b90573d6000803e3d6000fd5b5050505050505050565b6000828152600560209081526040808320546004909252909120546001600160a01b03918216911680610c0f5760405162461bcd60e51b815260206004820152601160248201527f506f6420646f65736e277420657869737400000000000000000000000000000060448201526064016108ff565b6001600160a01b038216610c7a57336001600160a01b03821614610c755760405162461bcd60e51b815260206004820152601b60248201527f4f6e6c7920736166652063616e20616464206e65772061646d696e000000000060448201526064016108ff565b610cd2565b336001600160a01b03831614610cd25760405162461bcd60e51b815260206004820152601b60248201527f4f6e6c792061646d696e2063616e207570646174652061646d696e000000000060448201526064016108ff565b6001600160a01b038082166000908152602081905260409020805460ff1916918516151591909117905560008481526005602090815260409182902080546001600160a01b0319166001600160a01b0387169081179091558251878152918201527ffef38cfc44da305e6203142455e0a2b129109e8fd7b40914acff6874f170e3df910160405180910390a150505050565b6000610da68585808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152508792508691506126319050565b95945050505050565b6001600160a01b038516610e055760405162461bcd60e51b815260206004820152601460248201527f696e76616c69642073616665206164647265737300000000000000000000000060448201526064016108ff565b6001600160a01b038516600090815260036020526040902054610ead576000805260046020527f17ef568e3e12ab5b9c7254a8d58478811de00f9e6eb34345acd53bf8fd09d3ec546001600160a01b0386811691161415610ea85760405162461bcd60e51b815260206004820152601360248201527f7361666520616c726561647920696e207573650000000000000000000000000060448201526064016108ff565b610ef5565b60405162461bcd60e51b815260206004820152601360248201527f7361666520616c726561647920696e207573650000000000000000000000000060448201526064016108ff565b6001600160a01b03851660009081526003602052604090205415610f5b5760405162461bcd60e51b815260206004820152601360248201527f7361666520616c726561647920696e207573650000000000000000000000000060448201526064016108ff565b610f64856114a1565b610fb05760405162461bcd60e51b815260206004820152601b60248201527f73616665206d6f64756c65206d75737420626520656e61626c6564000000000060448201526064016108ff565b610fba8533612594565b80610fcd5750336001600160a01b038616145b6110195760405162461bcd60e51b815260206004820152601d60248201527f63616c6c6572206d7573742062652073616665206f72206d656d62657200000060448201526064016108ff565b600061102486611534565b9050611035818789888888886128b9565b50505050505050565b6040518060800160405280605a8152602001614d20605a913981565b6001600160a01b0381161561106e57600080fd5b50565b6001600160a01b0381166110b95760405162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b60448201526064016108ff565b60405163c3c5a54760e01b81523360048201527f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03169063c3c5a5479060240160206040518083038186803b15801561111857600080fd5b505afa15801561112c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111509190614686565b61119c5760405162461bcd60e51b815260206004820152601960248201527f436f6e74726f6c6c6572206e6f7420726567697374657265640000000000000060448201526064016108ff565b6000838152600560205260409020546001600160a01b03161580156111d657506000838152600460205260409020546001600160a01b0316155b80156111f857506001600160a01b038116600090815260036020526040902054155b6112445760405162461bcd60e51b815260206004820152601260248201527f506f6420616c726561647920657869737473000000000000000000000000000060448201526064016108ff565b6001600160a01b0382161561129857600083815260056020908152604080832080546001600160a01b0319166001600160a01b038781169190911790915584168352908290529020805460ff191660011790555b600083815260046020908152604080832080546001600160a01b0319166001600160a01b0386169081179091558352600390915290208390556112db8130612d35565b604080518481526001600160a01b03841660208201527ffef38cfc44da305e6203142455e0a2b129109e8fd7b40914acff6874f170e3df910160405180910390a1505050565b611329612e54565b6113336000612eb4565b565b60405163610b592560e01b81526001600160a01b0382166004820152309063610b592590602401600060405180830381600087803b15801561137657600080fd5b505af115801561138a573d6000803e3d6000fd5b5050505050565b3360009081526003602052604090205480611424576000818152600460205260409020546001600160a01b0316806113ca57505061145a565b6001600160a01b03811633146114225760405162461bcd60e51b815260206004820152600e60248201527f4e6f7420417574686f72697a656400000000000000000000000000000000000060448201526064016108ff565b505b60048a5110611458573360009081526020819052604090205460ff161561144e5761144e8a612f25565b611458818b613060565b505b5050505050505050505050565b6000611474888885612631565b9050610b90888288888888886128b9565b604051806080016040528060468152602001614d7a6046913981565b6040517f2d9ad53d0000000000000000000000000000000000000000000000000000000081523060048201526000906001600160a01b03831690632d9ad53d9060240160206040518083038186803b1580156114fc57600080fd5b505afa158015611510573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108789190614686565b6060816001600160a01b031663a0e67e2b6040518163ffffffff1660e01b815260040160006040518083038186803b15801561156f57600080fd5b505afa158015611583573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526108789190810190614550565b6000838152600460209081526040808320546005909252909120546001600160a01b039182169116816116205760405162461bcd60e51b815260206004820152601260248201527f706f64206e6f742072656769737465726564000000000000000000000000000060448201526064016108ff565b6001600160a01b038116156116ac57336001600160a01b038216146116875760405162461bcd60e51b815260206004820152600d60248201527f6d7573742062652061646d696e0000000000000000000000000000000000000060448201526064016108ff565b6001600160a01b0382166000908152602081905260409020805460ff19169055611704565b336001600160a01b038316146117045760405162461bcd60e51b815260206004820152601960248201527f7478206d7573742062652073656e742066726f6d20736166650000000000000060448201526064016108ff565b600254604080517f04f3bcec00000000000000000000000000000000000000000000000000000000815290516000926001600160a01b0316916304f3bcec916004808301926020929190829003018186803b15801561176257600080fd5b505afa158015611776573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061179a9190614253565b60025460405163cfeac6a560e01b8152600481018890529192506000916001600160a01b039091169063cfeac6a59060240160206040518083038186803b1580156117e457600080fd5b505afa1580156117f8573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061181c91906146a3565b6040517f3b3b57de000000000000000000000000000000000000000000000000000000008152600481018290529091506000906001600160a01b03841690633b3b57de9060240160206040518083038186803b15801561187b57600080fd5b505afa15801561188f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906118b39190614253565b9050846001600160a01b0316816001600160a01b0316146119165760405162461bcd60e51b815260206004820152601b60248201527f7361666520616e64206c6162656c206469646e2774206d61746368000000000060448201526064016108ff565b60025460405163043c4ea360e21b81526001600160a01b03909116906310f13a8c90611946908590600401614a99565b600060405180830381600087803b15801561196057600080fd5b505af1158015611974573d6000803e3d6000fd5b505060025460405163043c4ea360e21b81526001600160a01b0390911692506310f13a8c91506119a8908590600401614b09565b600060405180830381600087803b1580156119c257600080fd5b505af11580156119d6573d6000803e3d6000fd5b50506002546040517fd5fa2b0000000000000000000000000000000000000000000000000000000000815260048101869052600060248201526001600160a01b03909116925063d5fa2b009150604401600060405180830381600087803b158015611a4057600080fd5b505af1158015611a54573d6000803e3d6000fd5b50506002546040517fd22057a9000000000000000000000000000000000000000000000000000000008152600481018b9052600060248201526001600160a01b03909116925063d22057a99150604401600060405180830381600087803b158015611abe57600080fd5b505af1158015611ad2573d6000803e3d6000fd5b50505050611adf856114a1565b15611b7f57611aef856000612d35565b611b7f85600260009054906101000a90046001600160a01b03166001600160a01b031663808698536040518163ffffffff1660e01b815260040160206040518083038186803b158015611b4157600080fd5b505afa158015611b55573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611b799190614253565b886132e2565b600088815260056020908152604080832080546001600160a01b0319908116909155600480845282852080549092169091556001600160a01b038916808552600390935281842084905590517fcf00cec900000000000000000000000000000000000000000000000000000000815290810191909152309063cf00cec99060240160006040518083038186803b158015611c1857600080fd5b505afa158015611c2c573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052611c549190810190614550565b60405163b898410d60e01b81529091506001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063b898410d90611ca59084908d9060040161499b565b600060405180830381600087803b158015611cbf57600080fd5b505af1158015611cd3573d6000803e3d6000fd5b505050507fbf40bbc71e7cad18fa06345bce0dcaecb93fb664d0808f5afe28904c1d1b25da89604051611d0891815260200190565b60405180910390a1505050505050505050565b611d23612e54565b6001600160a01b038116611d6b5760405162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b60448201526064016108ff565b600280546001600160a01b0319166001600160a01b0392909216919091179055565b6000828152600560205260409020546001600160a01b03163314611df35760405162461bcd60e51b815260206004820181905260248201527f4d7573742062652061646d696e20746f20736574206d6f64756c65206c6f636b60448201526064016108ff565b6000828152600460209081526040808320546001600160a01b03168352908290529020805460ff19168215151790555050565b6001600160a01b038216611e6e5760405162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b60448201526064016108ff565b6001600160a01b038216301415611eed5760405162461bcd60e51b815260206004820152602160248201527f43616e6e6f74206d69677261746520746f2073616d6520636f6e74726f6c6c6560448201527f720000000000000000000000000000000000000000000000000000000000000060648201526084016108ff565b60405163c3c5a54760e01b81526001600160a01b0383811660048301527f0000000000000000000000000000000000000000000000000000000000000000169063c3c5a5479060240160206040518083038186803b158015611f4e57600080fd5b505afa158015611f62573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611f869190614686565b611fd25760405162461bcd60e51b815260206004820152601960248201527f436f6e74726f6c6c6572206e6f7420726567697374657265640000000000000060448201526064016108ff565b6000838152600560209081526040808320546004909252909120546001600160a01b039182169116338214806120105750336001600160a01b038216145b61205c5760405162461bcd60e51b815260206004820152601360248201527f55736572206e6f7420617574686f72697a65640000000000000000000000000060448201526064016108ff565b600085815260056020908152604080832080546001600160a01b0319908116909155600480845282852080549092169091556001600160a01b038581168552600390935281842093909355517f82786654000000000000000000000000000000000000000000000000000000008152918201879052858116602483015285917f000000000000000000000000000000000000000000000000000000000000000090911690638278665490604401600060405180830381600087803b15801561212357600080fd5b505af1158015612137573d6000803e3d6000fd5b5050505061214682868661353a565b6040517f62067cd1000000000000000000000000000000000000000000000000000000008152600481018790526001600160a01b03848116602483015283811660448301528216906362067cd190606401600060405180830381600087803b1580156121b157600080fd5b505af11580156121c5573d6000803e3d6000fd5b50505050505050505050565b336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016146122495760405162461bcd60e51b815260206004820152600e60248201527f4e6f7420417574686f72697a656400000000000000000000000000000000000060448201526064016108ff565b6001600160a01b0386163014156122d5578051156122b757600160ff168160008151811061227957612279614cd0565b016020015160f81c141561228c576124ff565b600260ff16816000815181106122a4576122a4614cd0565b016020015160f81c14156122b7576124ff565b6001805460ff16151514156122d5576001805460ff191690556124ff565b60005b83518110156110355760008482815181106122f5576122f5614cd0565b60209081029190910181015160008181526004835260408082205460059094529020549092506001600160a01b0391821691168115801561233d57506001600160a01b038816155b1561234b57505050506124ff565b6001600160a01b0389166123e757816001600160a01b03168a6001600160a01b0316148061238a5750806001600160a01b03168a6001600160a01b0316145b8061239d57506001600160a01b038a1630145b6123d85760405162461bcd60e51b815260206004820152600c60248201526b139bc8149d5b195cc814d95d60a21b60448201526064016108ff565b6123e28883613891565b6124e8565b6001600160a01b03881661247e57816001600160a01b03168a6001600160a01b031614806124265750806001600160a01b03168a6001600160a01b0316145b8061243957506001600160a01b038a1630145b6124745760405162461bcd60e51b815260206004820152600c60248201526b139bc8149d5b195cc814d95d60a21b60448201526064016108ff565b6123e28983613a29565b60008381526006602052604090205460ff16156124dd5760405162461bcd60e51b815260206004820152601660248201527f506f64204973205472616e73666572204c6f636b65640000000000000000000060448201526064016108ff565b6124e8898984613cec565b5050506001816124f89190614bce565b90506122d8565b505050505050565b61250f612e54565b6001600160a01b03811661258b5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201527f646472657373000000000000000000000000000000000000000000000000000060648201526084016108ff565b61106e81612eb4565b6040517f2f54bf6e0000000000000000000000000000000000000000000000000000000081526001600160a01b03828116600483015260009190841690632f54bf6e9060240160206040518083038186803b1580156125f257600080fd5b505afa158015612606573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061262a9190614686565b9392505050565b604080518082018252601681527f64656c656761746553657475702861646472657373290000000000000000000060208201529051306024820152600091829160440160408051601f19818403018152908290529161268f91614896565b60405180910390206001600160e01b0319166020820180516001600160e01b03838183161783525050505090506000604051806080016040528060468152602001614d7a60469139868630857f000000000000000000000000000000000000000000000000000000000000000060008060006040516024016127189897969594939291906149f2565b60408051601f19818403018152908290529161273391614896565b60408051918290039091206020830180516001600160e01b03166001600160e01b0319909216919091179052517f1688f0b90000000000000000000000000000000000000000000000000000000081529091506001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001690631688f0b9906127e9907f000000000000000000000000000000000000000000000000000000000000000090859089906004016148b2565b602060405180830381600087803b15801561280357600080fd5b505af1925050508015612833575060408051601f3d908101601f1916820190925261283091810190614253565b60015b6128af573d808015612861576040519150601f19603f3d011682016040523d82523d6000602084013e612866565b606091505b5060405162461bcd60e51b815260206004820152601d60248201527f4372656174652050726f787920576974682044617461204661696c656400000060448201526064016108ff565b925061262a915050565b604080516001808252818301909252600091602082018180368337019050509050600160f81b816000815181106128f2576128f2614cd0565b60200101906001600160f81b031916908160001a9053506040517f9aa0055e0000000000000000000000000000000000000000000000000000000081526000906001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001690639aa0055e90612973908c908690600401614976565b602060405180830381600087803b15801561298d57600080fd5b505af11580156129a1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906129c591906146a3565b9050838114612a165760405162461bcd60e51b815260206004820152601e60248201527f706f64206964206469646e2774206d617463682c2074727920616761696e000060448201526064016108ff565b7fb298a97e1ae845f4ac62f176cde255ccfe5ac42197eae12459c99761bad66a4881898988604051612a4b9493929190614b47565b60405180910390a1604080518281526001600160a01b03891660208201527ffef38cfc44da305e6203142455e0a2b129109e8fd7b40914acff6874f170e3df910160405180910390a1612a9e8830612d35565b6001600160a01b03871615612af8576001600160a01b0388166000908152602081905260409020805460ff19166001179055600081815260056020526040902080546001600160a01b0319166001600160a01b0389161790555b600081815260046020818152604080842080546001600160a01b0319166001600160a01b038e8116918217909255808652600390935281852086905560025491517f98eed3e90000000000000000000000000000000000000000000000000000000081529384018b9052602484019290925233604484015216906398eed3e990606401602060405180830381600087803b158015612b9557600080fd5b505af1158015612ba9573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612bcd9190614253565b9050612bda898288613e75565b60025460405163cfeac6a560e01b8152600481018990526000916001600160a01b03169063cfeac6a59060240160206040518083038186803b158015612c1f57600080fd5b505afa158015612c33573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612c5791906146a3565b60025460405163043c4ea360e21b81529192506001600160a01b0316906310f13a8c90612c8a9084908990600401614a5b565b600060405180830381600087803b158015612ca457600080fd5b505af1158015612cb8573d6000803e3d6000fd5b50506002546001600160a01b031691506310f13a8c905082612cd986613ee8565b6040518363ffffffff1660e01b8152600401612cf6929190614ade565b600060405180830381600087803b158015612d1057600080fd5b505af1158015612d24573d6000803e3d6000fd5b505050505050505050505050505050565b6040516001600160a01b038216602482015260009060440160408051601f198184030181529181526020820180516001600160e01b031663e19a9dd960e01b1790525163468721a760e01b81529091506000906001600160a01b0385169063468721a790612dad9087908590879082906004016148e4565b602060405180830381600087803b158015612dc757600080fd5b505af1158015612ddb573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612dff9190614686565b905080612e4e5760405162461bcd60e51b815260206004820152601360248201527f436f756c64206e6f74207365742067756172640000000000000000000000000060448201526064016108ff565b50505050565b6001546001600160a01b036101009091041633146113335760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016108ff565b600180546001600160a01b038381166101008181027fffffffffffffffffffffff0000000000000000000000000000000000000000ff85161790945560405193909204169182907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b63610b592560e01b612f3682614c11565b6001600160e01b0319161415612f8e5760405162461bcd60e51b815260206004820152601560248201527f43616e6e6f7420456e61626c65204d6f64756c6573000000000000000000000060448201526064016108ff565b637004e7ef60e11b612f9f82614c11565b6001600160e01b0319161415612ff75760405162461bcd60e51b815260206004820152601660248201527f43616e6e6f742044697361626c65204d6f64756c65730000000000000000000060448201526064016108ff565b63e19a9dd960e01b61300882614c11565b6001600160e01b031916141561106e5760405162461bcd60e51b815260206004820152601360248201527f43616e6e6f74204368616e67652047756172640000000000000000000000000060448201526064016108ff565b630d582f1360e01b61307182614c11565b6001600160e01b03191614156131115760248101516001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000166394d008ef82856130bf61400a565b6040518463ffffffff1660e01b81526004016130dd9392919061493b565b600060405180830381600087803b1580156130f757600080fd5b505af115801561310b573d6000803e3d6000fd5b50505050505b63f8dc5dd960e01b61312282614c11565b6001600160e01b03191614156131c75760448101516001805460ff191681179055604051632770a7eb60e21b81526001600160a01b038281166004830152602482018590527f00000000000000000000000000000000000000000000000000000000000000001690639dc29fac90604401600060405180830381600087803b1580156131ad57600080fd5b505af11580156131c1573d6000803e3d6000fd5b50505050505b63e318b52b60e01b6131d882614c11565b6001600160e01b03191614156105b357604481015160648201516001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000166394d008ef828661322b61400a565b6040518463ffffffff1660e01b81526004016132499392919061493b565b600060405180830381600087803b15801561326357600080fd5b505af1158015613277573d6000803e3d6000fd5b50506001805460ff1916811790555061328d9050565b604051632770a7eb60e21b81526001600160a01b038381166004830152602482018690527f00000000000000000000000000000000000000000000000000000000000000001690639dc29fac90604401610b62565b60405160206024820152600060448201819052849160640160408051601f198184030181529181526020820180516001600160e01b031663c47f002760e01b1790525163468721a760e01b81529091506001600160a01b0383169063468721a790613358908790600090869082906004016148e4565b602060405180830381600087803b15801561337257600080fd5b505af1158015613386573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906133aa9190614686565b506040516000602482018190529060440160408051601f198184030181529181526020820180516001600160e01b031663e19a9dd960e01b1790525163468721a760e01b81529091506001600160a01b0384169063468721a790613419908990600090869082906004016148e4565b602060405180830381600087803b15801561343357600080fd5b505af1158015613447573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061346b9190614686565b506040516001600160a01b038516602482015230604482015260009060640160408051601f198184030181529181526020820180516001600160e01b0316637004e7ef60e11b1790525163468721a760e01b81529091506001600160a01b0385169063468721a7906134e8908a90600090869082906004016148e4565b602060405180830381600087803b15801561350257600080fd5b505af1158015613516573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b909190614686565b6040516001600160a01b038316602482015260009060440160408051601f198184030181529181526020820180516001600160e01b031663610b592560e01b1790525163468721a760e01b81529091506000906001600160a01b0386169063468721a7906135b29088908590879082906004016148e4565b602060405180830381600087803b1580156135cc57600080fd5b505af11580156135e0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906136049190614686565b9050806136535760405162461bcd60e51b815260206004820152601a60248201527f4d6967726174696f6e206661696c6564206f6e20656e61626c6500000000000060448201526064016108ff565b6040517fcc2f84520000000000000000000000000000000000000000000000000000000081526001600160a01b038481166004830152600160248301526000919087169063cc2f84529060440160006040518083038186803b1580156136b857600080fd5b505afa1580156136cc573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526136f49190810190614585565b509050306001600160a01b03168160008151811061371457613714614cd0565b60200260200101516001600160a01b0316146137725760405162461bcd60e51b815260206004820152601460248201527f696e636f727265637420707265764d6f64756c6500000000000000000000000060448201526064016108ff565b6040516001600160a01b038516602482015230604482015260009060640160408051601f198184030181529181526020820180516001600160e01b0316637004e7ef60e11b1790525163468721a760e01b81529091506000906001600160a01b0389169063468721a7906137f0908b908590879082906004016148e4565b602060405180830381600087803b15801561380a57600080fd5b505af115801561381e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906138429190614686565b905080610b905760405162461bcd60e51b815260206004820152601b60248201527f4d6967726174696f6e206661696c6564206f6e2064697361626c65000000000060448201526064016108ff565b6000816001600160a01b031663e75235b86040518163ffffffff1660e01b8152600401602060405180830381600087803b1580156138ce57600080fd5b505af11580156138e2573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061390691906146a3565b6040516001600160a01b03851660248201526044810182905290915060009060640160408051601f198184030181529181526020820180516001600160e01b0316630d582f1360e01b1790525163468721a760e01b81529091506000906001600160a01b0385169063468721a7906139889087908590879082906004016148e4565b602060405180830381600087803b1580156139a257600080fd5b505af11580156139b6573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906139da9190614686565b90508061138a5760405162461bcd60e51b815260206004820152601960248201527f4d6f64756c65205472616e73616374696f6e204661696c65640000000000000060448201526064016108ff565b6000816001600160a01b031663e75235b86040518163ffffffff1660e01b8152600401602060405180830381600087803b158015613a6657600080fd5b505af1158015613a7a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613a9e91906146a3565b90506000826001600160a01b031663a0e67e2b6040518163ffffffff1660e01b815260040160006040518083038186803b158015613adb57600080fd5b505afa158015613aef573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052613b179190810190614550565b90506000805b8251811015613ba057856001600160a01b0316838281518110613b4257613b42614cd0565b60200260200101516001600160a01b03161415613b8e5780613b675760019150613b8e565b82613b73600183614bfa565b81518110613b8357613b83614cd0565b602002602001015191505b80613b9881614c75565b915050613b1d565b508260018351613bb09190614bfa565b1015613bc457613bc1600184614bfa565b92505b6040516001600160a01b038083166024830152861660448201526064810184905260009060840160408051601f198184030181529181526020820180516001600160e01b031663f8dc5dd960e01b1790525163468721a760e01b81529091506000906001600160a01b0387169063468721a790613c4b9089908590879082906004016148e4565b602060405180830381600087803b158015613c6557600080fd5b505af1158015613c79573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613c9d9190614686565b9050806110355760405162461bcd60e51b815260206004820152601960248201527f4d6f64756c65205472616e73616374696f6e204661696c65640000000000000060448201526064016108ff565b6000816001600160a01b031663a0e67e2b6040518163ffffffff1660e01b815260040160006040518083038186803b158015613d2757600080fd5b505afa158015613d3b573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052613d639190810190614550565b90506000805b8251811015613dec57856001600160a01b0316838281518110613d8e57613d8e614cd0565b60200260200101516001600160a01b03161415613dda5780613db35760019150613dda565b82613dbf600183614bfa565b81518110613dcf57613dcf614cd0565b602002602001015191505b80613de481614c75565b915050613d69565b506040516001600160a01b03808316602483015280871660448301528516606482015260009060840160408051601f198184030181529181526020820180516001600160e01b031663e318b52b60e01b1790525163468721a760e01b81529091506000906001600160a01b0386169063468721a790613c4b9088908590879082906004016148e4565b600081604051602401613e889190614b34565b60408051601f198184030181529181526020820180516001600160e01b031663c47f002760e01b1790525163468721a760e01b81529091506000906001600160a01b0386169063468721a7906139889087908590879082906004016148e4565b606081613f2857505060408051808201909152600181527f3000000000000000000000000000000000000000000000000000000000000000602082015290565b8160005b8115613f525780613f3c81614c75565b9150613f4b9050600a83614be6565b9150613f2c565b60008167ffffffffffffffff811115613f6d57613f6d614ce6565b6040519080825280601f01601f191660200182016040528015613f97576020820181803683370190505b5090505b841561400257613fac600183614bfa565b9150613fb9600a86614c90565b613fc4906030614bce565b60f81b818381518110613fd957613fd9614cd0565b60200101906001600160f81b031916908160001a905350613ffb600a86614be6565b9450613f9b565b949350505050565b60408051600180825281830190925260609160009190602082018180368337019050509050600260f81b8160008151811061404757614047614cd0565b60200101906001600160f81b031916908160001a905350919050565b803561406e81614cfc565b919050565b600082601f83011261408457600080fd5b8135602061409961409483614baa565b614b79565b80838252828201915082860187848660051b89010111156140b957600080fd5b60005b858110156140e15781356140cf81614cfc565b845292840192908401906001016140bc565b5090979650505050505050565b600082601f8301126140ff57600080fd5b8151602061410f61409483614baa565b80838252828201915082860187848660051b890101111561412f57600080fd5b60005b858110156140e157815161414581614cfc565b84529284019290840190600101614132565b600082601f83011261416857600080fd5b8135602061417861409483614baa565b80838252828201915082860187848660051b890101111561419857600080fd5b60005b858110156140e15781358452928401929084019060010161419b565b600082601f8301126141c857600080fd5b813567ffffffffffffffff8111156141e2576141e2614ce6565b6141f5601f8201601f1916602001614b79565b81815284602083860101111561420a57600080fd5b816020850160208301376000918101602001919091529392505050565b80356002811061406e57600080fd5b60006020828403121561424857600080fd5b813561262a81614cfc565b60006020828403121561426557600080fd5b815161262a81614cfc565b6000806040838503121561428357600080fd5b823561428e81614cfc565b9150602083013561429e81614cfc565b809150509250929050565b60008060008060008060c087890312156142c257600080fd5b86356142cd81614cfc565b955060208701356142dd81614cfc565b945060408701356142ed81614cfc565b9350606087013567ffffffffffffffff8082111561430a57600080fd5b6143168a838b01614157565b9450608089013591508082111561432c57600080fd5b6143388a838b01614157565b935060a089013591508082111561434e57600080fd5b5061435b89828a016141b7565b9150509295509295509295565b60008060008060008060c0878903121561438157600080fd5b863561438c81614cfc565b9550602087013561439c81614cfc565b945060408701359350606087013567ffffffffffffffff808211156143c057600080fd5b6143cc8a838b016141b7565b94506080890135935060a089013591508082111561434e57600080fd5b60008060008060008060008060008060006101608c8e03121561440b57600080fd5b6144148c614063565b9a5060208c0135995067ffffffffffffffff8060408e0135111561443757600080fd5b6144478e60408f01358f016141b7565b995061445560608e01614227565b985060808d0135975060a08d0135965060c08d0135955061447860e08e01614063565b94506144876101008e01614063565b9350806101208e0135111561449b57600080fd5b506144ad8d6101208e01358e016141b7565b91506144bc6101408d01614063565b90509295989b509295989b9093969950565b600080600080606085870312156144e457600080fd5b843567ffffffffffffffff808211156144fc57600080fd5b818701915087601f83011261451057600080fd5b81358181111561451f57600080fd5b8860208260051b850101111561453457600080fd5b6020928301999098509187013596604001359550909350505050565b60006020828403121561456257600080fd5b815167ffffffffffffffff81111561457957600080fd5b614002848285016140ee565b6000806040838503121561459857600080fd5b825167ffffffffffffffff8111156145af57600080fd5b6145bb858286016140ee565b925050602083015161429e81614cfc565b600080600080600080600060e0888a0312156145e757600080fd5b873567ffffffffffffffff808211156145ff57600080fd5b61460b8b838c01614073565b985060208a0135975060408a0135915061462482614cfc565b909550606089013594506080890135908082111561464157600080fd5b61464d8b838c016141b7565b945060a08a0135935060c08a013591508082111561466a57600080fd5b506146778a828b016141b7565b91505092959891949750929550565b60006020828403121561469857600080fd5b815161262a81614d11565b6000602082840312156146b557600080fd5b5051919050565b600080604083850312156146cf57600080fd5b82359150602083013561429e81614d11565b6000602082840312156146f357600080fd5b81356001600160e01b03198116811461262a57600080fd5b60006020828403121561471d57600080fd5b5035919050565b6000806040838503121561473757600080fd5b82359150602083013561429e81614cfc565b60008060006060848603121561475e57600080fd5b83359250602084013561477081614cfc565b9150604084013561478081614cfc565b809150509250925092565b6000806000606084860312156147a057600080fd5b83359250602084013567ffffffffffffffff808211156147bf57600080fd5b6147cb87838801614073565b935060408601359150808211156147e157600080fd5b506147ee86828701614073565b9150509250925092565b60008060006060848603121561480d57600080fd5b8335925060208401359150604084013561478081614cfc565b600081518084526020808501945080840160005b8381101561485f5781516001600160a01b03168752958201959082019060010161483a565b509495945050505050565b60008151808452614882816020860160208601614c49565b601f01601f19169290920160200192915050565b600082516148a8818460208701614c49565b9190910192915050565b6001600160a01b03841681526060602082015260006148d4606083018561486a565b9050826040830152949350505050565b6001600160a01b038516815283602082015260806040820152600061490c608083018561486a565b90506002831061492c57634e487b7160e01b600052602160045260246000fd5b82606083015295945050505050565b6001600160a01b0384168152826020820152606060408201526000610da6606083018461486a565b60208152600061262a6020830184614826565b6040815260006149896040830185614826565b8281036020840152610da6818561486a565b6040815260006149ae6040830185614826565b90508260208301529392505050565b6060815260006149d06060830186614826565b84602084015282810360408401526149e8818561486a565b9695505050505050565b6000610100808352614a068184018c614826565b90508960208401526001600160a01b03808a1660408501528382036060850152614a30828a61486a565b978116608085015295861660a0840152505060c081019290925290911660e090910152949350505050565b828152606060208201526000614a8760608301600681526530bb30ba30b960d11b602082015260400190565b8281036040840152610da6818561486a565b818152606060208201526000614ac560608301600681526530bb30ba30b960d11b602082015260400190565b8281036040840152600081526020810191505092915050565b828152606060208201526000614a876060830160058152641c1bd9125960da1b602082015260400190565b818152606060208201526000614ac56060830160058152641c1bd9125960da1b602082015260400190565b60208152600061262a602083018461486a565b84815260006001600160a01b038086166020840152808516604084015250608060608301526149e8608083018461486a565b604051601f8201601f1916810167ffffffffffffffff81118282101715614ba257614ba2614ce6565b604052919050565b600067ffffffffffffffff821115614bc457614bc4614ce6565b5060051b60200190565b60008219821115614be157614be1614ca4565b500190565b600082614bf557614bf5614cba565b500490565b600082821015614c0c57614c0c614ca4565b500390565b6000815160208301516001600160e01b031980821693506004831015614c415780818460040360031b1b83161693505b505050919050565b60005b83811015614c64578181015183820152602001614c4c565b83811115612e4e5750506000910152565b6000600019821415614c8957614c89614ca4565b5060010190565b600082614c9f57614c9f614cba565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b038116811461106e57600080fd5b801515811461106e57600080fdfe657865635472616e73616374696f6e28616464726573732c75696e743235362c62797465732c75696e74382c75696e743235362c75696e743235362c75696e743235362c616464726573732c616464726573732c627974657329736574757028616464726573735b5d2c75696e743235362c616464726573732c62797465732c616464726573732c616464726573732c75696e743235362c6164647265737329a264697066735822122085553cca2517c1a743cea40c8b66968899ae115b4a9eec97cce0375a1d31780564736f6c63430008070033",
  "devdoc": {
    "kind": "dev",
    "methods": {
      "beforeTokenTransfer(address,address,address,uint256[],uint256[],bytes)": {
        "params": {
          "data": "Passes a flag for an initial creation event",
          "from": "The address sending the membership token",
          "ids": "An array of membership token ids to be transfered",
          "operator": "The address that initiated the action",
          "to": "The address recieveing the membership token"
        }
      },
      "checkTransaction(address,uint256,bytes,uint8,uint256,uint256,uint256,address,address,bytes,address)": {
        "details": "This will be called by the safe at execution time time _param to Destination address of Safe transaction. _param value Ether value of Safe transaction.",
        "params": {
          "data": "Data payload of Safe transaction. _param operation Operation type of Safe transaction. _param safeTxGas Gas that should be used for the Safe transaction. _param baseGas Gas costs that are independent of the transaction execution(e.g. base transaction fee, signature check, payment of the refund) _param gasPrice Gas price that should be used for the payment calculation. _param gasToken Token address (or 0 if ETH) that is used for the payment. _param refundReceiver Address of receiver of gas payment (or 0 if tx.origin). _param signatures Packed signature data ({bytes32 r}{bytes32 s}{uint8 v}) _param msgSender Account executing safe transaction"
        }
      },
      "constructor": {
        "details": "Will instantiate safe teller with gnosis master and proxy addresses",
        "params": {
          "_controllerRegistry": "The address of the ControllerRegistry contract",
          "_gnosisMasterAddress": "The gnosis master address",
          "_memberToken": "The address of the MemberToken contract",
          "_proxyFactoryAddress": "The proxy factory address"
        }
      },
      "createPod(address[],uint256,address,bytes32,string,uint256,string)": {
        "params": {
          "_admin": "The address of the pod admin",
          "_ensString": "string of pod ens name (i.e.'mypod.pod.xyz')",
          "_label": "label hash of pod name (i.e labelhash('mypod'))",
          "_members": "The addresses of the members of the pod",
          "threshold": "The number of members that are required to sign a transaction"
        }
      },
      "createPodWithSafe(address,address,bytes32,string,uint256,string)": {
        "details": "Used to create a pod with an existing safeWill automatically distribute membership NFTs to current safe members",
        "params": {
          "_admin": "The address of the pod admin",
          "_ensString": "string of pod ens name (i.e.'mypod.pod.xyz')",
          "_label": "label hash of pod name (i.e labelhash('mypod'))",
          "_safe": "The address of existing safe"
        }
      },
      "ejectSafe(uint256,bytes32,address)": {
        "params": {
          "label": "- labelhash of pod ENS name, i.e., `labelhash(\"mypod\")`",
          "podId": "- ID of pod being ejected",
          "previousModule": "- previous module"
        }
      },
      "migratePodController(uint256,address,address)": {
        "details": "This will nullify all pod state on this controllerUpdate state on _newControllerUpdate controller to _newController in Safe and MemberToken",
        "params": {
          "_newController": "The address of the new pod controller",
          "_podId": "The id number of the pod",
          "_prevModule": "The module that points to the orca module in the safe's ModuleManager linked list"
        }
      },
      "owner()": {
        "details": "Returns the address of the current owner."
      },
      "recoverSafe(address[],uint256,uint256)": {
        "params": {
          "members": "The addresses of the members of the pod as it was originally created.",
          "podId": "- Pod ID of safe you are trying to recreate",
          "threshold": "The number of members that are required to sign a transaction"
        }
      },
      "renounceOwnership()": {
        "details": "Leaves the contract without owner. It will not be possible to call `onlyOwner` functions anymore. Can only be called by the current owner. NOTE: Renouncing ownership will leave the contract without an owner, thereby removing any functionality that is only available to the owner."
      },
      "setPodModuleLock(uint256,bool)": {
        "details": "Allows admin to unlock the safe modules and allow them to be edited by members",
        "params": {
          "_isLocked": "true - pod modules cannot be added/removed",
          "_podId": "The id number of the pod"
        }
      },
      "setPodTransferLock(uint256,bool)": {
        "params": {
          "_isTransferLocked": "The address of the new pod admin",
          "_podId": "The id number of the pod"
        }
      },
      "supportsInterface(bytes4)": {
        "details": "Returns true if this contract implements the interface defined by `interfaceId`. See the corresponding https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section] to learn more about how these ids are created. This function call must use less than 30 000 gas."
      },
      "transferOwnership(address)": {
        "details": "Transfers ownership of the contract to a new account (`newOwner`). Can only be called by the current owner."
      },
      "updatePodAdmin(uint256,address)": {
        "params": {
          "_newAdmin": "The address of the new pod admin",
          "_podId": "The id number of the pod"
        }
      },
      "updatePodState(uint256,address,address)": {
        "details": "This is called by another version of controller to migrate a pod to this versionWill only accept calls from registered controllersCan only be called once.",
        "params": {
          "_podAdmin": "The address of the pod admin",
          "_podId": "The id number of the pod",
          "_safeAddress": "The address of the safe"
        }
      }
    },
    "version": 1
  },
  "userdoc": {
    "kind": "user",
    "methods": {
      "ejectSafe(uint256,bytes32,address)": {
        "notice": "Ejects a safe from the Orca ecosystem. Also handles clean up for safes that have already been ejected. Note that the reverse registry entry cannot be cleaned up if the safe has already been ejected."
      },
      "recoverSafe(address[],uint256,uint256)": {
        "notice": "Uses CREATE2 to replicate a given safe on a new network."
      }
    },
    "version": 1
  },
  "storageLayout": {
    "storage": [
      {
        "astId": 2645,
        "contract": "contracts/ControllerV1.sol:ControllerV1",
        "label": "areModulesLocked",
        "offset": 0,
        "slot": "0",
        "type": "t_mapping(t_address,t_bool)"
      },
      {
        "astId": 1715,
        "contract": "contracts/ControllerV1.sol:ControllerV1",
        "label": "BURN_SYNC_FLAG",
        "offset": 0,
        "slot": "1",
        "type": "t_bool"
      },
      {
        "astId": 5752,
        "contract": "contracts/ControllerV1.sol:ControllerV1",
        "label": "_owner",
        "offset": 1,
        "slot": "1",
        "type": "t_address"
      },
      {
        "astId": 144,
        "contract": "contracts/ControllerV1.sol:ControllerV1",
        "label": "podEnsRegistrar",
        "offset": 0,
        "slot": "2",
        "type": "t_contract(IPodEnsRegistrar)3469"
      },
      {
        "astId": 151,
        "contract": "contracts/ControllerV1.sol:ControllerV1",
        "label": "safeToPodId",
        "offset": 0,
        "slot": "3",
        "type": "t_mapping(t_address,t_uint256)"
      },
      {
        "astId": 156,
        "contract": "contracts/ControllerV1.sol:ControllerV1",
        "label": "podIdToSafe",
        "offset": 0,
        "slot": "4",
        "type": "t_mapping(t_uint256,t_address)"
      },
      {
        "astId": 160,
        "contract": "contracts/ControllerV1.sol:ControllerV1",
        "label": "podAdmin",
        "offset": 0,
        "slot": "5",
        "type": "t_mapping(t_uint256,t_address)"
      },
      {
        "astId": 164,
        "contract": "contracts/ControllerV1.sol:ControllerV1",
        "label": "isTransferLocked",
        "offset": 0,
        "slot": "6",
        "type": "t_mapping(t_uint256,t_bool)"
      }
    ],
    "types": {
      "t_address": {
        "encoding": "inplace",
        "label": "address",
        "numberOfBytes": "20"
      },
      "t_bool": {
        "encoding": "inplace",
        "label": "bool",
        "numberOfBytes": "1"
      },
      "t_contract(IPodEnsRegistrar)3469": {
        "encoding": "inplace",
        "label": "contract IPodEnsRegistrar",
        "numberOfBytes": "20"
      },
      "t_mapping(t_address,t_bool)": {
        "encoding": "mapping",
        "key": "t_address",
        "label": "mapping(address => bool)",
        "numberOfBytes": "32",
        "value": "t_bool"
      },
      "t_mapping(t_address,t_uint256)": {
        "encoding": "mapping",
        "key": "t_address",
        "label": "mapping(address => uint256)",
        "numberOfBytes": "32",
        "value": "t_uint256"
      },
      "t_mapping(t_uint256,t_address)": {
        "encoding": "mapping",
        "key": "t_uint256",
        "label": "mapping(uint256 => address)",
        "numberOfBytes": "32",
        "value": "t_address"
      },
      "t_mapping(t_uint256,t_bool)": {
        "encoding": "mapping",
        "key": "t_uint256",
        "label": "mapping(uint256 => bool)",
        "numberOfBytes": "32",
        "value": "t_bool"
      },
      "t_uint256": {
        "encoding": "inplace",
        "label": "uint256",
        "numberOfBytes": "32"
      }
    }
  }
}