-
LockNFT
- 此方法會鎖定指定的不可見變數替代字。若要鎖定記號,必須要有一個具備
TokenSys
vault
角色的使用者,而該角色是作為 Vault 管理員。只有記號的擁有者才能呼叫此方法。
-
func (t *Controller) LockNFT(orgId string, userId string, tokenId string) (interface{}, error) {
return t.Ctx.ERC1155Token.LockNFT(orgId, userId, tokenId)
}
- 參數:
orgId: string
– 目前組織中使用者的成員身分服務提供者 (MSP) ID。
userId: string
– 使用者的使用者名稱或電子郵件 ID (選擇性)。
tokenID: string
– 要鎖定之記號的 ID。
- 傳回值:
- 傳回值範例:
{
"AssetType":"otoken",
"Behaviors":[
"indivisible",
"mintable",
"transferable",
"burnable",
"lockable",
"roles"
],
"CreatedBy":"oaccount~208e3345ac84b4849f0d2648b2f2f018019886a1230f99304ebff1b6a7733463",
"CreationDate":"2023-10-20T12:22:47Z",
"IsBurned":false,
"IsLocked":true,
"Mintable":{
"Max_mint_quantity":20000
},
"On_sale_flag":false,
"Owner":"oaccount~208e3345ac84b4849f0d2648b2f2f018019886a1230f99304ebff1b6a7733463",
"Price":120,
"Quantity":1,
"Roles":{
"minter_role_name":"minter"
},
"TokenDesc":"",
"TokenId":"token1",
"TokenMetadata":{
"Description":"",
"Image":"",
"Painter_name":"",
"Painting_name":""
},
"TokenName":"artcollection",
"TokenStandard":"erc1155+",
"TokenType":"nonfungible",
"TokenUnit":"whole",
"TokenUri":"token1.example.com"
}
-
IsNFTLocked
- 此方法會傳回布林值,指示指定的記號是否被鎖定。只有記號擁有者、保存庫管理員 (具備
TokenSys
vault
角色的使用者) 或鏈碼的 Token Admin
才能呼叫此方法。
-
func (t *Controller) IsNFTLocked(tokenId string) (interface{}, error) {
auth, err := t.Ctx.ERC1155Auth.CheckAuthorization("ERC1155Token.IsNFTLocked", "TOKEN", map[string]string{"tokenId": tokenId})
if err != nil && !auth {
isCallerTokenSysRoleHolder, error := t.Ctx.ERC1155Token.IsCallerTokenSysRoleHolder(constants.Vault)
if error != nil {
return nil, error
}
if !isCallerTokenSysRoleHolder {
return nil, fmt.Errorf("error in authorizing the caller %s", err.Error())
}
}
return t.Ctx.ERC1155Token.IsNFTLocked(tokenId)
}
- 參數:
tokenID: string
– 記號的 ID。
- 傳回值:
- 傳回值範例:
{
"isNFTLocked":true
}
-
GetAllLockedNFTs
- 此方法會傳回所有鎖定之不可行記號的清單。保存庫管理程式 (具備
TokenSys
vault
角色的使用者) 或鏈碼的 Token Admin
才能呼叫此方法。
-
func (t *Controller) GetAllLockedNFTs() (interface{}, error) {
auth, err := t.Ctx.ERC1155Auth.CheckAuthorization("ERC1155Token.GetAllLockedNFTs", "TOKEN")
if err != nil && !auth {
isCallerTokenSysRoleHolder, error := t.Ctx.ERC1155Token.IsCallerTokenSysRoleHolder(constants.Vault)
if error != nil {
return nil, error
}
if !isCallerTokenSysRoleHolder {
return nil, fmt.Errorf("error in authorizing the caller %s", err.Error())
}
}
return t.Ctx.ERC1155Token.GetAllLockedNFTs()
}
- 參數:
- 傳回值:
- 傳回值範例:
[
{
"key":"token1",
"valueJson":{
"AssetType":"otoken",
"Behaviors":[
"indivisible",
"mintable",
"transferable",
"burnable",
"lockable",
"roles"
],
"CreatedBy":"oaccount~208e3345ac84b4849f0d2648b2f2f018019886a1230f99304ebff1b6a7733463",
"CreationDate":"2023-10-20T12:22:47Z",
"IsBurned":false,
"IsLocked":true,
"Mintable":{
"Max_mint_quantity":20000
},
"On_sale_flag":false,
"Owner":"oaccount~208e3345ac84b4849f0d2648b2f2f018019886a1230f99304ebff1b6a7733463",
"Price":120,
"Quantity":1,
"Roles":{
"minter_role_name":"minter"
},
"TokenDesc":"",
"TokenId":"token1",
"TokenMetadata":{
"Description":"",
"Image":"",
"Painter_name":"",
"Painting_name":""
},
"TokenName":"artcollection",
"TokenStandard":"erc1155+",
"TokenType":"nonfungible",
"TokenUnit":"whole",
"TokenUri":"token1.example.com"
}
}
]
-
GetAllLockedNFTsByOrg
- 此方法會傳回指定組織的所有鎖定不可行記號清單,以及選擇性地傳回指定的使用者。保存庫管理程式 (具備
TokenSys
vault
角色的使用者) 或鏈碼的 Token Admin
才能呼叫此方法。
-
func (t *Controller) GetLockedNFTsByOrg(orgId string, userId ...string) (interface{}, error) {
auth, err := t.Ctx.ERC1155Auth.CheckAuthorization("ERC1155Token.GetLockedNFTsByOrg", "TOKEN")
if err != nil && !auth {
isCallerTokenSysRoleHolder, error := t.Ctx.ERC1155Token.IsCallerTokenSysRoleHolder(constants.Vault)
if error != nil {
return nil, error
}
if !isCallerTokenSysRoleHolder {
return nil, fmt.Errorf("error in authorizing the caller %s", err.Error())
}
}
return t.Ctx.ERC1155Token.GetLockedNFTsByOrg(orgId, userId...)
}
- 參數:
orgId: string
– 目前組織中使用者的成員身分服務提供者 (MSP) ID。
userId: string
– 使用者的使用者名稱或電子郵件 ID (選擇性)。
- 傳回值:
- 傳回值範例:
[
{
"key":"token1",
"valueJson":{
"AssetType":"otoken",
"Behaviors":[
"indivisible",
"mintable",
"transferable",
"burnable",
"lockable",
"roles"
],
"CreatedBy":"oaccount~208e3345ac84b4849f0d2648b2f2f018019886a1230f99304ebff1b6a7733463",
"CreationDate":"2023-10-20T12:22:47Z",
"IsBurned":false,
"IsLocked":true,
"Mintable":{
"Max_mint_quantity":20000
},
"On_sale_flag":false,
"Owner":"oaccount~208e3345ac84b4849f0d2648b2f2f018019886a1230f99304ebff1b6a7733463",
"Price":120,
"Quantity":1,
"Roles":{
"minter_role_name":"minter"
},
"TokenDesc":"",
"TokenId":"token1",
"TokenMetadata":{
"Description":"",
"Image":"",
"Painter_name":"",
"Painting_name":""
},
"TokenName":"artcollection",
"TokenStandard":"erc1155+",
"TokenType":"nonfungible",
"TokenUnit":"whole",
"TokenUri":"token1.example.com"
}
}
]