PolyDocs: an open-source tool to create immutable and dynamic documents using IPFS and Polygon smart contracts. Our goal is to De-Risk the web3 space.
Finalist: HackFS 2022
- MetadataURI.sol: Interface for adding Metadata on contract level
- Signable.sol: Interface that allows for signing of terms
- TokenSignable.sol: Interface that allows for signing of token specific terms
- TermReader.sol - Interface for termsreader contracts
- TokenTermReader.sol - Interface for token termsreader contracts
- TermsableBase.sol - Abstract contract that implements the TermReader and Metadata interfaces and provides the base functionality for termsable contracts
- TermsableNoToken.sol - Abstract contract that inherits TermsableBase.sol, implements Signable.sol and provides functionality for acceptance of Terms that are not token specific
- TokenTermsable.sol - Abstract contract that inherits TermsableBase.sol , implements TokenTermReader and TokenSignable interfaces and provides functionality for acceptance of terms that are token specific
- TemplateRegistery - list and ability to vote on the credibility of templates to start to build reputation management
npm install @polydocs/contracts
Once installed, you can use the contracts in the library by importing them:
pragma solidity ^0.8.9;
import "@polydocs/contracts/TermsableNoToken.sol";
contract MyCollectible is ERC721 is TermsableNoToken {
constructor() ERC721("MyCollectible", "MCO") {
}
// Adds terms restrictions while transferring a token
function _transfer(
address from,
address to,
uint256 tokenId
) internal virtual override {
require(_acceptedTerms(to), "Terms not accepted");
super._transfer(from, to, tokenId);
}
// Adds terms restrictions while minting a token
function _safeMint(address _to, uint256 _tokenId) internal override {
require(_acceptedTerms(_to), "Terms not accepted");
super._safeMint(_to, _tokenId);
}
}
Polydocs Contracts is released under the MIT License.# Solidity API
event UpdatedURI(string uri)
Event that is emitted when contract URI is updated.
This event is emitted when contract URI is updated.
Name | Type | Description |
---|---|---|
uri | string | The new contract URI. |
function URI() external view returns (string _uri)
This function is used to return the contract URI
Function to return the contract URI
Name | Type | Description |
---|---|---|
_uri | string | The contract URI |
event AcceptedTerms(address sender, string terms)
Event that is emitted when a terms are accepted.
This event is emitted when a terms are accepted.
Name | Type | Description |
---|---|---|
sender | address | The address that accepted the terms. |
terms | string | The terms that were accepted. |
function termsUrlWithPrefix(string prefix) external view returns (string)
This function returns the terms url with a given prefix.
This function returns the terms url with a given prefix.
Name | Type | Description |
---|---|---|
prefix | string | The prefix to add to the terms url. |
Name | Type | Description |
---|---|---|
[0] | string | The terms url with the prefix. |
function termsUrl() external view returns (string)
This function returns the terms url.
This function returns the terms url.
Name | Type | Description |
---|---|---|
[0] | string | The terms url. |
function acceptTerms(string _newtermsUrl) external
This function is used to accept the terms at certain url
This function is called by a user that wants to accepts terms.
Name | Type | Description |
---|---|---|
_newtermsUrl | string | The url of the terms. |
function acceptTermsFor(address _signer, string _newtermsUrl, bytes _signature) external
This function is used to accept the terms at certain url on behalf of the user (metasigner)
This function is called by a metasigner to accept terms on behalf of the signer that wants to accepts terms.
Name | Type | Description |
---|---|---|
_signer | address | The address of the signer that wants to accept terms. |
_newtermsUrl | string | The url of the terms. |
_signature | bytes | The signature of the signer that wants to accept terms. |
function acceptedTerms(address _address) external view returns (bool)
This function returns whether or not a user has accepted the terms.
This function returns whether or not a user has accepted the terms.
Name | Type | Description |
---|---|---|
_address | address | The address of the user. |
Name | Type | Description |
---|---|---|
[0] | bool | True if the user has accepted the terms, false otherwise. |
event GlobalTermChanged(bytes32 _term, bytes32 _value)
This event is fired when a token term is added.
Event when a new Global term is added to the contract
Name | Type | Description |
---|---|---|
_term | bytes32 | The term being added to the contract |
_value | bytes32 | value of the term added to the contract |
event GlobalRendererChanged(string _renderer)
This event is emitted when the global renderer is updated.
This event is emitted when the global renderer is updated.
Name | Type | Description |
---|---|---|
_renderer | string | The new renderer. |
event GlobalTemplateChanged(string _template)
This event is emitted when the global template is updated.
This event is emitted when the global template is updated.
Name | Type | Description |
---|---|---|
_template | string | The new template. |
function globalTerm(string _term) external view returns (string _value)
This function is used to return the value of the term
Function to return the value of the term
Name | Type | Description |
---|---|---|
_term | string | The term to get |
Name | Type | Description |
---|---|---|
_value | string | The value of the term |
event AcceptedTerms(address sender, uint256 tokenId, string terms)
Event that is emitted when a terms are accepted.
This event is emitted when a terms are accepted by an address for a specific token and terms agreement
Name | Type | Description |
---|---|---|
sender | address | The address that accepted the terms. |
tokenId | uint256 | The token id for which the terms are accepted. |
terms | string | The terms that were accepted. |
function acceptedTerms(address to, uint256 tokenId) external view returns (bool)
This is an external function that returns whether the address has accepted terms for a specific token.
This function returns a boolean value indicating whether the address has accepted terms for a specific token.
Name | Type | Description |
---|---|---|
to | address | The address to check. |
tokenId | uint256 | The token id to check. |
Name | Type | Description |
---|---|---|
[0] | bool | _acceptedTerms(to, tokenId) True if the address has accepted terms for a specific token, false otherwise. |
function acceptTerms(uint256 tokenId, string newtermsUrl) external
This is external function that the user can call to accept specific terms for a specific token.
This function accepts specific terms agreement mentioned on a URL for a specific token.
Name | Type | Description |
---|---|---|
tokenId | uint256 | The token id for which the terms are accepted. |
newtermsUrl | string | The terms that are accepted. |
function acceptTermsFor(address _signer, string _newtermsUrl, uint256 _tokenId, bytes _signature) external
This function is used to accept the terms at certain url on behalf of the user (metasigner) for a specific token.
This function is called by a metasigner to accept terms on behalf of the signer that wants to accepts terms for a specific token. It uses ECDSA to recover the signer from the signature and the hash of the termsurl and checks if they match.
Name | Type | Description |
---|---|---|
_signer | address | The address of the signer that wants to accept terms. |
_newtermsUrl | string | The url of the terms. |
_tokenId | uint256 | The token id for which the terms are accepted. |
_signature | bytes | The signature of the signer that wants to accept terms. |
function termsUrl(uint256 tokenId) external view returns (string)
This is an external function that returns the URL for the agreement for a specific token.
This function returns the URL for the agreement for a specific token with prefix "ipfs://".
function termsUrlWithPrefix(uint256 tokenId, string prefix) external view returns (string)
This is an external function that returns the URL of the agreement for a specific token.
This function returns the URL of the agreement for a specific token.
Name | Type | Description |
---|---|---|
tokenId | uint256 | The token id for which the terms URL is returned. |
prefix | string | The prefix to be added to the URL. |
Name | Type | Description |
---|---|---|
[0] | string | _termsUrlWithPrefix(tokenId, prefix) The URL of the terms agreement for a specific token with a given prefix. |
event TokenTermChanged(bytes32 _term, uint256 _tokenId, bytes32 _value)
Event emitted when a new token term is added.
Event emitted when a new token term is added.
Name | Type | Description |
---|---|---|
_term | bytes32 | The term being added to the contract. |
_tokenId | uint256 | The token id of the token for which the term is being added. |
_value | bytes32 | The value of the term being added to the contract. |
event TokenRendererChanged(uint256 _tokenId, string _renderer)
This event is emitted when the global renderer is updated.
This event is emitted when the global renderer is updated.
Name | Type | Description |
---|---|---|
_tokenId | uint256 | The token id of the token for which the renderer is being updated. |
_renderer | string | The new renderer. |
event TokenTemplateChanged(uint256 _tokenId, string _template)
This event is emitted when the global template is updated.
This event is emitted when the global template is updated.
Name | Type | Description |
---|---|---|
_tokenId | uint256 | The token id of the token for which the template is being updated. |
_template | string | The new template. |
function tokenTerm(string _term, uint256 _tokenId) external view returns (string _value)
This function is used to return the value of the term for a specific token.
This function returns the value of a term given its term for a specific token.
Name | Type | Description |
---|---|---|
_term | string | The term to get |
_tokenId | uint256 | The token id of the token for which the term's value is being returned. |
Name | Type | Description |
---|---|---|
_value | string | The value of the term. |
struct Template {
string name;
string cid;
int256 score;
string MetadataURI;
address owner;
}
struct TemplateRegistry.Template[] templates
Array that stores all the templates
mapping(string => uint256) indexes
Mapping that stores the mapping of template cid to template index
uint256 minfee
Minimum fee to score a template
event TemplateAdded(address owner, uint256 index)
This event is emitted when a template is added to the registry
This event is emitted when a template is added to the registry
Name | Type | Description |
---|---|---|
owner | address | The owner of the template |
index | uint256 | The index of the template in the registry |
function add(struct TemplateRegistry.Template _template) public
This function let's a user add a template to the registry
This function let's a user add a template of type Template structure to the registry and emits the TemplateAdded event.
Name | Type | Description |
---|---|---|
_template | struct TemplateRegistry.Template | The template of type struct Template to add to the registry |
function template(uint256 _index) public view returns (struct TemplateRegistry.Template)
This function returns the template at a certain index
This function returns the template at a certain index
Name | Type | Description |
---|---|---|
_index | uint256 | The index of the template to return |
Name | Type | Description |
---|---|---|
[0] | struct TemplateRegistry.Template | The template of type Template at the given index |
function templatebyCID(string _cid) public view returns (struct TemplateRegistry.Template)
This function returns the template given a cid
This function returns the template given a cid
Name | Type | Description |
---|---|---|
_cid | string | The cid of the template to return |
Name | Type | Description |
---|---|---|
[0] | struct TemplateRegistry.Template | The template of type Template at the given cid |
function count() public view returns (uint256)
This function returns the number of templates in the registry
function indexOf(string _cid) public view returns (uint256)
This function returns the index of a template given a cid
This function returns the index of a template given a cid
Name | Type | Description |
---|---|---|
_cid | string | The cid of the template to return the index of |
Name | Type | Description |
---|---|---|
[0] | uint256 | The index of the template in the registry |
function upvote(string _cid) public payable
This function let's a user upvote a template to increase its reputation score
This is a payable function let's a user upvote a template given it's cid to increase its reputation score This function also checks if the user has paid atleast the minimum fee to score a template
Name | Type | Description |
---|---|---|
_cid | string | The cid of the template to upvote |
function downvote(string _cid) public payable
This function let's a user downvote a template to increase its reputation score
This is a payable function let's a user downvote a template given it's cid to decrease its reputation score This function also checks if the user has paid atleast the minimum fee to score a template
Name | Type | Description |
---|---|---|
_cid | string | The cid of the template to downvote |
function score(string _cid) public view returns (int256)
This function returns the reputation score of a template given a cid
This function returns the reputation score of a template given a cid
Name | Type | Description |
---|---|---|
_cid | string | The cid of the template to return the reputation score of |
Name | Type | Description |
---|---|---|
[0] | int256 | The reputation score of the template |
string _globalRenderer
The default value of the global renderer.
The default value of the global renderer.
string _globalDocTemplate
The default value of the global template.
The default value of the global template.
string _uri
mapping(string => string) _globalTerms
Mapping that store the global terms.
This mapping stores the global terms.
uint256 _lastTermChange
This is the latest block height at which the terms were updated.
This is the latest block height at which the terms were updated. 0 by default.
mapping(address => bool) _metaSigners
Returns whether the address is allowed to accept terms on behalf of the signer.
This function returns whether the address is allowed to accept terms on behalf of the signer.
modifier onlyMetaSigner()
This modifier requires that the msg.sender is either the owner of the contract or an approved metasigner
function addMetaSigner(address _signer) external
Adds a meta signer to the list of signers that can accept terms on behalf of the signer.
This function adds a meta signer to the list of signers that can accept terms on behalf of the signer. This function is only available to the owner of the contract.
Name | Type | Description |
---|---|---|
_signer | address | The address of the signer that can accept terms on behalf of the signer. |
function _addMetaSigner(address _signer) internal
Adds a meta signer to the list of signers that can accept terms on behalf of the signer.
This internal function adds a meta signer to the list of signers that can accept terms on behalf of the signer.
Name | Type | Description |
---|---|---|
_signer | address | The address of the signer that can accept terms on behalf of the signer. |
function removeMetaSigner(address _signer) external
Removes a meta signer from the list of signers that can accept terms on behalf of the signer.
This function removes a meta signer from the list of signers that can accept terms on behalf of the signer. This function is only available to the owner of the contract.
Name | Type | Description |
---|---|---|
_signer | address | The address of the signer that can no longer accept terms on behalf of the signer. |
function _removeMetaSigner(address _signer) internal
Removes a meta signer from the list of signers that can accept terms on behalf of the signer.
This internal function removes a meta signer from the list of signers that can accept terms on behalf of the signer.
Name | Type | Description |
---|---|---|
_signer | address | The address of the signer that can no longer accept terms on behalf of the signer. |
function isMetaSigner(address _signer) public view returns (bool)
Returns whether the address is allowed to accept terms on behalf of the signer.
This function returns whether the address is allowed to accept terms on behalf of the signer.
Name | Type | Description |
---|---|---|
_signer | address | The address of the signer that can accept terms on behalf of the signer. |
Name | Type | Description |
---|---|---|
[0] | bool | Whether the address is allowed to accept terms on behalf of the signer. |
function setGlobalRenderer(string _newRenderer) external
Function to set the Global Renderer.
This function lets the owner of the contract set the global renderer of the terms.
Name | Type | Description |
---|---|---|
_newRenderer | string | The new renderer to use for the terms. |
function _setGlobalRenderer(string _newRenderer) internal
Function to set the Global Renderer.
This internal function sets the global renderer of the terms. It emits the GlobalRendererChanged event when renderer is updated.
Name | Type | Description |
---|---|---|
_newRenderer | string | The new renderer to use for the terms. |
function renderer() public view returns (string)
Function that returns the global renderer.
This function returns the global renderer of the terms.
Name | Type | Description |
---|---|---|
[0] | string | _globalRenderer The global renderer of the terms. |
function setGlobalTemplate(string _newDocTemplate) external
Function to set the Global Document Template.
This function lets the owner of the contract set the global document template of the terms.
Name | Type | Description |
---|---|---|
_newDocTemplate | string | The new document template to use for the terms. |
function _setGlobalTemplate(string _newDocTemplate) internal
Function to set the Global Document Template.
This internal function sets the global document template of the terms. It emits the GlobalTemplateChanged event when template is updated.
Name | Type | Description |
---|---|---|
_newDocTemplate | string | The new document template to use for the terms. |
function docTemplate() external view returns (string)
Function that returns the global document template.
This function returns the global document template of the terms.
Name | Type | Description |
---|---|---|
[0] | string | _globalDocTemplate The global document template of the terms. |
function setGlobalTerm(string _term, string _value) external
Function to set the Global Term/// @notice Explain to an end user what this does
This function lets the owner of the contract set the global terms
Name | Type | Description |
---|---|---|
_term | string | The term to set. |
_value | string | The value of the term to set. |
function _setGlobalTerm(string _term, string _value) internal
Function to set the Global Term
This internal function sets the global terms It emits the GlobalTermChanged event when term is updated.
Name | Type | Description |
---|---|---|
_term | string | The term to set. |
_value | string | The value of the term to set. |
function globalTerm(string _term) public view returns (string)
This function returns the global value of the term
This function returns the global value of the term
Name | Type | Description |
---|---|---|
_term | string | The term to get. |
Name | Type | Description |
---|---|---|
[0] | string | _globalTerms[_term] The global value of the term |
function currentTermsBlock() public view returns (uint256)
Function to get block of the latest term change.
This function returns the block number of the last term change.
Name | Type | Description |
---|---|---|
[0] | uint256 | _lastTermChange The block number of the last term change. |
function setURI(string _newURI) external
Function to set the contract URI
This function lets the owner of the contract or a metasigner set the contract URI. It emits UpdatedURI event when URI is updated.
Name | Type | Description |
---|---|---|
_newURI | string | The URI to set. |
function URI() public view returns (string)
Function to get the contract URI
This function returns the contract URI.
Name | Type | Description |
---|---|---|
[0] | string | _uri The contract URI. |
mapping(address => bool) _hasAcceptedTerms
Mapping that stores whether the address has accepted terms.
This mapping returns a boolean value indicating whether the address has accepted terms.
function _acceptedTerms(address _to) internal view returns (bool)
This is an internal function that returns whether the address has accepted terms.
This function returns a boolean value indicating whether the address has accepted terms.
Name | Type | Description |
---|---|---|
_to | address | The address to check. |
Name | Type | Description |
---|---|---|
[0] | bool | True if the address has accepted terms, false otherwise. |
function acceptedTerms(address _address) external view returns (bool)
This is an external function that returns whether the address has accepted terms.
This function returns a boolean value indicating whether the address has accepted terms.
Name | Type | Description |
---|---|---|
_address | address | The address to check. |
Name | Type | Description |
---|---|---|
[0] | bool | True if the address has accepted terms, false otherwise. |
function acceptTerms(string _newtermsUrl) external
This is an external function called by a user that wants to accepts the agreement at certain url
_This function is called by a user that wants to accepts terms. It checks if the terms url for the agreement is the latest one. It then updates the mapping hasAcceptedTerms and emits the AcceptedTerms event.
Name | Type | Description |
---|---|---|
_newtermsUrl | string | The url of the terms. |
function acceptTermsFor(address _signer, string _newtermsUrl, bytes _signature) external
This function is used to accept the terms at certain url on behalf of the user (metasigner)
This function is called by a metasigner to accept terms on behalf of the signer that wants to accepts terms. It uses ECDSA to recover the signer from the signature and the hash of the termsurl and checks if they match.
Name | Type | Description |
---|---|---|
_signer | address | The address of the signer that wants to accept terms. |
_newtermsUrl | string | The url of the terms. |
_signature | bytes | The signature of the signer that wants to accept terms. |
function _acceptTerms(address _signer, string _newtermsUrl) internal
This is an internal function called by a user that wants to accepts the agreement at certain url
_This function is called by a the external function which is called by a user that wants to accepts terms. It updates the mapping hasAcceptedTerms and emits the AcceptedTerms event.
Name | Type | Description |
---|---|---|
_signer | address | The address of the signer that wants to accept terms. |
_newtermsUrl | string | The url of the terms. |
function termsUrl() external view returns (string)
This function returns the url of the terms.
This function returns the url of the terms with the prefix "ipfs://".
function _termsUrl() internal view returns (string)
This internal function returns the url of the terms.
This internal function returns the url of the terms with the prefix "ipfs://".
function termsUrlWithPrefix(string prefix) external view returns (string)
This function returns the url of the terms with a given prefix
This function returns the url of the terms with the prefix
Name | Type | Description |
---|---|---|
prefix | string | The prefix of the url. return _termsUrlWithPrefix(prefix) The url of the terms with the prefix. |
function _termsUrlWithPrefix(string prefix) internal view returns (string _termsURL)
This is an internal function that returns the url of the agreement with a given prefix.
This function returns the url of the agreement with the prefix. It uses the global renderer, template, chain id, contract address of the deployed contract and the latest block height to concatenate the url.
Name | Type | Description |
---|---|---|
prefix | string | The prefix of the url. |
Name | Type | Description |
---|---|---|
_termsURL | string | The url of the agreement with the prefix. |
mapping(address => mapping(uint256 => bool)) hasAcceptedTerms
Mapping that stores whether the address has accepted terms for a specific token.
This mapping returns a boolean value indicating whether the address has accepted terms for a specific token.
mapping(string => mapping(uint256 => string)) _tokenTerms
This is mapping that store the URL for the agreeemnt for a specific token.
This mapping returns the URL for the agreement for a specific token.
mapping(uint256 => string) _tokenDocTemplates
This is mapping that store the CID of the template for a specific token.
This mapping returns the CID of the template for a specific token.
mapping(uint256 => string) _tokenRenderers
This is mapping that store the CID of the Renderer for a specific token.
This mapping returns the CID of the Renderer for a specific token.
function _acceptedTerms(address to, uint256 tokenId) internal view returns (bool)
This is an internal function that returns whether the address has accepted terms for a specific token.
This function returns a boolean value indicating whether the address has accepted terms for a specific token.
Name | Type | Description |
---|---|---|
to | address | The address to check. |
tokenId | uint256 | The token id to check. |
Name | Type | Description |
---|---|---|
[0] | bool | hasAcceptedTerms[to][tokenId] True if the address has accepted terms for a specific token, false otherwise. |
function acceptedTerms(address to, uint256 tokenId) external view returns (bool)
This is an external function that returns whether the address has accepted terms for a specific token.
This function returns a boolean value indicating whether the address has accepted terms for a specific token.
Name | Type | Description |
---|---|---|
to | address | The address to check. |
tokenId | uint256 | The token id to check. |
Name | Type | Description |
---|---|---|
[0] | bool | _acceptedTerms(to, tokenId) True if the address has accepted terms for a specific token, false otherwise. |
function acceptTerms(uint256 tokenId, string newtermsUrl) external
This is external function that the user can call to accept specific terms for a specific token.
This function accepts specific terms agreement mentioned on a URL for a specific token.
Name | Type | Description |
---|---|---|
tokenId | uint256 | The token id for which the terms are accepted. |
newtermsUrl | string | The terms that are accepted. |
function acceptTermsFor(address _signer, string _newtermsUrl, uint256 _tokenId, bytes _signature) external
This function is used to accept the terms at certain url on behalf of the user (metasigner) for a specific token.
This function is called by a metasigner to accept terms on behalf of the signer that wants to accepts terms for a specific token. It uses ECDSA to recover the signer from the signature and the hash of the termsurl and checks if they match.
Name | Type | Description |
---|---|---|
_signer | address | The address of the signer that wants to accept terms. |
_newtermsUrl | string | The url of the terms. |
_tokenId | uint256 | The token id for which the terms are accepted. |
_signature | bytes | The signature of the signer that wants to accept terms. |
function _acceptTerms(uint256 _tokenId, string _newtermsUrl) internal virtual
This is an internal function that the user can call to accept specific terms for a specific token.
This function accepts specific terms agreement on a URL for a specific token. It first checks if the terms the user is accepting are the latest terms for the token. If they are not, it throws an error. If they are, it accepts the terms (updates mapping) and emits the AcceptedTerms event.
Name | Type | Description |
---|---|---|
_tokenId | uint256 | The token id for which the terms are accepted. |
_newtermsUrl | string | The terms that are accepted. |
function termsUrl(uint256 tokenId) external view returns (string)
This is an external function that returns the URL for the agreement for a specific token.
This function returns the URL for the agreement for a specific token with prefix "ipfs://".
function _termsUrl(uint256 tokenId) internal view returns (string)
This is an internal function that returns the URL for the agreement for a specific token.
This function returns the URL for the agreement for a specific token with prefix "ipfs://".
function _termsUrlWithPrefix(uint256 tokenId, string prefix) internal view returns (string _termsURL)
This is an internal function that returns the URL for the terms agreement for a specific token.
This function returns the URL for the terms agreement for a specific token. It takes a prefix as an argument. It concatenates the prefix with tokenRenderer, tokenTemplate, chain Id, address of the contract, latest block height when the terms changed for that token and token Id.
Name | Type | Description |
---|---|---|
tokenId | uint256 | The token id for which the terms URL is returned. |
prefix | string | The prefix to be added to the URL. |
Name | Type | Description |
---|---|---|
_termsURL | string | The URL of the terms agreement for a specific token. |
function termsUrlWithPrefix(uint256 tokenId, string prefix) public view returns (string)
This is a public function that returns the URL of the agreement for a specific token.
This function returns the URL of the agreement for a specific token.
Name | Type | Description |
---|---|---|
tokenId | uint256 | The token id for which the terms URL is returned. |
prefix | string | The prefix to be added to the URL. |
Name | Type | Description |
---|---|---|
[0] | string | _termsUrlWithPrefix(tokenId, prefix) The URL of the terms agreement for a specific token with a given prefix. |
function setTokenTemplate(uint256 tokenId, string newTokenTemplate) external
This function can be called by the owner to set the CID of the template for a specific token.
This function sets the CID of the template for a specific token.
Name | Type | Description |
---|---|---|
tokenId | uint256 | The token id for which the template is set. |
newTokenTemplate | string | The CID of the template for a specific token. |
function _setTokenTemplate(uint256 tokenId, string newTokenTemplate) internal virtual
This is an internal function that sets the CID of the template for a specific token.
This function sets the CID of the template for a specific token. It emits TokenTemplateChanged.
Name | Type | Description |
---|---|---|
tokenId | uint256 | The token id for which the template is set. |
newTokenTemplate | string | The CID of the template for a specific token. |
function tokenTemplate(uint256 tokenId) external view returns (string)
This function returns the CID of the template for a specific token.
This function returns the CID of the template for a specific token.
Name | Type | Description |
---|---|---|
tokenId | uint256 | The token id for which the template is returned. |
Name | Type | Description |
---|---|---|
[0] | string | _tokenTempate(tokenId) The CID of the template for a specific token. |
function setTokenRenderer(uint256 tokenId, string newRenderer) external
This is a function that can be called by the owner to set the CID of the renderer for a specific token.
This function sets the CID of the renderer for a specific token.
Name | Type | Description |
---|---|---|
tokenId | uint256 | The token id for which the renderer is set. |
newRenderer | string | The CID of the renderer for a specific token. |
function _setTokenRenderer(uint256 tokenId, string newRenderer) internal virtual
This is an internal function that sets the CID of the renderer for a specific token.
This function sets the CID of the renderer for a specific token. It emits TokenRendererChanged.
Name | Type | Description |
---|---|---|
tokenId | uint256 | The token id for which the renderer is set. |
newRenderer | string | The CID of the renderer for a specific token. |
function tokenRenderer(uint256 tokenId) external view returns (string)
This function returns the CID of the renderer for a specific token.
This function returns the CID of the renderer for a specific token.
Name | Type | Description |
---|---|---|
tokenId | uint256 | The token id for which the renderer is returned. |
Name | Type | Description |
---|---|---|
[0] | string | _tokenRenderer(tokenId) The CID of the renderer for a specific token. |
function _tokenRenderer(uint256 _tokenId) internal view returns (string)
This is an internal function that returns the CID of the renderer for a specific token.
This function returns the CID of the renderer for a specific token or the global renderer if the token renderer is not set.
Name | Type | Description |
---|---|---|
_tokenId | uint256 | The token id for which the renderer is returned. |
Name | Type | Description |
---|---|---|
[0] | string | _tokenRenderers[_tokenId] The CID of the renderer for a specific token or _globalRenderer if the token renderer is not set. |
function _tokenTemplate(uint256 _tokenId) internal view returns (string)
This is an internal function that returns the CID of the template for a specific token.
This function returns the CID of the renderer for a specific token or the global template if the token template is not set.
Name | Type | Description |
---|---|---|
_tokenId | uint256 | The token id for which the template is returned. |
Name | Type | Description |
---|---|---|
[0] | string | _tokenDocTemplates[_tokenId] The CID of the template for a specific token or _globalDocTemplate if the token template is not set. |
function setTokenTerm(string _term, uint256 _tokenId, string _value) external
This function is used to set a value for a specific term for a specific token.
This function is used to set a value for a specific term for a specific token. It emits the the TokenTermAdded event and records the last time the terms were changed.
Name | Type | Description |
---|---|---|
_term | string | The term for which the value is set. |
_tokenId | uint256 | The token id for which the term is set. |
_value | string | The value for the term. |
function _setTokenTerm(string _term, uint256 _tokenId, string _value) internal virtual
This is an internal function that sets a value for a specific term for a specific token.
This function is used to set a value for a specific term for a specific token. It emits the the TokenTermChanged event.
Name | Type | Description |
---|---|---|
_term | string | The term for which the value is set. |
_tokenId | uint256 | The token id for which the term is set. |
_value | string | The value for the term. |
function tokenTerm(string _term, uint256 _tokenId) public view virtual returns (string)
This function is used to get the value for a specific term for a specific token.
_This function is used to get the value for a specific term for a specific token. If the term is not set for the specific token, it returns the global term value for the specific term.
Name | Type | Description |
---|---|---|
_term | string | The term for which the value is returned. |
_tokenId | uint256 | The token id for which the term is returned. |
Name | Type | Description |
---|---|---|
[0] | string | _tokenTerms[_term][_tokenId] The value for the term or the global term value if the term is not set. |
struct Counters.Counter _tokenIds
string _uri
event MintNFT(address sender, uint256 tokenId)
constructor(address _newOwner, string _name, string _symbol) public
function supportsInterface(bytes4 interfaceId) public view virtual returns (bool)
function _transfer(address from, address to, uint256 tokenId) internal virtual
_Transfers tokenId
from from
to to
.
As opposed to {transferFrom}, this imposes no restrictions on msg.sender.
Requirements:
to
cannot be the zero address.tokenId
token must be owned byfrom
.
Emits a {Transfer} event._
struct TermsInfo {
string key;
string value;
}
function setPolydocs(string renderer, string template, struct ERC721Termsable.TermsInfo[] terms) public
function mint(string _tokenURI) public returns (uint256)
struct Counters.Counter _tokenIds
string _uri
event MintNFT(address sender, uint256 tokenId)
constructor(address _newOwner, string _name, string _symbol) public
function supportsInterface(bytes4 interfaceId) public view virtual returns (bool)
function _transfer(address from, address to, uint256 tokenId) internal virtual
_Transfers tokenId
from from
to to
.
As opposed to {transferFrom}, this imposes no restrictions on msg.sender.
Requirements:
to
cannot be the zero address.tokenId
token must be owned byfrom
.
Emits a {Transfer} event._
function tokenTerm(string _term, uint256 _tokenId) public view returns (string)
This function is used to get the value for a specific term for a specific token.
_This function is used to get the value for a specific term for a specific token. If the term is not set for the specific token, it returns the global term value for the specific term.
Name | Type | Description |
---|---|---|
_term | string | The term for which the value is returned. |
_tokenId | uint256 | The token id for which the term is returned. |
Name | Type | Description |
---|---|---|
[0] | string | _tokenTerms[_term][_tokenId] The value for the term or the global term value if the term is not set. |
struct TermsInfo {
string key;
string value;
}
function setPolydocs(uint256 _tokenId, string renderer, string template, struct ERC721TokenTermsable.TermsInfo[] terms) public
function mint(string _tokenURI) public returns (uint256)