myria-core-sdk
Version:
Latest version SDK
659 lines (612 loc) • 41.7 kB
JavaScript
import { CollectionAPI } from "./../core/apis/collection.api";
import { ProjectAPI } from "../core/apis";
/**
* Create CollectionManager module
* @class CollectionManager
* @param {EnvTypes} env Environment type (DEV / STAGING / PREPROD / PROD)
* @example <caption>CollectionManager Instantiation</caption>
const collectionManager = new CollectionManager(EnvTypes.STAGING);
*
*/
export class CollectionManager {
constructor(env) {
this.collectionAPI = new CollectionAPI(env);
this.projectAPI = new ProjectAPI(env);
}
/**
* @summary Create collection data
* @param {CreateCollectionParams} payload Create collection request params (name / collectionImageUrl / description / contractAddress / metadataUrl)
* @returns {CreateCollectionResponse} Collection details response
* @throws {string} Exception: StarkKey is required
* @throws {string} Exception: Name is required
* @throws {string} Exception: ContractAddress is required
* @throws {string} Exception: MetadataAPIUri is required
* @throws {string} Exception: OwnerPublicKey is required
* @throws {string} Exception: ProjectID is required
* @throws {string} Exception: Create Collection failure with internal server error
* @example <caption>Sample of createCollection({}) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const contractAddress: string = config.collection_contract_address;
const metadataApiUrl: string = config.metadata_api_url;
const publicKey: string = config.public_key;
const projectId: number = config.project_id;
const starkKey: string = config.stark_key;
const params: CreateCollectionParams = {
name: "Test Collection 1",
description: "Collection Test with SDK",
contractAddress: contractAddress,
metadataApiUrl: metadataApiUrl,
ownerPublicKey: publicKey,
projectId: projectId,
starkKey: starkKey,
};
console.log("Creating the collection...");
const collectionResponse: CreateCollectionResponse = await collectionManager.createCollection(params);
console.log("Created collection response:");
console.log(JSON.stringify(collectionResponse, null, 2));
*/
async createCollection(payload) {
let createCollectionData;
if (!payload.starkKey) {
throw new Error("StarkKey is required");
}
if (!payload.name) {
throw new Error("Name is required");
}
if (!payload.contractAddress) {
throw new Error("ContractAddress is required");
}
if (!payload.metadataApiUrl) {
throw new Error("MetadataAPIUri is required");
}
if (!payload.ownerPublicKey) {
throw new Error("OwnerPublicKey is required");
}
if (!payload.projectId) {
throw new Error("ProjectId is required");
}
{
try {
const createCollectionRes = await this.collectionAPI.createCollection(payload);
if ((createCollectionRes === null || createCollectionRes === void 0 ? void 0 : createCollectionRes.status) === "success") {
createCollectionData = createCollectionRes === null || createCollectionRes === void 0 ? void 0 : createCollectionRes.data;
}
else {
throw new Error("Create Collection failure with internal server error");
}
}
catch (error) {
throw new Error(error);
}
}
return createCollectionData;
}
/**
* @summary Get collection list
* @param {GetCollectionParams} GetCollectionParams query collections params
* @returns {CommonPaginateDataTypes<CollectionResponse[]>} Paginable collections data
* @example <caption>Sample of getCollectionList({}) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const params: GetCollectionParams = {
limit: 10,
page: 1,
isHot: true
};
console.log("Get the collection...");
const collections: CommonPaginateDataTypes<CollectionResponse[]> = await collectionManager.getCollectionList(params);
console.log("List of collection response:");
console.log(JSON.stringify(collections, null, 2));
*/
async getCollectionList(params) {
const collectionList = await this.collectionAPI.getCollectionList(params);
return collectionList;
}
/**
* @summary Get collection by developer api key and account ID
* @param {GetCollectionByApiKeyParams} GetCollectionByApiKeyParams Params to get collections by developer api key and account ID
* @returns {CollectionResponse[]} List of collections
* @example <caption>Sample of getCollectionsByApiKey({}) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const params: GetCollectionByApiKeyParams = {
accountId: 'uuid-get-from-dev-portal',
apiKey: 'api-key-get-from-dev-portal'
};
console.log("Get the collection...");
const collections: CollectionResponse[] = await collectionManager.getCollectionsByApiKey(params);
console.log("List of collection response:");
console.log(JSON.stringify(collections, null, 2));
*/
async getCollectionsByApiKey(params) {
if (!params.accountId) {
throw new Error('Account ID is required');
}
if (!params.apiKey) {
throw new Error('Developer API Key is required');
}
const collections = await this.collectionAPI.getCollectionsByApiKeyV2(params);
return collections;
}
async getCollections(params) {
if (!params.accountId) {
throw new Error('Myria User ID is required');
}
if (!params.apiKey) {
throw new Error('Developer API Key is required');
}
const reqProjects = await this.projectAPI.getProjectsByUserIDAndApiKey(params.accountId, params.apiKey);
let listProjects = [];
if ((reqProjects === null || reqProjects === void 0 ? void 0 : reqProjects.status) === 'success') {
listProjects = reqProjects.data || [];
}
const listCollections = [];
for (const project of listProjects) {
// Get list projects
const collectionResponseData = await this.projectAPI.getCollectionListByProjectId(project.id);
if (collectionResponseData.status === 'success') {
listCollections.push(...collectionResponseData.data.collections);
}
else {
continue;
}
}
return listCollections;
}
/**
* @summary Get collection details by ID
* @param {number} id unique ID of the collection
* @returns {CollectionDetailsResponseData} Collection details information data
* @throws {string} Exception: Collection ID is required
* @throws {string} Exception: Get collection by ID failed with internal server error
* @example <caption>Sample of getCollectionById(collectionId) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const collectionId = 1;
console.log("Get the collection...");
const collectionData: CollectionDetailsResponseData = await collectionManager.getCollectionById(collectionId);
console.log(JSON.stringify(collectionData, null, 2));
*/
async getCollectionById(id) {
if (!id) {
throw new Error("Collection ID is required");
}
const collectionResponse = await this.collectionAPI.getCollectionById(id);
if ((collectionResponse === null || collectionResponse === void 0 ? void 0 : collectionResponse.status) !== 'success') {
throw new Error("Get collection by ID failed with internal server error");
}
return collectionResponse.data;
}
/**
* @summary Get collection metadata schema by smart contract address (deployed address of the collection)
* @param {string} contractAddress The smart contract address of the collection
* @returns {CollectionMetadataSchemaParams[]} List of metadata fields of the specific collection
* @throws {string} Exception: Contract address is required
* @example <caption>Sample of getCollectionMetadataByAddress(contractAddress) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const contractAddress = '0xFCB75a9De034b9DEff9aD1a12142c12E51665F97';
console.log("Get the collection metadata...");
const collectionMetadata: APIResponseType<CollectionMetadataSchemaParams[]> = await collectionManager.getCollectionMetadataByAddress(contractAddress);
console.log(JSON.stringify(collectionMetadata, null, 2));
*/
async getCollectionMetadataByAddress(contractAddress) {
if (!contractAddress) {
throw new Error('Contract address is required');
}
const collectionByAddress = await this.collectionAPI.getCollectionMetadataByAddress(contractAddress);
return collectionByAddress;
}
/**
* @summary Create collection metadata schema by smart contract address (deployed address of the collection contract)
* @param {string} contractAddress Smart contract address of the collection
* @param {CreateCollectionMetadataParams} payload The metadata structure params
* @returns {CollectionDetailsResponseData} List of metadata fields of the specific collection
* @throws {string} Exception: Contract address is required
* @throws {string} Exception: StarkKey is required
* @throws {string} Exception: Key name of metadata is required
* @throws {string} Exception: Internal server error
* @example <caption>Sample of createCollectionMetadataByAddress(contractAddress, {}) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const contractAddress = '0xFCB75a9De034b9DEff9aD1a12142c12E51665F97';
const payload: CreateCollectionMetadataParams = {
metadata: [
{
name: 'rarity',
type: 'string',
filterable: true,
},
{
name: 'power',
type: 'string',
filterable: true,
},
{
name: 'level',
type: 'enum',
filterable: true,
},
{
name: 'color',
type: 'string',
filterable: false,
},
];
starkKey: '0xFC....',
};
console.log("Get the collection metadata...");
const collectionMetadata: CollectionDetailsResponseData = await collectionManager.createCollectionMetadataByAddress(contractAddress, payload);
console.log(JSON.stringify(collectionMetadata, null, 2));
*/
async createCollectionMetadataByAddress(contractAddress, payload) {
let collectionByAddress;
if (!contractAddress) {
throw new Error("Contract address is required");
}
if (!payload.starkKey) {
throw new Error("StarkKey is required");
}
payload.metadata.forEach((data, index) => {
if (!data.name) {
throw new Error(`${index + 1}th item's name for metadata is required!`);
}
});
try {
collectionByAddress = await this.collectionAPI.createCollectionMetadataByAddress(contractAddress, payload);
if ((collectionByAddress === null || collectionByAddress === void 0 ? void 0 : collectionByAddress.status) === "success") {
collectionByAddress = collectionByAddress === null || collectionByAddress === void 0 ? void 0 : collectionByAddress.data;
}
else {
throw new Error("Create Collection by smart contract address failure with internal server error");
}
}
catch (error) {
throw new Error(error);
}
return collectionByAddress;
}
/**
* @summary Update metadata schema (change field key) by smart contract address
* @param {string} contractAddress The unique smart contract address for the collection
* @param {string} name The existing key property in the metadata schema (for example we have the property power, and we want to change to power_character)
* @param {UpdateCollectionMetadataParams} payload The request params for Updated Metadata
* @returns {CollectionDetailsResponseData} The collection details information (including new metadata updated...)
* @throws {string} Exception: Internal server error
*
* @example <caption>Sample of updateCollectionMetadataByAddress(contractAddress, name, {}) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const contractAddress = '0xFCB75a9De034b9DEff9aD1a12142c12E51665F97';
const name = 'Rarity';
const payload: UpdateCollectionMetadataParams = {
name: 'Rarity_1',
type: 'string',
filterable: true,
starkKey: '0x09af....'
};
console.log("Update the collection metadata by smart contract address...");
const collectionData: CollectionDetailsResponseData = await collectionManager.updateCollectionMetadataByAddress(contractAddress, name, payload);
console.log(JSON.stringify(collectionData, null, 2));
*/
async updateCollectionMetadataByAddress(contractAddress, name, payload) {
let collectionByAddress;
if (this.validationParams({ contractAddress, name: payload.name, starkKey: payload.starkKey })) {
try {
collectionByAddress = await this.collectionAPI.updateCollectionMetadataByAddress(contractAddress, name, payload);
if ((collectionByAddress === null || collectionByAddress === void 0 ? void 0 : collectionByAddress.status) === "success") {
collectionByAddress = collectionByAddress === null || collectionByAddress === void 0 ? void 0 : collectionByAddress.data;
}
else {
throw new Error("Update Collection Metadata by smart contract address failure due to internal server error");
}
}
catch (error) {
throw new Error(error);
}
}
return collectionByAddress;
}
/**
* @summary Get the collection by the public ID (uuid)
* @param {string} publicId The unique public ID (UUID) of the collection
* @returns {CollectionDetailsResponseData} Collection details information data (metadata schema, name, description, metadataUrl...)
* @throws {string} Exception: The public ID is required
* @example <caption>Sample of getCollectionByPublicId(publicId) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const publicId = 'f1d203eb-cd15-49ff-8852-41846a508bd8'; // unique UUID of the collection
console.log("Get collection by public ID...");
const collectionData: CollectionDetailsResponseData = await collectionManager.getCollectionByPublicId(publicId);
console.log(JSON.stringify(collectionData, null, 2));
*/
async getCollectionByPublicId(publicId) {
if (!publicId) {
throw new Error("The public ID is required");
}
const collectionByPublicId = await this.collectionAPI.getCollectionByPublicId(publicId);
return collectionByPublicId;
}
/**
* @summary Get the asset list by collection ID
* @param {GetAssetByCollectionParams} payload The request params for querying the list of the assets
* @returns {CommonPaginateDataTypes<AssetListResponse[]>} The paginated data response (including the list of the assets)
* @throws {string} Exception: The collectionID is required
* @throws {string} Exception: The assetType is required
* @example <caption>Sample of getAssetByCollectionId({}) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const payload: GetAssetByCollectionParams = {
collectionId: 1,
assetType: 'NON_SALE',
limit: 100,
page: 1
};
console.log("Get asset list by collection ID");
const assetsData: CommonPaginateDataTypes<AssetListResponse[]> = await collectionManager.getAssetByCollectionId(payload);
console.log(JSON.stringify(assetsData, null, 2));
*/
async getAssetByCollectionId(payload) {
if (!payload.collectionId) {
throw new Error('The collectionID is required');
}
if (!payload.assetType) {
throw new Error('The assetType is required');
}
const expectedAssetType = payload.assetTypeOutput || 'ASSETS';
payload.assetTypeOutput = expectedAssetType;
const listAssetByCollectionId = await this.collectionAPI.getAssetByCollectionId(payload);
return listAssetByCollectionId;
}
/**
* @description Get total purchased assets group by user
* @param {GetTotalAssetsByOwnerParams} totalPurchasedAssets Request for query total assets by owner params
* @returns {CommonPaginateDataTypes<OwnerAssetsCount[]>} owner assets count result
* @throws {string} Exception: CollectionId is required
* @throws {string} Exception: Stark key is required
* @throws {string} Exception: Internal server error
* @throws {string} Exception: Get list failed: ${err}
* @example <caption>Sample of getTotalPurchasedAssetsGroupedByUser({}) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const payload: GetTotalAssetsByOwnerParams = {
collectionId: 1,
starkKey: '0xFA....'
};
console.log("Get total purchased assets group by users");
const ownerData: CommonPaginateDataTypes<OwnerAssetsCount[]> = await collectionManager.getTotalPurchasedAssetsGroupedByUser(payload);
console.log(JSON.stringify(ownerData, null, 2));
*/
async getTotalPurchasedAssetsGroupedByUser(totalPurchasedAssets) {
if (!totalPurchasedAssets.collectionId) {
throw new Error('CollectionId is required');
}
if (!totalPurchasedAssets.starkKey) {
throw new Error("Stark key is required");
}
let response;
try {
const result = await this.collectionAPI.getTotalPurchasedAssetsGroupedByUser(totalPurchasedAssets.collectionId, totalPurchasedAssets.starkKey, totalPurchasedAssets.paginationType);
if (result.status === "success") {
response = result.data;
}
else {
throw new Error('Fetch ownerlist failed with internal server error');
}
}
catch (err) {
throw new Error(`Get ownerlist failed: ${err}`);
}
return response;
}
/**
* @description Update collection by contract address and stark key
* @param {UpdateCollectionByContractAddressParams} payload The updated collection requests params
* @returns {CollectionDetailsResponseData} The collection details information
* @throws {string} Exception: Contract Address is required
* @throws {string} Exception: Stark key is required
* @throws {string} Exception: Internal server error
* @example <caption>Sample of updateCollectionByContractAddress({}) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const payload: UpdateCollectionByContractAddressParams = {
contractAddress: '0xFC...',
name: 'New name of the collection',
starkKey: '0xabc...',
description: 'New description of collection',
collectionImageUrl: 'https://collection-banner-url.com'
iconUrl: 'https://icon-avatar-collection.com'
};
console.log("Update collection by smart contract address");
const collectionData: CollectionDetailsResponseData = await collectionManager.updateCollectionByContractAddress(payload);
console.log(JSON.stringify(collectionData, null, 2));
*/
async updateCollectionByContractAddress(payload) {
if (!payload.contractAddress) {
throw new Error("Contract Address is required");
}
if (!payload.starkKey) {
throw new Error("StarkKey is required");
}
let updateResult;
try {
const response = await this.collectionAPI.updateCollectionByContractAddress(payload);
if ((response === null || response === void 0 ? void 0 : response.status) === "success") {
updateResult = response === null || response === void 0 ? void 0 : response.data;
}
else {
throw new Error("Update collection failed with internal server error");
}
}
catch (err) {
throw new Error(err);
}
return updateResult;
}
/**
* @description Update collection by contract address and partner api key
* @param {UpdateCollectionByCollectionIdAndApiKeyParams} payload The updated collection requests params
* @returns {CollectionDetailsResponseData} The collection details information
* @throws {string} Exception: Contract Address is required
* @throws {string} Exception: Stark key is required
* @throws {string} Exception: Myria account ID is required
* @example <caption>Sample of updateCollectionByCollectionIdAndApiKey({}) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const payload: UpdateCollectionByCollectionIdAndApiKeyParams = {
collectionId: '1', // Number string
name: 'New name of the collection',
accountId: '0xabc...',
apiKey: '0x1acd...', // Partner API key
description: 'New description of collection',
collectionImageUrl: 'https://collection-banner-url.com'
iconUrl: 'https://icon-avatar-collection.com'
};
console.log("Update collection by smart contract address");
const collectionData: CollectionDetailsResponseData = await collectionManager.updateCollectionByCollectionIdAndApiKey(payload);
console.log(JSON.stringify(collectionData, null, 2));
*/
async updateCollectionByCollectionIdAndApiKey(payload) {
if (!payload.collectionId) {
throw new Error("Contract ID is required");
}
if (!payload.accountId) {
throw new Error("Myria account ID is required");
}
if (!payload.apiKey) {
throw new Error("Partner Api Key is required");
}
let updateResult;
try {
const response = await this.collectionAPI.updateCollectionByCollectionIdAndApiKey(payload);
if ((response === null || response === void 0 ? void 0 : response.status) === "success") {
updateResult = response === null || response === void 0 ? void 0 : response.data;
}
else {
throw new Error("Update collection failed with internal server error");
}
}
catch (err) {
throw new Error(err);
}
return updateResult;
}
async getAttributesByCollectionId(id) {
const attributesResponse = await this.collectionAPI.getAttributesByCollectionId(id);
return attributesResponse;
}
/**
* @summary Create the collection by using myria user ID and api key
* @param {CreateCollectionByApiKeyParams} payload create Collection request params (name,collectionImageUrl?,description?,iconUrl?,contractAddress,ownerPublicKey,metadataApiUrl,projectId,accountId,apiKey)
* @throws {string} Exception: Collection name is required
* @throws {string} Exception: Contract address is required
* @throws {string} Exception: Owner PublicKey is required
* @throws {string} Exception: metadataApiUrl is required
* @throws {string} Exception: Project ID is required
* @throws {string} Exception: ApiKey is required
* @throws {string} Exception: Myria User ID is required
* @throws {string} Exception: Create project failed with internal server error
* @returns {CreateCollectionResponse | undefined} Collection information data
* @example <caption>Sample of createCollectionByApiKey() on testnet environment</caption>
*
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const params: CreateCollectionByApiKeyParams = {
name: name_Collection;
collectionImageUrl?: 'abc.png';
description?: description;
iconUrl?: abc.png;
contractAddress: contractAddress;
ownerPublicKey: Owner PublicKey;
metadataApiUrl: metaDataApiURL;
projectId: 1;
accountId: accountId;
apiKey: APIKey
};
console.log("Create the Collection...");
const newCollectionResponse: CreateCollectionResponse = await collectionManager.createCollectionByApiKey(params);
console.log("Created Collection response:");
console.log(JSON.stringify(newCollectionResponse, null, 2));
*/
async createCollectionByApiKey(payload) {
if (!payload.apiKey) {
throw new Error("API Key is required");
}
if (!payload.accountId) {
throw new Error("Account ID is required");
}
if (!payload.name) {
throw new Error("Collection Name is required");
}
if (!payload.contractAddress) {
throw new Error("Contract Address is required");
}
if (!payload.projectId) {
throw new Error("Project Id is required");
}
if (!payload.ownerPublicKey) {
throw new Error("Owner Public Key is required");
}
let collectionCreateRes;
try {
const result = await this.collectionAPI.createCollectionByMyriaUserIdAndApiKey(payload);
if (result.status === 'success') {
collectionCreateRes = result.data;
}
else {
throw new Error('Create Collection failed with internal server error');
}
}
catch (err) {
throw new Error(`Create Collection failed with ${err}`);
}
return collectionCreateRes;
}
/**
* @description Validate the metadata with metadataSchema and metaData URL test
* @param {ValidateMetadataParams} payload The updated collection requests params
* @returns {ValidateMetadataResponse} The collection details information
* @throws {string} Exception: Metadata Schema is required
* @throws {string} Exception: Asset Metadata Url is required
* @throws {string} Http Status Code 500: Validate metadata failed with internal server error
* @example <caption>Sample of validateMetadata({}) on Staging env</caption>
const collectionManager: CollectionManager = new CollectionManager(EnvTypes.STAGING);
const payload: ValidateMetadataParams = {
metadata: [
{
"name": "type",
"type": "string",
"filterable": true
},
{
"name": "rarity",
"type": "string",
"filterable": true
}
],
"assetMetadataUri": "https://myria.com/v1/sigil/metadata/1"
};
console.log("Validate Metadata by metadata url and metadataSchema");
const validateMetadataRespond: CollectionDetailsResponseData = await collectionManager.validateMetadata(payload);
console.log(JSON.stringify(validateMetadataRespond, null, 2));
*/
async validateMetadata(payload) {
if (!payload.metadata.length) {
throw new Error("Metadata Schema is required");
}
if (!payload.assetMetadataUri) {
throw new Error("Asset Metadata Uri is required");
}
let resultValidateMetadata;
try {
const response = await this.collectionAPI.validateMetadataSchemaWithTestMetadataUrl(payload);
if ((response === null || response === void 0 ? void 0 : response.status) === "success") {
resultValidateMetadata = response === null || response === void 0 ? void 0 : response.data;
}
else {
throw new Error("Validate metadata failed with internal server error");
}
}
catch (err) {
throw new Error(err);
}
return resultValidateMetadata;
}
validationParams(params) {
for (const keys of params) {
if (!params[keys]) {
throw new Error(`Invalid ${keys}`);
}
}
return true;
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CollectionManager.js","sourceRoot":"","sources":["../../../../src/modules/CollectionManager.ts"],"names":[],"mappings":"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"}