Polymath
master
master
  • README
  • api
    • Proxy (Proxy.sol)
    • Base abstract contract to be extended by all STO modules (STO.sol)
    • OwnedUpgradeabilityProxy (OwnedUpgradeabilityProxy.sol)
    • Transfer Manager module for core transfer validation functionality (GeneralTransferManager.sol)
    • VotingCheckpointStorage.sol
    • PLCRVotingCheckpoint.sol
    • Factory for deploying VestingEscrowWallet module (VestingEscrowWalletFactory.sol)
    • Helper library use to compare or validate the semantic versions (VersionUtils.sol)
    • Interface to be implemented by all Wallet modules (Wallet.sol)
    • Factory for deploying CappedSTO module (CappedSTOFactory.sol)
    • Checkpoint module for issuing ERC20 dividends (ERC20DividendCheckpoint.sol)
    • Interface to be implemented by all Transfer Manager modules (ITransferManager.sol)
    • StableOracle.sol
    • VolumeRestrictionTM.sol
    • SecurityTokenRegistryProxy (SecurityTokenRegistryProxy.sol)
    • PreSaleSTO module Proxy (PreSaleSTOProxy.sol)
    • DataStoreProxy Proxy (DataStoreProxy.sol)
    • Proxy for deploying SecurityToken instances (STFactory.sol)
    • Ownable (IOwnable.sol)
    • Checkpoint module for issuing ether dividends (DividendCheckpoint.sol)
    • CountTransferManager module Proxy (BlacklistTransferManagerProxy.sol)
    • Security Token contract (mock) (MockSTGetter.sol)
    • Permission Manager module for core permissioning functionality (GeneralPermissionManager.sol)
    • Contract used to store layout for the CountTransferManager storage (CountTransferManagerStorage.sol)
    • DummySTO module Proxy (DummySTOProxy.sol)
    • Transfer Manager module for limiting percentage of token supply a single address can hold (Percentag
    • Helps contracts guard against reentrancy attacks. (ReentrancyGuard.sol)
    • Factory for deploying EtherDividendCheckpoint module (ScheduledCheckpointFactory.sol)
    • Interface that every module factory contract should implement (IModuleFactory.sol)
    • Factory for deploying GeneralTransferManager module (TrackedRedemptionFactory.sol)
    • SafeMath (SafeMath.sol)
    • USDTiered STO module Proxy (SecurityTokenProxy.sol)
    • USDTiered STO module Proxy (USDTieredSTOProxy.sol)
    • IOracle.sol
    • ManualApprovalTransferManager module Proxy (ManualApprovalTransferManagerProxy.sol)
    • Interface to be implemented by all permission manager modules (IPermissionManager.sol)
    • Factory for deploying PreSaleSTO module (PreSaleSTOFactory.sol)
    • MockPolyOracle.sol
    • Transfer Manager module for verifing transations with a signed message (SignedTransferManager.sol)
    • DataStoreFactory.sol
    • OraclizeAddrResolverI.sol
    • PolyTokenFaucet.sol
    • Registry contract for issuers to register their security tokens (MockModuleRegistry.sol)
    • VolumeRestrictionLib.sol
    • Contract used to store layout for the PercentageTransferManager storage (PercentageTransferManagerSt
    • Transfer Manager for limiting maximum number of token holders (CountTransferManager.sol)
    • ModuleRegistryProxy (ModuleRegistryProxy.sol)
    • Voting module for governance (WeightedVoteCheckpointProxy.sol)
    • Factory for deploying BlacklistTransferManager module (BlacklistTransferManagerFactory.sol)
    • Contract used to store layout for the GeneralPermissionManager storage (GeneralPermissionManagerStor
    • CountTransferManager module Proxy (LockUpTransferManagerProxy.sol)
    • Holds the storage variable for the DividendCheckpoint modules (i.e ERC20, Ether) (DividendCheckpoint
    • Factory for deploying DummySTO module (DummySTOFactory.sol)
    • IERC1644.sol
    • Core functionality for registry upgradability (PolymathRegistry.sol)
    • Utility contract to allow owner to retreive any ERC20 sent to the contract (ReclaimTokens.sol)
    • SecurityTokenMock.sol
    • Factory for deploying CappedSTO module (USDTieredSTOFactory.sol)
    • Factory for deploying ManualApprovalTransferManager module (ManualApprovalTransferManagerFactory.sol
    • IERC1643.sol
    • Transfer Manager module for core transfer validation functionality (EtherDividendCheckpointProxy.sol
    • solcChecker.sol
    • It holds the storage variables related to ERC20DividendCheckpoint module (ERC20DividendCheckpointSto
    • Interface for all security tokens (ISecurityToken.sol)
    • Base abstract contract to be implemented by all Transfer Manager modules (TransferManager.sol)
    • Storage layout for VolumeRestrictionTM (VolumeRestrictionTMStorage.sol)
    • Security Token contract (mock) (MockSecurityTokenLogic.sol)
    • Transfer Manager module for core transfer validation functionality (GeneralTransferManagerStorage.so
    • IERC1410.sol
    • VotingCheckpoint.sol
    • Factory for deploying WeightedVoteCheckpoint module (WeightedVoteCheckpointFactory.sol)
    • PLCRVotingCheckpointStorage.sol
    • IDataStore.sol
    • TestSTOFactory.sol
    • Ownable (Ownable.sol)
    • UpgradeabilityProxy (UpgradeabilityProxy.sol)
    • Mock Contract Not fit for production environment (MockFactory.sol)
    • Registry contract for issuers to register their security tokens (SecurityTokenRegistryMock.sol)
    • ICheckPermission.sol
    • Factory for deploying LockUpTransferManager module (LockUpTransferManagerFactory.sol)
    • Storage layout for the STO contract (STOStorage.sol)
    • Interface for the Polymath Security Token Registry contract (ISecurityTokenRegistry.sol)
    • Mock Contract Not fit for production environment (MockWrongTypeFactory.sol)
    • Transfer Manager module for core transfer validation functionality (KYCTransferManager.sol)
    • Factory for deploying EtherDividendCheckpoint module (EtherDividendCheckpointFactory.sol)
    • functionSigClash2.sol
    • Standard Interface of ERC1594 (IERC1594.sol)
    • TokenLib.sol
    • MakerDAOOracle.sol
    • Interface that any module contract should implement (Module.sol)
    • Interface that any module factory contract should implement (ModuleFactory.sol)
    • STGetter.sol
    • Interface to be implemented by upgradable token factories (IUpgradableTokenFactory.sol)
    • ERC20 interface (IERC20.sol)
    • KYCTransferManagerFactory.sol
    • Checkpoint module for issuing ether dividends (EtherDividendCheckpoint.sol)
    • functionSigClash1.sol
    • Wallet for core vesting escrow functionality (VestingEscrowWalletStorage.sol)
    • Interface for managing polymath feature switches (IFeatureRegistry.sol)
    • Encoder.sol
    • STRGetter.sol
    • OraclizeI.sol
    • Contract used to store layout for the CappedSTO storage (CappedSTOStorage.sol)
    • LockUpTransferManager.sol
    • Checkpoint module for token weighted vote (WeightedVoteCheckpoint.sol)
    • Registry contract to store registered modules (ModuleRegistry.sol)
    • Factory for deploying upgradable modules (UpgradableModuleFactory.sol)
    • Utility contract to allow pausing and unpausing of certain functions (Pausable.sol)
    • CountTransferManager module Proxy (CountTransferManagerProxy.sol)
    • Math (Math.sol)
    • IPolymathRegistry.sol
    • MockOracle.sol
    • Transfer Manager module for manually approving transactions between accounts (ManualApprovalTransfer
    • DecimalMath.sol
    • STO module for standard capped crowdsale (USDTieredSTO.sol)
    • Security Token contract (SecurityToken.sol)
    • PercentageTransferManager module Proxy (PercentageTransferManagerProxy.sol)
    • Interface to be implemented by all checkpoint modules (IBurn.sol)
    • Burn module for burning tokens and keeping track of burnt amounts (MockRedemptionManager.sol)
    • GeneralPermissionManager module Proxy (GeneralPermissionManagerProxy.sol)
    • STO module for sample implementation of a different crowdsale module (DummySTO.sol)
    • Factory for deploying CountTransferManager module (CountTransferManagerFactory.sol)
    • Interface to be implemented by all STO modules (ISTO.sol)
    • Data store contract that stores data for all the modules in a central contract. (DataStore.sol)
    • Transfer Manager module to automate blacklist and restrict transfers (BlacklistTransferManager.sol)
    • Contract used to store layout for the PreSaleSTO storage (PreSaleSTOStorage.sol)
    • Migrations.sol
    • Contract used to store layout for the CountTransferManager storage (BlacklistTransferManagerStorage.
    • STO module for private presales (PreSaleSTO.sol)
    • DataStoreStorage.sol
    • Storage layout for the ISTO contract (ISTOStorage.sol)
    • Registry contract for issuers to register their tickers and security tokens (SecurityTokenRegistry.s
    • Factory for deploying SignedTransferManager module (SignedTransferManagerFactory.sol)
    • Transfer Manager module for core transfer validation functionality (ERC20DividendCheckpointProxy.sol
    • Burn module for burning tokens and keeping track of burnt amounts (ScheduledCheckpoint.sol)
    • ERC20 interface (IPoly.sol)
    • Transfer Manager module for core transfer validation functionality (VolumeRestrictionTMProxy.sol)
    • Contract used to store layout for the DummySTO storage (DummySTOStorage.sol)
    • Burn module for burning tokens and keeping track of burnt amounts (TrackedRedemption.sol)
    • Interface that every module contract should implement (IModule.sol)
    • Contract used to store layout for the ManualApprovalTransferManager storage (ManualApprovalTransferM
    • Elliptic curve signature operations (ECDSA.sol)
    • Factory for deploying PercentageTransferManager module (PercentageTransferManagerFactory.sol)
    • Transfer Manager module for core transfer validation functionality (GeneralTransferManagerProxy.sol)
    • Utility contract for reusable code (Util.sol)
    • SecurityTokenStorage.sol
    • Contract used to store layout for the USDTieredSTO storage (USDTieredSTOStorage.sol)
    • Factory for deploying GeneralPermissionManager module (GeneralPermissionManagerFactory.sol)
    • Address.sol
    • StatusCodes.sol
    • Standard ERC20 token
    • Voting module for governance (PLCRVotingCheckpointProxy.sol)
    • CBOR.sol
    • Registry for managing polymath feature switches (FeatureRegistry.sol)
    • WeightedVoteCheckpointStorage.sol
    • Interface for the Polymath Module Registry contract (IModuleRegistry.sol)
    • Interface for security token proxy deployment (ISTFactory.sol)
    • Registry contract for issuers to register their security tokens (MockSTRGetter.sol)
    • Buffer.sol
    • BokkyPooBahsDateTimeLibrary.sol
    • Mock Contract Not fit for production environment (MockBurnFactory.sol)
    • Wallet for core vesting escrow functionality (LockUpTransferManagerStorage.sol)
    • Factory for deploying VolumeRestrictionTM module (VolumeRestrictionTMFactory.sol)
    • usingOraclize.sol
    • STO module for standard capped crowdsale (CappedSTO.sol)
    • Interface to MakerDAO Medianizer contract (IMedianizer.sol)
    • Interface to be implemented by all checkpoint modules (ICheckpoint.sol)
    • Factory for deploying ERC20DividendCheckpoint module (ERC20DividendCheckpointFactory.sol)
    • Factory for deploying GeneralTransferManager module (GeneralTransferManagerFactory.sol)
    • Escrow wallet module for vesting functionality (VestingEscrowWalletProxy.sol)
    • OZStorage.sol
    • Wallet for core vesting escrow functionality (VestingEscrowWallet.sol)
    • EternalStorage.sol
    • Factory for deploying PLCRVotingCheckpoint module (PLCRVotingCheckpointFactory.sol)
    • IVoting.sol
    • Transfer Manager for limiting maximum number of token holders (MockCountTransferManager.sol)
    • CappedSTO module Proxy (CappedSTOProxy.sol)
    • Storage for Module contract (ModuleStorage.sol)
  • wiki
    • Dividend-Module
    • Transfer-manager-results
    • General Permission Manager
    • Transfer-Feature
    • Voting-Checkpoint-Modules
    • USDTieredSTO
    • Contract-Manager
    • Vesting-Escrow-Wallet
    • General Transfer Manager
    • Permission-Manager
    • Dividends-Manager
    • Manual Approval Transfer Manager
    • Transfer-Ownership
    • Transfer-Manager
    • How-to-Use-the-Investor-Portal
    • Count Transfer Manager
    • VolumeRestrictionTransferManager
    • Time-Travel-(Contract-Testing)
    • Percentage Transfer Manager
    • Prerequisite-Instructions-for-Deploying-and-Setting-Up-the-Polymath-Contracts
    • How to Create and Launch an STO
    • Token-Manager
    • How to set up and use the POLY Faucet
    • Advanced PLCR Voting Checkpoint
    • Welcome to the Polymath Core Wiki
    • Capped STO
    • _Sidebar
    • CLI for Polymath-core
    • Lockup Transfer Manager
    • The-STO-Manager
    • Blacklist Transfer Manager (BTM)
  • misc
    • Multiple Transfer Managers
    • PolyOracle Encrypted URL
    • ethereum_status_codes
    • Flags List
    • Permissions List
Powered by GitBook
On this page
  • Modifiers
  • checkGranularity
  • Functions
  • initialize
  • isModule
  • _onlyModuleOrOwner
  • _isValidPartition
  • _isValidOperator
  • _zeroAddressCheck
  • _isValidTransfer
  • _isValidRedeem
  • _isSignedByOwner
  • _isIssuanceAllowed
  • _onlyController
  • _isAuthorised
  • _onlyOwner
  • _onlyModule
  • addModuleWithLabel
  • _addModuleData
  • addModule
  • archiveModule
  • upgradeModule
  • upgradeToken
  • unarchiveModule
  • removeModule
  • withdrawERC20
  • changeModuleBudget
  • updateTokenDetails
  • changeGranularity
  • changeDataStore
  • changeName
  • changeTreasuryWallet
  • _adjustInvestorCount
  • freezeTransfers
  • unfreezeTransfers
  • _adjustBalanceCheckpoints
  • transfer
  • transferWithData
  • _transferWithData
  • transferFrom
  • transferFromWithData
  • balanceOfByPartition
  • _balanceOfByPartition
  • transferByPartition
  • _transferByPartition
  • _returnPartition
  • authorizeOperator
  • revokeOperator
  • authorizeOperatorByPartition
  • revokeOperatorByPartition
  • operatorTransferByPartition
  • _validateOperatorAndPartition
  • _updateTransfer
  • _executeTransfer
  • freezeIssuance
  • issue
  • _issue
  • issueMulti
  • issueByPartition
  • redeem
  • _redeem
  • redeemByPartition
  • _redeemByPartition
  • operatorRedeemByPartition
  • _checkAndBurn
  • redeemFrom
  • createCheckpoint
  • setController
  • disableController
  • canTransfer
  • canTransferFrom
  • _canTransfer
  • canTransferByPartition
  • setDocument
  • removeDocument
  • isControllable
  • controllerTransfer
  • controllerRedeem
  • _implementation
  • updateFromRegistry
  • owner
  • isOwner
  • transferOwnership
  • _transferOwnership
  • _isSuccess

Was this helpful?

  1. api

Security Token contract (SecurityToken.sol)

PreviousSTO module for standard capped crowdsale (USDTieredSTO.sol)NextPercentageTransferManager module Proxy (PercentageTransferManagerProxy.sol)

Last updated 5 years ago

Was this helpful?

View Source:

↗ Extends: , , , , , , , ↘ Derived Contracts: ,

SecurityToken

SecurityToken is an ERC1400 token with added capabilities:

Events

event ModuleAdded(uint8[]  _types, bytes32 indexed _name, address indexed _moduleFactory, address  _module, uint256  _moduleCost, uint256  _budget, bytes32  _label, bool  _archived);
event ModuleUpgraded(uint8[]  _types, address  _module);
event UpdateTokenDetails(string  _oldDetails, string  _newDetails);
event UpdateTokenName(string  _oldName, string  _newName);
event GranularityChanged(uint256  _oldGranularity, uint256  _newGranularity);
event FreezeIssuance();
event FreezeTransfers(bool  _status);
event CheckpointCreated(uint256 indexed _checkpointId, uint256  _investorLength);
event SetController(address indexed _oldController, address indexed _newController);
event TreasuryWalletChanged(address  _oldTreasuryWallet, address  _newTreasuryWallet);
event DisableController();
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
event TokenUpgraded(uint8  _major, uint8  _minor, uint8  _patch);
event ModuleArchived(uint8[]  _types, address  _module);
event ModuleUnarchived(uint8[]  _types, address  _module);
event ModuleRemoved(uint8[]  _types, address  _module);
event ModuleBudgetChanged(uint8[]  _moduleTypes, address  _module, uint256  _oldBudget, uint256  _budget);

Modifiers

checkGranularity

modifier checkGranularity(uint256 _value) internal

Arguments

Name

Type

Description

_value

uint256

Functions

function () public nonpayable

Arguments

Name

Type

Description

initialize

Initialization function

function initialize(address _getterDelegate) public nonpayable

Arguments

Name

Type

Description

_getterDelegate

address

isModule

Checks if an address is a module of certain type

function isModule(address _module, uint8 _type) public view
returns(bool)

Arguments

Name

Type

Description

_module

address

Address to check

_type

uint8

type to check against

_onlyModuleOrOwner

function _onlyModuleOrOwner(uint8 _type) internal view

Arguments

Name

Type

Description

_type

uint8

_isValidPartition

function _isValidPartition(bytes32 _partition) internal pure

Arguments

Name

Type

Description

_partition

bytes32

_isValidOperator

function _isValidOperator(address _from, address _operator, bytes32 _partition) internal view

Arguments

Name

Type

Description

_from

address

_operator

address

_partition

bytes32

_zeroAddressCheck

function _zeroAddressCheck(address _entity) internal pure

Arguments

Name

Type

Description

_entity

address

_isValidTransfer

function _isValidTransfer(bool _isTransfer) internal pure

Arguments

Name

Type

Description

_isTransfer

bool

_isValidRedeem

function _isValidRedeem(bool _isRedeem) internal pure

Arguments

Name

Type

Description

_isRedeem

bool

_isSignedByOwner

function _isSignedByOwner(bool _signed) internal pure

Arguments

Name

Type

Description

_signed

bool

_isIssuanceAllowed

function _isIssuanceAllowed() internal view

Arguments

Name

Type

Description

_onlyController

function _onlyController() internal view

Arguments

Name

Type

Description

_isAuthorised

function _isAuthorised(bool _authorised) internal pure

Arguments

Name

Type

Description

_authorised

bool

_onlyOwner

Throws if called by any account other than the owner.

function _onlyOwner() internal view

Arguments

Name

Type

Description

_onlyModule

Require msg.sender to be the specified module type

function _onlyModule(uint8 _type) internal view

Arguments

Name

Type

Description

_type

uint8

addModuleWithLabel

Attachs a module to the SecurityToken

function addModuleWithLabel(address _moduleFactory, bytes _data, uint256 _maxCost, uint256 _budget, bytes32 _label, bool _archived) public nonpayable nonReentrant

Arguments

Name

Type

Description

_moduleFactory

address

is the address of the module factory to be added

_data

bytes

is data packed into bytes used to further configure the module (See STO usage)

_maxCost

uint256

max amount of POLY willing to pay to the module.

_budget

uint256

max amount of ongoing POLY willing to assign to the module.

_label

bytes32

custom module label.

_archived

bool

_addModuleData

function _addModuleData(uint8[] _moduleTypes, address _moduleFactory, address _module, uint256 _moduleCost, uint256 _budget, bytes32 _label, bool _archived) internal nonpayable

Arguments

Name

Type

Description

_moduleTypes

uint8[]

_moduleFactory

address

_module

address

_moduleCost

uint256

_budget

uint256

_label

bytes32

_archived

bool

addModule

addModule function will call addModuleWithLabel() with an empty label for backward compatible

function addModule(address _moduleFactory, bytes _data, uint256 _maxCost, uint256 _budget, bool _archived) external nonpayable

Arguments

Name

Type

Description

_moduleFactory

address

_data

bytes

_maxCost

uint256

_budget

uint256

_archived

bool

archiveModule

Archives a module attached to the SecurityToken

function archiveModule(address _module) external nonpayable

Arguments

Name

Type

Description

_module

address

address of module to archive

upgradeModule

Upgrades a module attached to the SecurityToken

function upgradeModule(address _module) external nonpayable

Arguments

Name

Type

Description

_module

address

address of module to archive

upgradeToken

Upgrades security token

function upgradeToken() external nonpayable

Arguments

Name

Type

Description

unarchiveModule

Unarchives a module attached to the SecurityToken

function unarchiveModule(address _module) external nonpayable

Arguments

Name

Type

Description

_module

address

address of module to unarchive

removeModule

Removes a module attached to the SecurityToken

function removeModule(address _module) external nonpayable

Arguments

Name

Type

Description

_module

address

address of module to unarchive

withdrawERC20

Allows the owner to withdraw unspent POLY stored by them on the ST or any ERC20 token.

function withdrawERC20(address _tokenContract, uint256 _value) external nonpayable

Arguments

Name

Type

Description

_tokenContract

address

Address of the ERC20Basic compliance token

_value

uint256

amount of POLY to withdraw

changeModuleBudget

allows owner to increase/decrease POLY approval of one of the modules

function changeModuleBudget(address _module, uint256 _change, bool _increase) external nonpayable

Arguments

Name

Type

Description

_module

address

module address

_change

uint256

change in allowance

_increase

bool

true if budget has to be increased, false if decrease

updateTokenDetails

updates the tokenDetails associated with the token

function updateTokenDetails(string _newTokenDetails) external nonpayable

Arguments

Name

Type

Description

_newTokenDetails

string

New token details

changeGranularity

Allows owner to change token granularity

function changeGranularity(uint256 _granularity) external nonpayable

Arguments

Name

Type

Description

_granularity

uint256

granularity level of the token

changeDataStore

Allows owner to change data store

function changeDataStore(address _dataStore) external nonpayable

Arguments

Name

Type

Description

_dataStore

address

Address of the token data store

changeName

Allows owner to change token name

function changeName(string _name) external nonpayable

Arguments

Name

Type

Description

_name

string

new name of the token

changeTreasuryWallet

Allows to change the treasury wallet address

function changeTreasuryWallet(address _wallet) external nonpayable

Arguments

Name

Type

Description

_wallet

address

Ethereum address of the treasury wallet

_adjustInvestorCount

Keeps track of the number of non-zero token holders

function _adjustInvestorCount(address _from, address _to, uint256 _value) internal nonpayable

Arguments

Name

Type

Description

_from

address

sender of transfer

_to

address

receiver of transfer

_value

uint256

value of transfer

freezeTransfers

freezes transfers

function freezeTransfers() external nonpayable

Arguments

Name

Type

Description

unfreezeTransfers

Unfreeze transfers

function unfreezeTransfers() external nonpayable

Arguments

Name

Type

Description

_adjustBalanceCheckpoints

Internal - adjusts token holder balance at checkpoint before a token transfer

function _adjustBalanceCheckpoints(address _investor) internal nonpayable

Arguments

Name

Type

Description

_investor

address

address of the token holder affected

transfer

Overloaded version of the transfer function

function transfer(address _to, uint256 _value) public nonpayable
returns(success bool)

Returns

bool success

Arguments

Name

Type

Description

_to

address

receiver of transfer

_value

uint256

value of transfer

transferWithData

Transfer restrictions can take many forms and typically involve on-chain rules or whitelists. However for many types of approved transfers, maintaining an on-chain list of approved transfers can be cumbersome and expensive. An alternative is the co-signing approach, where in addition to the token holder approving a token transfer, and authorised entity provides signed data which further validates the transfer.

function transferWithData(address _to, uint256 _value, bytes _data) public nonpayable

Arguments

Name

Type

Description

_to

address

address The address which you want to transfer to

_value

uint256

uint256 the amount of tokens to be transferred

_data

bytes

The bytes _data allows arbitrary data to be submitted alongside the transfer.

for the token contract to interpret or record. This could be signed data authorising the transfer (e.g. a dynamic whitelist) but is flexible enough to accomadate other use-cases. |

_transferWithData

function _transferWithData(address _from, address _to, uint256 _value, bytes _data) internal nonpayable

Arguments

Name

Type

Description

_from

address

_to

address

_value

uint256

_data

bytes

transferFrom

Overloaded version of the transferFrom function

function transferFrom(address _from, address _to, uint256 _value) public nonpayable
returns(bool)

Returns

bool success

Arguments

Name

Type

Description

_from

address

sender of transfer

_to

address

receiver of transfer

_value

uint256

value of transfer

transferFromWithData

Transfer restrictions can take many forms and typically involve on-chain rules or whitelists. However for many types of approved transfers, maintaining an on-chain list of approved transfers can be cumbersome and expensive. An alternative is the co-signing approach, where in addition to the token holder approving a token transfer, and authorised entity provides signed data which further validates the transfer.

function transferFromWithData(address _from, address _to, uint256 _value, bytes _data) public nonpayable

Arguments

Name

Type

Description

_from

address

address The address which you want to send tokens from

_to

address

address The address which you want to transfer to

_value

uint256

uint256 the amount of tokens to be transferred

_data

bytes

The bytes _data allows arbitrary data to be submitted alongside the transfer.

for the token contract to interpret or record. This could be signed data authorising the transfer (e.g. a dynamic whitelist) but is flexible enough to accomadate other use-cases. |

balanceOfByPartition

Get the balance according to the provided partitions

function balanceOfByPartition(bytes32 _partition, address _tokenHolder) public view
returns(uint256)

Returns

Amount of tokens as per the given partitions

Arguments

Name

Type

Description

_partition

bytes32

Partition which differentiate the tokens.

_tokenHolder

address

Whom balance need to queried

_balanceOfByPartition

function _balanceOfByPartition(bytes32 _partition, address _tokenHolder, uint256 _additionalBalance) internal view
returns(partitionBalance uint256)

Arguments

Name

Type

Description

_partition

bytes32

_tokenHolder

address

_additionalBalance

uint256

transferByPartition

Transfers the ownership of tokens from a specified partition from one address to another address

function transferByPartition(bytes32 _partition, address _to, uint256 _value, bytes _data) public nonpayable
returns(bytes32)

Returns

The partition to which the transferred tokens were allocated for the _to address

Arguments

Name

Type

Description

_partition

bytes32

The partition from which to transfer tokens

_to

address

The address to which to transfer tokens to

_value

uint256

The amount of tokens to transfer from _partition

_data

bytes

Additional data attached to the transfer of tokens

_transferByPartition

function _transferByPartition(address _from, address _to, uint256 _value, bytes32 _partition, bytes _data, address _operator, bytes _operatorData) internal nonpayable
returns(toPartition bytes32)

Arguments

Name

Type

Description

_from

address

_to

address

_value

uint256

_partition

bytes32

_data

bytes

_operator

address

_operatorData

bytes

_returnPartition

function _returnPartition(uint256 _beforeBalance, uint256 _afterBalance, uint256 _value) internal pure
returns(toPartition bytes32)

Arguments

Name

Type

Description

_beforeBalance

uint256

_afterBalance

uint256

_value

uint256

authorizeOperator

Authorises an operator for all partitions of msg.sender. NB - Allowing investors to authorize an investor to be an operator of all partitions but it doesn't mean we operator is allowed to transfer the LOCKED partition values. Logic for this restriction is written in operatorTransferByPartition() function.

function authorizeOperator(address _operator) public nonpayable

Arguments

Name

Type

Description

_operator

address

An address which is being authorised.

revokeOperator

Revokes authorisation of an operator previously given for all partitions of msg.sender. NB - Allowing investors to authorize an investor to be an operator of all partitions but it doesn't mean we operator is allowed to transfer the LOCKED partition values. Logic for this restriction is written in operatorTransferByPartition() function.

function revokeOperator(address _operator) public nonpayable

Arguments

Name

Type

Description

_operator

address

An address which is being de-authorised

authorizeOperatorByPartition

Authorises an operator for a given partition of msg.sender

function authorizeOperatorByPartition(bytes32 _partition, address _operator) public nonpayable

Arguments

Name

Type

Description

_partition

bytes32

The partition to which the operator is authorised

_operator

address

An address which is being authorised

revokeOperatorByPartition

Revokes authorisation of an operator previously given for a specified partition of msg.sender

function revokeOperatorByPartition(bytes32 _partition, address _operator) public nonpayable

Arguments

Name

Type

Description

_partition

bytes32

The partition to which the operator is de-authorised

_operator

address

An address which is being de-authorised

operatorTransferByPartition

Transfers the ownership of tokens from a specified partition from one address to another address

function operatorTransferByPartition(bytes32 _partition, address _from, address _to, uint256 _value, bytes _data, bytes _operatorData) external nonpayable
returns(bytes32)

Returns

The partition to which the transferred tokens were allocated for the _to address

Arguments

Name

Type

Description

_partition

bytes32

The partition from which to transfer tokens.

_from

address

The address from which to transfer tokens from

_to

address

The address to which to transfer tokens to

_value

uint256

The amount of tokens to transfer from _partition

_data

bytes

Additional data attached to the transfer of tokens

_operatorData

bytes

Additional data attached to the transfer of tokens by the operator

_validateOperatorAndPartition

function _validateOperatorAndPartition(bytes32 _partition, address _from, address _operator) internal view

Arguments

Name

Type

Description

_partition

bytes32

_from

address

_operator

address

_updateTransfer

Updates internal variables when performing a transfer

function _updateTransfer(address _from, address _to, uint256 _value, bytes _data) internal nonpayable nonReentrant 
returns(verified bool)

Returns

bool success

Arguments

Name

Type

Description

_from

address

sender of transfer

_to

address

receiver of transfer

_value

uint256

value of transfer

_data

bytes

data to indicate validation

_executeTransfer

Validate transfer with TransferManager module if it exists

function _executeTransfer(address _from, address _to, uint256 _value, bytes _data) internal nonpayable checkGranularity 
returns(bool)

Returns

bool

Arguments

Name

Type

Description

_from

address

sender of transfer

_to

address

receiver of transfer

_value

uint256

value of transfer

_data

bytes

data to indicate validation

freezeIssuance

Permanently freeze issuance of this security token.

function freezeIssuance(bytes _signature) external nonpayable

Arguments

Name

Type

Description

_signature

bytes

issue

This function must be called to increase the total supply (Corresponds to mint function of ERC20).

function issue(address _tokenHolder, uint256 _value, bytes _data) public nonpayable

Arguments

Name

Type

Description

_tokenHolder

address

The account that will receive the created tokens (account should be whitelisted or KYCed).

_value

uint256

The amount of tokens need to be issued

_data

bytes

The bytes _data allows arbitrary data to be submitted alongside the transfer.

_issue

function _issue(address _tokenHolder, uint256 _value, bytes _data) internal nonpayable

Arguments

Name

Type

Description

_tokenHolder

address

_value

uint256

_data

bytes

issueMulti

issue new tokens and assigns them to the target _tokenHolder.

function issueMulti(address[] _tokenHolders, uint256[] _values) public nonpayable

Returns

success

Arguments

Name

Type

Description

_tokenHolders

address[]

A list of addresses to whom the minted tokens will be dilivered

_values

uint256[]

A list of number of tokens get minted and transfer to corresponding address of the investor from _tokenHolders[] list

issueByPartition

Increases totalSupply and the corresponding amount of the specified owners partition

function issueByPartition(bytes32 _partition, address _tokenHolder, uint256 _value, bytes _data) external nonpayable

Arguments

Name

Type

Description

_partition

bytes32

The partition to allocate the increase in balance

_tokenHolder

address

The token holder whose balance should be increased

_value

uint256

The amount by which to increase the balance

_data

bytes

Additional data attached to the minting of tokens

redeem

This function redeem an amount of the token of a msg.sender. For doing so msg.sender may incentivize using different ways that could be implemented with in the redeem function definition. But those implementations are out of the scope of the ERC1594.

function redeem(uint256 _value, bytes _data) external nonpayable

Arguments

Name

Type

Description

_value

uint256

The amount of tokens need to be redeemed

_data

bytes

The bytes _data it can be used in the token contract to authenticate the redemption.

_redeem

function _redeem(address _from, uint256 _value, bytes _data) internal nonpayable

Arguments

Name

Type

Description

_from

address

_value

uint256

_data

bytes

redeemByPartition

Decreases totalSupply and the corresponding amount of the specified partition of msg.sender

function redeemByPartition(bytes32 _partition, uint256 _value, bytes _data) external nonpayable

Arguments

Name

Type

Description

_partition

bytes32

The partition to allocate the decrease in balance

_value

uint256

The amount by which to decrease the balance

_data

bytes

Additional data attached to the burning of tokens

_redeemByPartition

function _redeemByPartition(bytes32 _partition, address _from, uint256 _value, address _operator, bytes _data, bytes _operatorData) internal nonpayable

Arguments

Name

Type

Description

_partition

bytes32

_from

address

_value

uint256

_operator

address

_data

bytes

_operatorData

bytes

operatorRedeemByPartition

Decreases totalSupply and the corresponding amount of the specified partition of tokenHolder

function operatorRedeemByPartition(bytes32 _partition, address _tokenHolder, uint256 _value, bytes _data, bytes _operatorData) external nonpayable

Arguments

Name

Type

Description

_partition

bytes32

The partition to allocate the decrease in balance.

_tokenHolder

address

The token holder whose balance should be decreased

_value

uint256

The amount by which to decrease the balance

_data

bytes

Additional data attached to the burning of tokens

_operatorData

bytes

Additional data attached to the transfer of tokens by the operator

_checkAndBurn

function _checkAndBurn(address _from, uint256 _value, bytes _data) internal nonpayable
returns(verified bool)

Arguments

Name

Type

Description

_from

address

_value

uint256

_data

bytes

redeemFrom

This function redeem an amount of the token of a msg.sender. For doing so msg.sender may incentivize using different ways that could be implemented with in the redeem function definition. But those implementations are out of the scope of the ERC1594.

function redeemFrom(address _tokenHolder, uint256 _value, bytes _data) external nonpayable

Arguments

Name

Type

Description

_tokenHolder

address

The account whose tokens gets redeemed.

_value

uint256

The amount of tokens need to be redeemed

_data

bytes

The bytes _data it can be used in the token contract to authenticate the redemption.

createCheckpoint

Creates a checkpoint that can be used to query historical balances / totalSuppy

function createCheckpoint() external nonpayable
returns(uint256)

Returns

uint256

Arguments

Name

Type

Description

setController

Used by the issuer to set the controller addresses

function setController(address _controller) external nonpayable

Arguments

Name

Type

Description

_controller

address

address of the controller

disableController

Used by the issuer to permanently disable controller functionality

function disableController(bytes _signature) external nonpayable

Arguments

Name

Type

Description

_signature

bytes

canTransfer

Transfers of securities may fail for a number of reasons. So this function will used to understand the cause of failure by getting the byte value. Which will be the ESC that follows the EIP 1066. ESC can be mapped with a reson string to understand the failure cause, table of Ethereum status code will always reside off-chain

function canTransfer(address _to, uint256 _value, bytes _data) external view
returns(bytes1, bytes32)

Returns

byte Ethereum status code (ESC)

Arguments

Name

Type

Description

_to

address

address The address which you want to transfer to

_value

uint256

uint256 the amount of tokens to be transferred

_data

bytes

The bytes _data allows arbitrary data to be submitted alongside the transfer.

canTransferFrom

Transfers of securities may fail for a number of reasons. So this function will used to understand the cause of failure by getting the byte value. Which will be the ESC that follows the EIP 1066. ESC can be mapped with a reson string to understand the failure cause, table of Ethereum status code will always reside off-chain

function canTransferFrom(address _from, address _to, uint256 _value, bytes _data) external view
returns(reasonCode bytes1, appCode bytes32)

Returns

byte Ethereum status code (ESC)

Arguments

Name

Type

Description

_from

address

address The address which you want to send tokens from

_to

address

address The address which you want to transfer to

_value

uint256

uint256 the amount of tokens to be transferred

_data

bytes

The bytes _data allows arbitrary data to be submitted alongside the transfer.

_canTransfer

function _canTransfer(address _from, address _to, uint256 _value, bytes _data) internal view
returns(bytes1, bytes32)

Arguments

Name

Type

Description

_from

address

_to

address

_value

uint256

_data

bytes

canTransferByPartition

The standard provides an on-chain function to determine whether a transfer will succeed, and return details indicating the reason if the transfer is not valid.

function canTransferByPartition(address _from, address _to, bytes32 _partition, uint256 _value, bytes _data) external view
returns(reasonCode bytes1, appStatusCode bytes32, toPartition bytes32)

Returns

ESC (Ethereum Status Code) following the EIP-1066 standard

Arguments

Name

Type

Description

_from

address

The address from whom the tokens get transferred.

_to

address

The address to which to transfer tokens to.

_partition

bytes32

The partition from which to transfer tokens

_value

uint256

The amount of tokens to transfer from _partition

_data

bytes

Additional data attached to the transfer of tokens

setDocument

Used to attach a new document to the contract, or update the URI or hash of an existing attached document

function setDocument(bytes32 _name, string _uri, bytes32 _documentHash) external nonpayable

Arguments

Name

Type

Description

_name

bytes32

Name of the document. It should be unique always

_uri

string

Off-chain uri of the document from where it is accessible to investors/advisors to read.

_documentHash

bytes32

hash (of the contents) of the document.

removeDocument

Used to remove an existing document from the contract by giving the name of the document.

function removeDocument(bytes32 _name) external nonpayable

Arguments

Name

Type

Description

_name

bytes32

Name of the document. It should be unique always

isControllable

In order to provide transparency over whether controllerTransfer / controllerRedeem are useable or not isControllable function will be used.

function isControllable() public view
returns(bool)

Returns

bool true when controller address is non-zero otherwise return false.

Arguments

Name

Type

Description

controllerTransfer

This function allows an authorised address to transfer tokens between any two token holders. The transfer must still respect the balances of the token holders (so the transfer must be for at most balanceOf(_from) tokens) and potentially also need to respect other transfer restrictions.

function controllerTransfer(address _from, address _to, uint256 _value, bytes _data, bytes _operatorData) external nonpayable

Arguments

Name

Type

Description

_from

address

Address The address which you want to send tokens from

_to

address

Address The address which you want to transfer to

_value

uint256

uint256 the amount of tokens to be transferred

_data

bytes

data to validate the transfer. (It is not used in this reference implementation

because use of _data parameter is implementation specific). | | _operatorData | bytes | data attached to the transfer by controller to emit in event. (It is more like a reason string for calling this function (aka force transfer) which provides the transparency on-chain). |

controllerRedeem

This function allows an authorised address to redeem tokens for any token holder. The redemption must still respect the balances of the token holder (so the redemption must be for at most balanceOf(_tokenHolder) tokens) and potentially also need to respect other transfer restrictions.

function controllerRedeem(address _tokenHolder, uint256 _value, bytes _data, bytes _operatorData) external nonpayable

Arguments

Name

Type

Description

_tokenHolder

address

The account whose tokens will be redeemed.

_value

uint256

uint256 the amount of tokens need to be redeemed.

_data

bytes

data to validate the transfer. (It is not used in this reference implementation

because use of _data parameter is implementation specific). | | _operatorData | bytes | data attached to the transfer by controller to emit in event. (It is more like a reason string for calling this function (aka force transfer) which provides the transparency on-chain). |

_implementation

function _implementation() internal view
returns(address)

Arguments

Name

Type

Description

updateFromRegistry

function updateFromRegistry() public nonpayable

Arguments

Name

Type

Description

owner

function owner() public view
returns(address)

Returns

the address of the owner.

Arguments

Name

Type

Description

isOwner

function isOwner() public view
returns(bool)

Returns

true if msg.sender is the owner of the contract.

Arguments

Name

Type

Description

transferOwnership

Allows the current owner to transfer control of the contract to a newOwner.

function transferOwnership(address newOwner) external nonpayable

Arguments

Name

Type

Description

newOwner

address

The address to transfer ownership to.

_transferOwnership

Transfers control of the contract to a newOwner.

function _transferOwnership(address newOwner) internal nonpayable

Arguments

Name

Type

Description

newOwner

address

The address to transfer ownership to.

_isSuccess

Check if a status code represents success (ie: 0x*1)

function _isSuccess(bytes1 status) internal pure
returns(successful bool)

Returns

successful A boolean representing if the status code represents success

Arguments

Name

Type

Description

status

bytes1

Binary ERC-1066 status code

⤿ Overridden Implementation(s):

⤿ Overridden Implementation(s):

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

contracts/tokens/SecurityToken.sol
ERC20
ReentrancyGuard
SecurityTokenStorage
IERC1594
IERC1643
IERC1644
IERC1410
Proxy
MockSecurityTokenLogic
SecurityTokenMock
()
SecurityTokenMock.initialize
MockSecurityTokenLogic.addModuleWithLabel
ERC20.transfer
IERC1594.transferWithData
ERC20.transferFrom
IERC1594.transferFromWithData
IERC1410.balanceOfByPartition
IERC1410.transferByPartition
IERC1410.authorizeOperator
IERC1410.revokeOperator
IERC1410.authorizeOperatorByPartition
IERC1410.revokeOperatorByPartition
IERC1410.operatorTransferByPartition
IERC1594.issue
IERC1410.issueByPartition
IERC1594.redeem
IERC1410.redeemByPartition
IERC1410.operatorRedeemByPartition
IERC1594.redeemFrom
IERC1594.canTransfer
IERC1594.canTransferFrom
IERC1410.canTransferByPartition
IERC1643.setDocument
IERC1643.removeDocument
IERC1644.isControllable
IERC1644.controllerTransfer
IERC1644.controllerRedeem
Proxy._implementation
checkGranularity
initialize(address _getterDelegate)
isModule(address _module, uint8 _type)
_onlyModuleOrOwner(uint8 _type)
_isValidPartition(bytes32 _partition)
_isValidOperator(address _from, address _operator, bytes32 _partition)
_zeroAddressCheck(address _entity)
_isValidTransfer(bool _isTransfer)
_isValidRedeem(bool _isRedeem)
_isSignedByOwner(bool _signed)
_isIssuanceAllowed()
_onlyController()
_isAuthorised(bool _authorised)
_onlyOwner()
_onlyModule(uint8 _type)
addModuleWithLabel(address _moduleFactory, bytes _data, uint256 _maxCost, uint256 _budget, bytes32 _label, bool _archived)
_addModuleData(uint8[] _moduleTypes, address _moduleFactory, address _module, uint256 _moduleCost, uint256 _budget, bytes32 _label, bool _archived)
addModule(address _moduleFactory, bytes _data, uint256 _maxCost, uint256 _budget, bool _archived)
archiveModule(address _module)
upgradeModule(address _module)
upgradeToken()
unarchiveModule(address _module)
removeModule(address _module)
withdrawERC20(address _tokenContract, uint256 _value)
changeModuleBudget(address _module, uint256 _change, bool _increase)
updateTokenDetails(string _newTokenDetails)
changeGranularity(uint256 _granularity)
changeDataStore(address _dataStore)
changeName(string _name)
changeTreasuryWallet(address _wallet)
_adjustInvestorCount(address _from, address _to, uint256 _value)
freezeTransfers()
unfreezeTransfers()
_adjustBalanceCheckpoints(address _investor)
transfer(address _to, uint256 _value)
transferWithData(address _to, uint256 _value, bytes _data)
_transferWithData(address _from, address _to, uint256 _value, bytes _data)
transferFrom(address _from, address _to, uint256 _value)
transferFromWithData(address _from, address _to, uint256 _value, bytes _data)
balanceOfByPartition(bytes32 _partition, address _tokenHolder)
_balanceOfByPartition(bytes32 _partition, address _tokenHolder, uint256 _additionalBalance)
transferByPartition(bytes32 _partition, address _to, uint256 _value, bytes _data)
_transferByPartition(address _from, address _to, uint256 _value, bytes32 _partition, bytes _data, address _operator, bytes _operatorData)
_returnPartition(uint256 _beforeBalance, uint256 _afterBalance, uint256 _value)
authorizeOperator(address _operator)
revokeOperator(address _operator)
authorizeOperatorByPartition(bytes32 _partition, address _operator)
revokeOperatorByPartition(bytes32 _partition, address _operator)
operatorTransferByPartition(bytes32 _partition, address _from, address _to, uint256 _value, bytes _data, bytes _operatorData)
_validateOperatorAndPartition(bytes32 _partition, address _from, address _operator)
_updateTransfer(address _from, address _to, uint256 _value, bytes _data)
_executeTransfer(address _from, address _to, uint256 _value, bytes _data)
freezeIssuance(bytes _signature)
issue(address _tokenHolder, uint256 _value, bytes _data)
_issue(address _tokenHolder, uint256 _value, bytes _data)
issueMulti(address[] _tokenHolders, uint256[] _values)
issueByPartition(bytes32 _partition, address _tokenHolder, uint256 _value, bytes _data)
redeem(uint256 _value, bytes _data)
_redeem(address _from, uint256 _value, bytes _data)
redeemByPartition(bytes32 _partition, uint256 _value, bytes _data)
_redeemByPartition(bytes32 _partition, address _from, uint256 _value, address _operator, bytes _data, bytes _operatorData)
operatorRedeemByPartition(bytes32 _partition, address _tokenHolder, uint256 _value, bytes _data, bytes _operatorData)
_checkAndBurn(address _from, uint256 _value, bytes _data)
redeemFrom(address _tokenHolder, uint256 _value, bytes _data)
createCheckpoint()
setController(address _controller)
disableController(bytes _signature)
canTransfer(address _to, uint256 _value, bytes _data)
canTransferFrom(address _from, address _to, uint256 _value, bytes _data)
_canTransfer(address _from, address _to, uint256 _value, bytes _data)
canTransferByPartition(address _from, address _to, bytes32 _partition, uint256 _value, bytes _data)
setDocument(bytes32 _name, string _uri, bytes32 _documentHash)
removeDocument(bytes32 _name)
isControllable()
controllerTransfer(address _from, address _to, uint256 _value, bytes _data, bytes _operatorData)
controllerRedeem(address _tokenHolder, uint256 _value, bytes _data, bytes _operatorData)
_implementation()
updateFromRegistry()
owner()
isOwner()
transferOwnership(address newOwner)
_transferOwnership(address newOwner)
_isSuccess(bytes1 status)