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
  • Functions
  • getInitFunction
  • changeDefaults
  • changeIssuanceAddress
  • executeTransfer
  • _processTransferSignature
  • verifyTransfer
  • _verifyTransfer
  • modifyTransferRequirements
  • modifyTransferRequirementsMulti
  • _modifyTransferRequirements
  • modifyKYCData
  • _modifyKYCData
  • modifyKYCDataMulti
  • modifyInvestorFlag
  • _modifyInvestorFlag
  • modifyInvestorFlagMulti
  • modifyKYCDataSigned
  • _modifyKYCDataSigned
  • modifyKYCDataSignedMulti
  • _modifyKYCDataSignedMulti
  • _checkSig
  • _validExpiry
  • _validLockTime
  • _adjustTimes
  • _getKey
  • _getKYCValues
  • _isExistingInvestor
  • _getValuesForTransfer
  • getAllInvestors
  • getInvestors
  • getAllInvestorFlags
  • getInvestorFlag
  • getInvestorFlags
  • _getInvestorFlags
  • getAllKYCData
  • getKYCData
  • _kycData
  • getPermissions
  • getTokensByPartition
  • getAddressBytes32

Was this helpful?

  1. api

Transfer Manager module for core transfer validation functionality (GeneralTransferManager.sol)

PreviousOwnedUpgradeabilityProxy (OwnedUpgradeabilityProxy.sol)NextVotingCheckpointStorage.sol

Last updated 5 years ago

Was this helpful?

View Source:

↗ Extends: ,

GeneralTransferManager

Events

event ChangeIssuanceAddress(address  _issuanceAddress);
event ChangeDefaults(uint64  _defaultCanSendAfter, uint64  _defaultCanReceiveAfter);
event ModifyKYCData(address indexed _investor, address indexed _addedBy, uint64  _canSendAfter, uint64  _canReceiveAfter, uint64  _expiryTime);
event ModifyInvestorFlag(address indexed _investor, uint8 indexed _flag, bool  _value);
event ModifyTransferRequirements(enum GeneralTransferManagerStorage.TransferType indexed _transferType, bool  _fromValidKYC, bool  _toValidKYC, bool  _fromRestricted, bool  _toRestricted);

Functions

Constructor

function (address _securityToken, address _polyToken) public nonpayable Module

Arguments

Name

Type

Description

_securityToken

address

Address of the security token

_polyToken

address

getInitFunction

This function returns the signature of configure function

function getInitFunction() public pure
returns(bytes4)

Arguments

Name

Type

Description

changeDefaults

Used to change the default times used when canSendAfter / canReceiveAfter are zero

function changeDefaults(uint64 _defaultCanSendAfter, uint64 _defaultCanReceiveAfter) public nonpayable withPerm

Arguments

Name

Type

Description

_defaultCanSendAfter

uint64

default for zero canSendAfter

_defaultCanReceiveAfter

uint64

default for zero canReceiveAfter

changeIssuanceAddress

Used to change the Issuance Address

function changeIssuanceAddress(address _issuanceAddress) public nonpayable withPerm

Arguments

Name

Type

Description

_issuanceAddress

address

new address for the issuance

executeTransfer

Default implementation of verifyTransfer used by SecurityToken If the transfer request comes from the STO, it only checks that the investor is in the whitelist If the transfer request comes from a token holder, it checks that: a) Both are on the whitelist b) Seller's sale lockup period is over c) Buyer's purchase lockup is over

function executeTransfer(address _from, address _to, uint256 , bytes _data) external nonpayable
returns(enum ITransferManager.Result)

Arguments

Name

Type

Description

_from

address

Address of the sender

_to

address

Address of the receiver

uint256

_from Address of the sender

_data

bytes

_processTransferSignature

function _processTransferSignature(uint256 _nonce, uint256 _validFrom, uint256 _validTo, bytes _data) internal nonpayable

Arguments

Name

Type

Description

_nonce

uint256

_validFrom

uint256

_validTo

uint256

_data

bytes

verifyTransfer

Default implementation of verifyTransfer used by SecurityToken

function verifyTransfer(address _from, address _to, uint256 , bytes ) public view
returns(enum ITransferManager.Result, bytes32)

Arguments

Name

Type

Description

_from

address

Address of the sender

_to

address

Address of the receiver

uint256

_from Address of the sender

bytes

_from Address of the sender

_verifyTransfer

function _verifyTransfer(address _from, address _to) internal view
returns(enum ITransferManager.Result, bytes32)

Arguments

Name

Type

Description

_from

address

_to

address

modifyTransferRequirements

Modifies the successful checks required for a transfer to be deemed valid.

function modifyTransferRequirements(enum GeneralTransferManagerStorage.TransferType _transferType, bool _fromValidKYC, bool _toValidKYC, bool _fromRestricted, bool _toRestricted) public nonpayable withPerm

Arguments

Name

Type

Description

_transferType

enum GeneralTransferManagerStorage.TransferType

Type of transfer (0 = General, 1 = Issuance, 2 = Redemption)

_fromValidKYC

bool

Defines if KYC is required for the sender

_toValidKYC

bool

Defines if KYC is required for the receiver

_fromRestricted

bool

Defines if transfer time restriction is checked for the sender

_toRestricted

bool

Defines if transfer time restriction is checked for the receiver

modifyTransferRequirementsMulti

Modifies the successful checks required for transfers.

function modifyTransferRequirementsMulti(enum GeneralTransferManagerStorage.TransferType[] _transferTypes, bool[] _fromValidKYC, bool[] _toValidKYC, bool[] _fromRestricted, bool[] _toRestricted) public nonpayable withPerm

Arguments

Name

Type

Description

_transferTypes

enum GeneralTransferManagerStorage.TransferType[]

Types of transfer (0 = General, 1 = Issuance, 2 = Redemption)

_fromValidKYC

bool[]

Defines if KYC is required for the sender

_toValidKYC

bool[]

Defines if KYC is required for the receiver

_fromRestricted

bool[]

Defines if transfer time restriction is checked for the sender

_toRestricted

bool[]

Defines if transfer time restriction is checked for the receiver

_modifyTransferRequirements

function _modifyTransferRequirements(enum GeneralTransferManagerStorage.TransferType _transferType, bool _fromValidKYC, bool _toValidKYC, bool _fromRestricted, bool _toRestricted) internal nonpayable

Arguments

Name

Type

Description

_transferType

enum GeneralTransferManagerStorage.TransferType

_fromValidKYC

bool

_toValidKYC

bool

_fromRestricted

bool

_toRestricted

bool

modifyKYCData

Add or remove KYC info of an investor.

function modifyKYCData(address _investor, uint64 _canSendAfter, uint64 _canReceiveAfter, uint64 _expiryTime) public nonpayable withPerm

Arguments

Name

Type

Description

_investor

address

is the address to whitelist

_canSendAfter

uint64

is the moment when the sale lockup period ends and the investor can freely sell or transfer their tokens

_canReceiveAfter

uint64

is the moment when the purchase lockup period ends and the investor can freely purchase or receive tokens from others

_expiryTime

uint64

is the moment till investors KYC will be validated. After that investor need to do re-KYC

_modifyKYCData

function _modifyKYCData(address _investor, uint64 _canSendAfter, uint64 _canReceiveAfter, uint64 _expiryTime) internal nonpayable

Arguments

Name

Type

Description

_investor

address

_canSendAfter

uint64

_canReceiveAfter

uint64

_expiryTime

uint64

modifyKYCDataMulti

Add or remove KYC info of an investor.

function modifyKYCDataMulti(address[] _investors, uint64[] _canSendAfter, uint64[] _canReceiveAfter, uint64[] _expiryTime) public nonpayable withPerm

Arguments

Name

Type

Description

_investors

address[]

is the address to whitelist

_canSendAfter

uint64[]

is the moment when the sale lockup period ends and the investor can freely sell his tokens

_canReceiveAfter

uint64[]

is the moment when the purchase lockup period ends and the investor can freely purchase tokens from others

_expiryTime

uint64[]

is the moment till investors KYC will be validated. After that investor need to do re-KYC

modifyInvestorFlag

Used to modify investor Flag.

function modifyInvestorFlag(address _investor, uint8 _flag, bool _value) public nonpayable withPerm

Arguments

Name

Type

Description

_investor

address

is the address of the investor.

_flag

uint8

index of flag to change. flag is used to know specifics about investor like isAccredited.

_value

bool

value of the flag. a flag can be true or false.

_modifyInvestorFlag

function _modifyInvestorFlag(address _investor, uint8 _flag, bool _value) internal nonpayable

Arguments

Name

Type

Description

_investor

address

_flag

uint8

_value

bool

modifyInvestorFlagMulti

Used to modify investor data.

function modifyInvestorFlagMulti(address[] _investors, uint8[] _flag, bool[] _value) public nonpayable withPerm

Arguments

Name

Type

Description

_investors

address[]

List of the addresses to modify data about.

_flag

uint8[]

index of flag to change. flag is used to know specifics about investor like isAccredited.

_value

bool[]

value of the flag. a flag can be true or false.

modifyKYCDataSigned

Adds or removes addresses from the whitelist - can be called by anyone with a valid signature

function modifyKYCDataSigned(address _investor, uint256 _canSendAfter, uint256 _canReceiveAfter, uint256 _expiryTime, uint256 _validFrom, uint256 _validTo, uint256 _nonce, bytes _signature) public nonpayable

Arguments

Name

Type

Description

_investor

address

is the address to whitelist

_canSendAfter

uint256

is the moment when the sale lockup period ends and the investor can freely sell his tokens

_canReceiveAfter

uint256

is the moment when the purchase lockup period ends and the investor can freely purchase tokens from others

_expiryTime

uint256

is the moment till investors KYC will be validated. After that investor need to do re-KYC

_validFrom

uint256

is the time that this signature is valid from

_validTo

uint256

is the time that this signature is valid until

_nonce

uint256

nonce of signature (avoid replay attack)

_signature

bytes

issuer signature

_modifyKYCDataSigned

function _modifyKYCDataSigned(address _investor, uint256 _canSendAfter, uint256 _canReceiveAfter, uint256 _expiryTime, uint256 _validFrom, uint256 _validTo, uint256 _nonce, bytes _signature) internal nonpayable
returns(bool)

Arguments

Name

Type

Description

_investor

address

_canSendAfter

uint256

_canReceiveAfter

uint256

_expiryTime

uint256

_validFrom

uint256

_validTo

uint256

_nonce

uint256

_signature

bytes

modifyKYCDataSignedMulti

Adds or removes addresses from the whitelist - can be called by anyone with a valid signature

function modifyKYCDataSignedMulti(address[] _investor, uint256[] _canSendAfter, uint256[] _canReceiveAfter, uint256[] _expiryTime, uint256 _validFrom, uint256 _validTo, uint256 _nonce, bytes _signature) public nonpayable

Arguments

Name

Type

Description

_investor

address[]

is the address to whitelist

_canSendAfter

uint256[]

is the moment when the sale lockup period ends and the investor can freely sell his tokens

_canReceiveAfter

uint256[]

is the moment when the purchase lockup period ends and the investor can freely purchase tokens from others

_expiryTime

uint256[]

is the moment till investors KYC will be validated. After that investor need to do re-KYC

_validFrom

uint256

is the time that this signature is valid from

_validTo

uint256

is the time that this signature is valid until

_nonce

uint256

nonce of signature (avoid replay attack)

_signature

bytes

issuer signature

_modifyKYCDataSignedMulti

function _modifyKYCDataSignedMulti(address[] _investor, uint256[] _canSendAfter, uint256[] _canReceiveAfter, uint256[] _expiryTime, uint256 _validFrom, uint256 _validTo, uint256 _nonce, bytes _signature) internal nonpayable
returns(bool)

Arguments

Name

Type

Description

_investor

address[]

_canSendAfter

uint256[]

_canReceiveAfter

uint256[]

_expiryTime

uint256[]

_validFrom

uint256

_validTo

uint256

_nonce

uint256

_signature

bytes

_checkSig

Used to verify the signature

function _checkSig(bytes32 _hash, bytes _signature, uint256 _nonce) internal nonpayable
returns(bool)

Arguments

Name

Type

Description

_hash

bytes32

_signature

bytes

_nonce

uint256

_validExpiry

Internal function used to check whether the KYC of investor is valid

function _validExpiry(uint64 _expiryTime) internal view
returns(valid bool)

Arguments

Name

Type

Description

_expiryTime

uint64

Expiry time of the investor

_validLockTime

Internal function used to check whether the lock time of investor is valid

function _validLockTime(uint64 _lockTime) internal view
returns(valid bool)

Arguments

Name

Type

Description

_lockTime

uint64

Lock time of the investor

_adjustTimes

Internal function to adjust times using default values

function _adjustTimes(uint64 _canSendAfter, uint64 _canReceiveAfter) internal view
returns(uint64, uint64)

Arguments

Name

Type

Description

_canSendAfter

uint64

_canReceiveAfter

uint64

_getKey

function _getKey(bytes32 _key1, address _key2) internal pure
returns(bytes32)

Arguments

Name

Type

Description

_key1

bytes32

_key2

address

_getKYCValues

function _getKYCValues(address _investor, IDataStore dataStore) internal view
returns(canSendAfter uint64, canReceiveAfter uint64, expiryTime uint64, added uint8)

Arguments

Name

Type

Description

_investor

address

dataStore

IDataStore

_isExistingInvestor

function _isExistingInvestor(address _investor, IDataStore dataStore) internal view
returns(bool)

Arguments

Name

Type

Description

_investor

address

dataStore

IDataStore

_getValuesForTransfer

function _getValuesForTransfer(address _from, address _to) internal view
returns(canSendAfter uint64, fromExpiry uint64, canReceiveAfter uint64, toExpiry uint64)

Arguments

Name

Type

Description

_from

address

_to

address

getAllInvestors

Returns list of all investors

function getAllInvestors() public view
returns(investors address[])

Arguments

Name

Type

Description

getInvestors

Returns list of investors in a range

function getInvestors(uint256 _fromIndex, uint256 _toIndex) public view
returns(investors address[])

Arguments

Name

Type

Description

_fromIndex

uint256

_toIndex

uint256

getAllInvestorFlags

function getAllInvestorFlags() public view
returns(investors address[], flags uint256[])

Arguments

Name

Type

Description

getInvestorFlag

function getInvestorFlag(address _investor, uint8 _flag) public view
returns(value bool)

Arguments

Name

Type

Description

_investor

address

_flag

uint8

getInvestorFlags

function getInvestorFlags(address _investor) public view
returns(flags uint256)

Arguments

Name

Type

Description

_investor

address

_getInvestorFlags

function _getInvestorFlags(address _investor) internal view
returns(flags uint256)

Arguments

Name

Type

Description

_investor

address

getAllKYCData

Returns list of all investors data

function getAllKYCData() external view
returns(investors address[], canSendAfters uint256[], canReceiveAfters uint256[], expiryTimes uint256[])

Arguments

Name

Type

Description

getKYCData

Returns list of specified investors data

function getKYCData(address[] _investors) external view
returns(uint256[], uint256[], uint256[])

Arguments

Name

Type

Description

_investors

address[]

_kycData

function _kycData(address[] _investors) internal view
returns(uint256[], uint256[], uint256[])

Arguments

Name

Type

Description

_investors

address[]

getPermissions

Return the permissions flag that are associated with general trnasfer manager

function getPermissions() public view
returns(bytes32[])

Arguments

Name

Type

Description

getTokensByPartition

return the amount of tokens for a given user as per the partition

function getTokensByPartition(bytes32 _partition, address _tokenHolder, uint256 _additionalBalance) external view
returns(uint256)

Arguments

Name

Type

Description

_partition

bytes32

Identifier

_tokenHolder

address

Whom token amount need to query

_additionalBalance

uint256

It is the _value that transfer during transfer/transferFrom function call

getAddressBytes32

function getAddressBytes32() public view
returns(bytes32)

Arguments

Name

Type

Description

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

⤾ overrides

IModule.getInitFunction
ITransferManager.executeTransfer
ITransferManager.verifyTransfer
IModule.getPermissions
TransferManager.getTokensByPartition
contracts/modules/TransferManager/GTM/GeneralTransferManager.sol
GeneralTransferManagerStorage
TransferManager
(address _securityToken, address _polyToken)
getInitFunction()
changeDefaults(uint64 _defaultCanSendAfter, uint64 _defaultCanReceiveAfter)
changeIssuanceAddress(address _issuanceAddress)
executeTransfer(address _from, address _to, uint256 , bytes _data)
_processTransferSignature(uint256 _nonce, uint256 _validFrom, uint256 _validTo, bytes _data)
verifyTransfer(address _from, address _to, uint256 , bytes )
_verifyTransfer(address _from, address _to)
modifyTransferRequirements(enum GeneralTransferManagerStorage.TransferType _transferType, bool _fromValidKYC, bool _toValidKYC, bool _fromRestricted, bool _toRestricted)
modifyTransferRequirementsMulti(enum GeneralTransferManagerStorage.TransferType[] _transferTypes, bool[] _fromValidKYC, bool[] _toValidKYC, bool[] _fromRestricted, bool[] _toRestricted)
_modifyTransferRequirements(enum GeneralTransferManagerStorage.TransferType _transferType, bool _fromValidKYC, bool _toValidKYC, bool _fromRestricted, bool _toRestricted)
modifyKYCData(address _investor, uint64 _canSendAfter, uint64 _canReceiveAfter, uint64 _expiryTime)
_modifyKYCData(address _investor, uint64 _canSendAfter, uint64 _canReceiveAfter, uint64 _expiryTime)
modifyKYCDataMulti(address[] _investors, uint64[] _canSendAfter, uint64[] _canReceiveAfter, uint64[] _expiryTime)
modifyInvestorFlag(address _investor, uint8 _flag, bool _value)
_modifyInvestorFlag(address _investor, uint8 _flag, bool _value)
modifyInvestorFlagMulti(address[] _investors, uint8[] _flag, bool[] _value)
modifyKYCDataSigned(address _investor, uint256 _canSendAfter, uint256 _canReceiveAfter, uint256 _expiryTime, uint256 _validFrom, uint256 _validTo, uint256 _nonce, bytes _signature)
_modifyKYCDataSigned(address _investor, uint256 _canSendAfter, uint256 _canReceiveAfter, uint256 _expiryTime, uint256 _validFrom, uint256 _validTo, uint256 _nonce, bytes _signature)
modifyKYCDataSignedMulti(address[] _investor, uint256[] _canSendAfter, uint256[] _canReceiveAfter, uint256[] _expiryTime, uint256 _validFrom, uint256 _validTo, uint256 _nonce, bytes _signature)
_modifyKYCDataSignedMulti(address[] _investor, uint256[] _canSendAfter, uint256[] _canReceiveAfter, uint256[] _expiryTime, uint256 _validFrom, uint256 _validTo, uint256 _nonce, bytes _signature)
_checkSig(bytes32 _hash, bytes _signature, uint256 _nonce)
_validExpiry(uint64 _expiryTime)
_validLockTime(uint64 _lockTime)
_adjustTimes(uint64 _canSendAfter, uint64 _canReceiveAfter)
_getKey(bytes32 _key1, address _key2)
_getKYCValues(address _investor, IDataStore dataStore)
_isExistingInvestor(address _investor, IDataStore dataStore)
_getValuesForTransfer(address _from, address _to)
getAllInvestors()
getInvestors(uint256 _fromIndex, uint256 _toIndex)
getAllInvestorFlags()
getInvestorFlag(address _investor, uint8 _flag)
getInvestorFlags(address _investor)
_getInvestorFlags(address _investor)
getAllKYCData()
getKYCData(address[] _investors)
_kycData(address[] _investors)
getPermissions()
getTokensByPartition(bytes32 _partition, address _tokenHolder, uint256 _additionalBalance)
getAddressBytes32()