Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Bump up version to 1.2.0-rc.4 #368

Merged
merged 124 commits into from
Dec 17, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
124 commits
Select commit Hold shift + click to select a range
c21f663
Bump up sdk to v1.2.0-rc.0 (#298)
bonnie57 Oct 22, 2024
7c7abe1
Merge branch 'dev' of https://github.com/storyprotocol/sdk into dev
bpolania Oct 31, 2024
4136096
Merge branch 'dev' of https://github.com/storyprotocol/sdk into dev
bpolania Nov 4, 2024
9f91cc0
Updated Workflows
bpolania Dec 4, 2024
18cad49
Update Variables for Testing
bpolania Dec 4, 2024
438f609
Merge branch 'dev' of https://github.com/storyprotocol/sdk into dev
bpolania Dec 4, 2024
41a4b9f
Merge branch 'dev' into origin/dev-bpolania/workflows
bpolania Dec 4, 2024
58311b1
Updates variables for testing
bpolania Dec 4, 2024
62652e7
Create test_file.txt
bpolania Dec 4, 2024
9b1dc40
Typo correction
bpolania Dec 4, 2024
2ae83ca
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 4, 2024
794c09a
Debugging
bpolania Dec 5, 2024
2e2eaff
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 5, 2024
b8fbddd
Update pr-merge.yaml
bpolania Dec 5, 2024
fe2da63
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 5, 2024
190f3d7
Update test_file.txt
bpolania Dec 5, 2024
9750d1a
Update test_file.txt
bpolania Dec 5, 2024
d415264
Update package.json
bpolania Dec 5, 2024
c3f2b24
updated turbo.json
bpolania Dec 5, 2024
32daea8
Update test_file.txt
bpolania Dec 5, 2024
a27302a
Debug complete
bpolania Dec 5, 2024
3d8983f
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 5, 2024
8ac0bd6
Update test_file.txt
bpolania Dec 5, 2024
1aca0e5
Update pr-internal.yml
bpolania Dec 5, 2024
32b3ce0
Update pr-internal.yml
bpolania Dec 5, 2024
5cd7053
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 5, 2024
ade3d41
Update pr-internal.yml
bpolania Dec 5, 2024
10db1e8
Update test_file.txt
bpolania Dec 5, 2024
6d18db6
Update test_file.txt
bpolania Dec 5, 2024
772b9cc
Update test_file.txt
bpolania Dec 5, 2024
886c0ac
Update pr-internal.yml
bpolania Dec 5, 2024
dad8b8c
Update test_file.txt
bpolania Dec 5, 2024
9ab0317
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 5, 2024
7155570
Update pr-internal.yml
bpolania Dec 5, 2024
88a656c
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 5, 2024
8f5c0bf
Update pr-internal.yml
bpolania Dec 5, 2024
a17940b
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 5, 2024
ecbe83c
Update test_file.txt
bpolania Dec 5, 2024
d68e370
Update pr-internal.yml
bpolania Dec 5, 2024
262a725
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 5, 2024
058da89
Update pr-internal.yml
bpolania Dec 5, 2024
5b6335e
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 5, 2024
407c285
Update pr-internal.yml
bpolania Dec 5, 2024
87e1bc3
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 5, 2024
7976a80
Origin/dev polania/workflows test (#337)
bpolania Dec 5, 2024
9fc71ea
Update pr-merge.yaml
bpolania Dec 5, 2024
b4ba9fc
Merge branch 'origin/dev-bpolania/workflows' of https://github.com/st…
bpolania Dec 5, 2024
f9b0564
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 5, 2024
d943f1f
Merge pull request #338 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 5, 2024
fde5728
debug commit
bpolania Dec 5, 2024
02d37a6
Merge branch 'origin/dev-bpolania/workflows' of https://github.com/st…
bpolania Dec 5, 2024
3f2163a
Update test_file.txt
bpolania Dec 5, 2024
70849fb
Merge pull request #340 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 5, 2024
5d460e4
Update pr-merge.yaml
bpolania Dec 5, 2024
459bde9
Update test_file.txt
bpolania Dec 5, 2024
25cb00f
Merge pull request #341 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 5, 2024
967622d
Update pr-merge.yaml
bpolania Dec 5, 2024
74b4956
Merge branch 'origin/dev-bpolania/workflows' of https://github.com/st…
bpolania Dec 5, 2024
e21cbb2
Update test_file.txt
bpolania Dec 5, 2024
370debe
Merge pull request #342 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 5, 2024
34ca930
Update turbo.json
bpolania Dec 5, 2024
c9f59d5
Merge branch 'origin/dev-bpolania/workflows' of https://github.com/st…
bpolania Dec 5, 2024
993bc16
Update test_file.txt
bpolania Dec 5, 2024
cecee35
Merge pull request #343 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 5, 2024
04c3298
Turbo updates for test integrations
bpolania Dec 5, 2024
79972b3
Merge branch 'origin/dev-bpolania/workflows' of https://github.com/st…
bpolania Dec 5, 2024
b4238fe
Update test_file.txt
bpolania Dec 5, 2024
51abdb4
Merge pull request #344 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 5, 2024
2588d34
update
bpolania Dec 6, 2024
c73a460
Merge branch 'origin/dev-polania/workflows-test' into origin/dev-bpol…
bpolania Dec 6, 2024
adff404
Update test_file.txt
bpolania Dec 6, 2024
8bdcfc7
Merge pull request #345 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 6, 2024
b08a598
Update pr-merge.yaml
bpolania Dec 6, 2024
01bd1cd
Merge branch 'origin/dev-bpolania/workflows' of https://github.com/st…
bpolania Dec 6, 2024
bf15248
Update test_file.txt
bpolania Dec 6, 2024
6fa6a97
Merge pull request #346 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 6, 2024
7f3c04c
Update dispute.test.ts
bpolania Dec 6, 2024
787434d
Update test_file.txt
bpolania Dec 6, 2024
ef883b6
Debug
bpolania Dec 6, 2024
4f78d2f
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 6, 2024
b94811e
Update test_file.txt
bpolania Dec 6, 2024
b107302
Update pr-merge.yaml
bpolania Dec 6, 2024
87f7676
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 6, 2024
6f8f23e
Update test_file.txt
bpolania Dec 6, 2024
897f76d
Merge pull request #351 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 6, 2024
eeeb1b1
Update pr-merge.yaml
bpolania Dec 6, 2024
ad40644
Merge branch 'origin/dev-bpolania/workflows' of https://github.com/st…
bpolania Dec 6, 2024
0dc7a23
Update test_file.txt
bpolania Dec 6, 2024
c2bd92f
Merge pull request #352 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 6, 2024
c0ee5de
Update pr-merge.yaml
bpolania Dec 6, 2024
2212689
Merge branch 'origin/dev-bpolania/workflows' of https://github.com/st…
bpolania Dec 6, 2024
6591443
Update test_file.txt
bpolania Dec 6, 2024
3fc6b67
Merge pull request #353 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 6, 2024
1187502
TEST_WALLET_ADDRESS added
bpolania Dec 10, 2024
cb958c2
Update test_file.txt
bpolania Dec 10, 2024
1933d35
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 10, 2024
2f32dae
Update test_file.txt
bpolania Dec 10, 2024
6b0fdd8
Merge pull request #357 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 10, 2024
2060889
Debugging
bpolania Dec 10, 2024
9f06d7e
Update test_file.txt
bpolania Dec 10, 2024
ebfbeb8
Merge pull request #358 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 10, 2024
b8f265a
Pre-PR commit
bpolania Dec 10, 2024
75c8eb7
Merge branch 'origin/dev-bpolania/workflows' of https://github.com/st…
bpolania Dec 10, 2024
0e55860
Update pr-internal.yml
bpolania Dec 10, 2024
bb7244e
Update test_file.txt
bpolania Dec 10, 2024
6ee9c2e
Delete pr-merge.yaml
bpolania Dec 10, 2024
1338c9d
Merge branch 'origin/dev-bpolania/workflows' into origin/dev-polania/…
bpolania Dec 10, 2024
d29c642
Update test_file.txt
bpolania Dec 10, 2024
dc56e1f
Update test_file.txt
bpolania Dec 10, 2024
8985f68
Merge pull request #359 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 10, 2024
995d20d
Update pr-internal.yml
bpolania Dec 10, 2024
f929cd1
Update test_file.txt
bpolania Dec 10, 2024
896cdc3
Merge pull request #360 from storyprotocol/origin/dev-polania/workflo…
bpolania Dec 10, 2024
753ca6e
pre-PR commit
bpolania Dec 10, 2024
752764a
Merge branch 'origin/dev-bpolania/workflows' of https://github.com/st…
bpolania Dec 10, 2024
db80b16
Merge branch 'dev' of https://github.com/storyprotocol/sdk into dev
bpolania Dec 10, 2024
d759c99
Merge branch 'dev' into origin/dev-bpolania/workflows
bpolania Dec 10, 2024
52ee271
Update dispute.test.ts
bpolania Dec 10, 2024
f116aa0
Update royalty.test.ts
bpolania Dec 10, 2024
f760276
Update package.json
bpolania Dec 10, 2024
92b162e
Update pr-internal.yml
bpolania Dec 11, 2024
5da3cf9
Update package.json
bpolania Dec 11, 2024
56c2c9c
Merge pull request #361 from storyprotocol/origin/dev-bpolania/workflows
bpolania Dec 11, 2024
f9bba29
Enhance some features (#366)
bonnie57 Dec 17, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 3 additions & 3 deletions .github/workflows/pr-external.yaml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: Workflow for External PRs
name: Workflow for External PRs with Unit Tests

on:
pull_request_target:
Expand All @@ -21,10 +21,10 @@ jobs:
Timestamp_PR_APPROVED:
needs: [authorize]
uses: storyprotocol/gha-workflows/.github/workflows/reusable-timestamp.yml@main

build_and_test:
needs: [authorize, Timestamp_PR_APPROVED]
uses: storyprotocol/gha-workflows/.github/workflows/reusable-build-test-workflow.yml@main
uses: storyprotocol/gha-workflows/.github/workflows/reusable-build-unit-test-workflow.yml@main
with:
sha: ${{ github.event.pull_request.head.sha }}
ENVIRONMENT: "beta-sepolia"
Expand Down
23 changes: 16 additions & 7 deletions .github/workflows/pr-internal.yml
Original file line number Diff line number Diff line change
@@ -1,27 +1,36 @@
name: Workflow for internal PRs
name: Conditional Workflow

on:
push:
pull_request:
branches:
- main
- dev

pull_request:
push:
branches:
- main
- dev

jobs:
Timestamp:
if: ${{ github.event.pull_request.head.repo.full_name == github.repository }}
uses: storyprotocol/gha-workflows/.github/workflows/reusable-timestamp.yml@main

build_and_test:
pr_build_and_test:
if: github.event_name == 'pull_request'
needs: [Timestamp]
uses: storyprotocol/gha-workflows/.github/workflows/reusable-build-test-workflow.yml@main
uses: storyprotocol/gha-workflows/.github/workflows/reusable-build-unit-test-workflow.yml@main
with:
sha: ${{ github.event.pull_request.head.sha }}
ENVIRONMENT: "beta-sepolia"
secrets:
WALLET_PRIVATE_KEY: ${{ secrets.WALLET_PRIVATE_KEY }}
TEST_WALLET_ADDRESS: ${{ secrets.TEST_WALLET_ADDRESS }}

push_build_and_test:
if: github.event_name == 'push'
uses: storyprotocol/gha-workflows/.github/workflows/reusable-build-integration-test-workflow.yml@main
with:
sha: ${{ github.sha }}
ENVIRONMENT: "beta-sepolia"
secrets:
WALLET_PRIVATE_KEY: ${{ secrets.WALLET_PRIVATE_KEY }}
TEST_WALLET_ADDRESS: ${{ secrets.TEST_WALLET_ADDRESS }}
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
"lint": "turbo run lint",
"fix": "turbo run fix",
"test": "turbo run test --no-cache --concurrency=1",
"test:integration": "turbo run test:integration --no-cache",
"prepare": "husky install"
},
"devDependencies": {
Expand Down
2 changes: 1 addition & 1 deletion packages/core-sdk/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@story-protocol/core-sdk",
"version": "1.2.0-rc.3",
"version": "1.2.0-rc.4",
"description": "Story Protocol Core SDK",
"main": "dist/story-protocol-core-sdk.cjs.js",
"module": "dist/story-protocol-core-sdk.esm.js",
Expand Down
20 changes: 10 additions & 10 deletions packages/core-sdk/src/abi/generated.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10946,8 +10946,8 @@ export const royaltyTokenDistributionWorkflowsAbi = [
},
{
name: "terms",
internalType: "struct PILTerms",
type: "tuple",
internalType: "struct PILTerms[]",
type: "tuple[]",
components: [
{ name: "transferable", internalType: "bool", type: "bool" },
{ name: "royaltyPolicy", internalType: "address", type: "address" },
Expand Down Expand Up @@ -11010,7 +11010,7 @@ export const royaltyTokenDistributionWorkflowsAbi = [
outputs: [
{ name: "ipId", internalType: "address", type: "address" },
{ name: "tokenId", internalType: "uint256", type: "uint256" },
{ name: "licenseTermsId", internalType: "uint256", type: "uint256" },
{ name: "licenseTermsIds", internalType: "uint256[]", type: "uint256[]" },
],
stateMutability: "nonpayable",
},
Expand Down Expand Up @@ -11094,8 +11094,8 @@ export const royaltyTokenDistributionWorkflowsAbi = [
},
{
name: "terms",
internalType: "struct PILTerms",
type: "tuple",
internalType: "struct PILTerms[]",
type: "tuple[]",
components: [
{ name: "transferable", internalType: "bool", type: "bool" },
{ name: "royaltyPolicy", internalType: "address", type: "address" },
Expand Down Expand Up @@ -11168,7 +11168,7 @@ export const royaltyTokenDistributionWorkflowsAbi = [
name: "registerIpAndAttachPILTermsAndDeployRoyaltyVault",
outputs: [
{ name: "ipId", internalType: "address", type: "address" },
{ name: "licenseTermsId", internalType: "uint256", type: "uint256" },
{ name: "licenseTermsIds", internalType: "uint256[]", type: "uint256[]" },
{ name: "ipRoyaltyVault", internalType: "address", type: "address" },
],
stateMutability: "nonpayable",
Expand Down Expand Up @@ -23809,7 +23809,7 @@ export type RoyaltyTokenDistributionWorkflowsDistributeRoyaltyTokensRequest = {
* @param spgNftContract address
* @param recipient address
* @param ipMetadata tuple
* @param terms tuple
* @param terms tuple[]
* @param royaltyShares tuple[]
*/
export type RoyaltyTokenDistributionWorkflowsMintAndRegisterIpAndAttachPilTermsAndDistributeRoyaltyTokensRequest =
Expand Down Expand Up @@ -23840,7 +23840,7 @@ export type RoyaltyTokenDistributionWorkflowsMintAndRegisterIpAndAttachPilTermsA
derivativeRevCeiling: bigint;
currency: Address;
uri: string;
};
}[];
royaltyShares: {
author: Address;
percentage: number;
Expand Down Expand Up @@ -23884,7 +23884,7 @@ export type RoyaltyTokenDistributionWorkflowsMintAndRegisterIpAndMakeDerivativeA
* @param nftContract address
* @param tokenId uint256
* @param ipMetadata tuple
* @param terms tuple
* @param terms tuple[]
* @param sigMetadata tuple
* @param sigAttach tuple
*/
Expand Down Expand Up @@ -23916,7 +23916,7 @@ export type RoyaltyTokenDistributionWorkflowsRegisterIpAndAttachPilTermsAndDeplo
derivativeRevCeiling: bigint;
currency: Address;
uri: string;
};
}[];
sigMetadata: {
signer: Address;
deadline: bigint;
Expand Down
3 changes: 3 additions & 0 deletions packages/core-sdk/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,7 @@ export type {
RegisterNonComSocialRemixingPILRequest,
RegisterCommercialUsePILRequest,
RegisterCommercialRemixPILRequest,
RegisterPILTermsRequest,
RegisterPILResponse,
AttachLicenseTermsRequest,
AttachLicenseTermsResponse,
Expand Down Expand Up @@ -156,3 +157,5 @@ export type {
export { getPermissionSignature, getSignature } from "./utils/sign";

export { convertCIDtoHashIPFS, convertHashIPFStoCID } from "./utils/ipfs";

export type { TxOptions } from "./types/options";
53 changes: 32 additions & 21 deletions packages/core-sdk/src/resources/ipAsset.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1524,12 +1524,12 @@ export class IPAssetClient {
}
}
/**
* Register the given NFT and attach license terms and distribute royalty tokens. In order to successfully distribute royalty tokens, the license terms attached to the IP must be
* Register the given NFT and attach license terms and distribute royalty tokens. In order to successfully distribute royalty tokens, the first license terms attached to the IP must be
* a commercial license.
* @param request - The request object that contains all data needed to register ip and attach license terms and distribute royalty tokens.
* @param request.nftContract The address of the NFT collection.
* @param request.tokenId The ID of the NFT.
* @param request.terms The array of license terms to be attached.
* @param {Array} request.terms The array of license terms to be attached.
* @param request.terms.transferable Indicates whether the license is transferable or not.
* @param request.terms.royaltyPolicy The address of the royalty policy contract which required to StoryProtocol in advance.
* @param request.terms.mintingFee The fee to be paid when minting a license.
Expand Down Expand Up @@ -1557,19 +1557,24 @@ export class IPAssetClient {
* @param request.royaltyShares.percentage The percentage of the royalty share, 10 represents 10%.
* @param request.deadline [Optional] The deadline for the signature in seconds, default is 1000s.
* @param request.txOptions [Optional] This extends `WaitForTransactionReceiptParameters` from the Viem library, excluding the `hash` property, without encodedTxData option.
* @returns A Promise that resolves to a transaction hashes, IP ID, License terms ID, and IP royalty vault.
* @returns A Promise that resolves to a transaction hashes, IP ID, IP royalty vault and an array containing the license terms ID.
* @emits IPRegistered (ipId, chainId, tokenContract, tokenId, name, uri, registrationDate)
* @emits IpRoyaltyVaultDeployed (ipId, ipRoyaltyVault)
*/
public async registerIPAndAttachLicenseTermsAndDistributeRoyaltyTokens(
request: RegisterIPAndAttachLicenseTermsAndDistributeRoyaltyTokensRequest,
): Promise<RegisterIPAndAttachLicenseTermsAndDistributeRoyaltyTokensResponse> {
try {
if (!request.terms.commercialUse) {
throw new Error("Commercial use is required to deploy a royalty vault.");
}
const { royaltyShares, totalAmount } = this.getRoyaltyShares(request.royaltyShares);
const licenseTerm = await validateLicenseTerms(request.terms, this.rpcClient);
const licenseTerms: LicenseTerms[] = [];
for (let i = 0; i < request.terms.length; i++) {
const term = request.terms[i];
if (i === 0 && !term.commercialUse) {
throw new Error("The first license term must be a commercial license.");
}
const licenseTerm = await validateLicenseTerms(term, this.rpcClient);
licenseTerms.push(licenseTerm);
}
const blockTimestamp = (await this.rpcClient.getBlock()).timestamp;
const calculatedDeadline = getDeadline(blockTimestamp, request.deadline);
const ipIdAddress = await this.getIpIdAddress(
Expand Down Expand Up @@ -1629,7 +1634,7 @@ export class IPAssetClient {
nftMetadataURI: request.ipMetadata?.nftMetadataURI || "",
nftMetadataHash: request.ipMetadata?.nftMetadataHash || zeroHash,
},
terms: licenseTerm,
terms: licenseTerms,
sigMetadata: {
signer: this.wallet.account!.address,
deadline: calculatedDeadline,
Expand All @@ -1647,7 +1652,7 @@ export class IPAssetClient {
hash: registerIpAndAttachPilTermsAndDeployRoyaltyVaultTxHash,
});
const { ipId } = this.getIpIdAndTokenIdsFromEvent(txReceipt)[0];
const licenseTermsId = await this.getLicenseTermsId([licenseTerm]);
const licenseTermsIds = await this.getLicenseTermsId(licenseTerms);
const { ipRoyaltyVault } =
this.royaltyModuleEventClient.parseTxIpRoyaltyVaultDeployedEvent(txReceipt)[0];
const distributeRoyaltyTokensTxHash = await this.distributeRoyaltyTokens({
Expand All @@ -1669,7 +1674,7 @@ export class IPAssetClient {
registerIpAndAttachPilTermsAndDeployRoyaltyVaultTxHash,
distributeRoyaltyTokensTxHash,
ipId,
licenseTermsId: licenseTermsId[0],
licenseTermsIds,
ipRoyaltyVault,
};
} catch (error) {
Expand Down Expand Up @@ -1703,7 +1708,7 @@ export class IPAssetClient {
* @emits IPRegistered (ipId, chainId, tokenContract, tokenId, name, uri, registrationDate)
* @emits IpRoyaltyVaultDeployed (ipId, ipRoyaltyVault)
*/
public async registerDerivativeAndAttachLicenseTermsAndDistributeRoyaltyTokens(
public async registerDerivativeIpAndAttachLicenseTermsAndDistributeRoyaltyTokens(
request: RegisterDerivativeAndAttachLicenseTermsAndDistributeRoyaltyTokensRequest,
): Promise<RegisterDerivativeAndAttachLicenseTermsAndDistributeRoyaltyTokensResponse> {
try {
Expand Down Expand Up @@ -1806,7 +1811,7 @@ export class IPAssetClient {
});
}
return {
registerDerivativeAndAttachLicenseTermsAndDistributeRoyaltyTokensTxHash: txHash,
registerDerivativeIpAndAttachLicenseTermsAndDistributeRoyaltyTokensTxHash: txHash,
distributeRoyaltyTokensTxHash,
ipId,
tokenId,
Expand All @@ -1821,11 +1826,11 @@ export class IPAssetClient {
}

/**
* Mint an NFT and register the IP, attach PIL terms, and distribute royalty tokens. In order to successfully distribute royalty tokens, the license terms attached to the IP must be
* Mint an NFT and register the IP, attach PIL terms, and distribute royalty tokens. In order to successfully distribute royalty tokens, First the license terms attached to the IP must be
* a commercial license.
* @param request - The request object that contains all data needed to mint an NFT and register the IP, attach PIL terms, and distribute royalty tokens.
* @param request.spgNftContract The address of the SPG NFT contract.
* @param request.terms The array of license terms to be attached.
* @param {Array} request.terms The array of license terms to be attached.
* @param request.terms.transferable Indicates whether the license is transferable or not.
* @param request.terms.royaltyPolicy The address of the royalty policy contract which required to StoryProtocol in advance.
* @param request.terms.mintingFee The fee to be paid when minting a license.
Expand Down Expand Up @@ -1853,17 +1858,23 @@ export class IPAssetClient {
* @param request.royaltyShares.percentage The percentage of the royalty share, 10 represents 10%.
* @param request.recipient - [Optional] The address to receive the minted NFT,default value is your wallet address.
* @param request.txOptions [Optional] This extends `WaitForTransactionReceiptParameters` from the Viem library, excluding the `hash` property, without encodedTxData option.
* @returns A Promise that resolves to a transaction hash, IP ID, License terms ID, and IP royalty vault, Token ID.
* @returns A Promise that resolves to a transaction hash, IP ID, IP royalty vault, Token ID, and an array containing the license terms ID.
* @emits IPRegistered (ipId, chainId, tokenContract, tokenId, name, uri, registrationDate)
* @emits IpRoyaltyVaultDeployed (ipId, ipRoyaltyVault)
*/
public async mintAndRegisterIpAndAttachPilTermsAndDistributeRoyaltyTokens(
request: MintAndRegisterIpAndAttachPILTermsAndDistributeRoyaltyTokensRequest,
): Promise<MintAndRegisterIpAndAttachPILTermsAndDistributeRoyaltyTokensResponse> {
try {
if (!request.terms.commercialUse) {
throw new Error("Commercial use is required to deploy a royalty vault.");
const licenseTerms: LicenseTerms[] = [];
for (let i = 0; i < request.terms.length; i++) {
const term = request.terms[i];
if (i === 0 && !term.commercialUse) {
throw new Error("First license term must be a commercial license.");
}
const licenseTerm = await validateLicenseTerms(term, this.rpcClient);
licenseTerms.push(licenseTerm);
}
const licenseTerm = await validateLicenseTerms(request.terms, this.rpcClient);
const { royaltyShares } = this.getRoyaltyShares(request.royaltyShares);
const txHash =
await this.royaltyTokenDistributionWorkflowsClient.mintAndRegisterIpAndAttachPilTermsAndDistributeRoyaltyTokens(
Expand All @@ -1878,7 +1889,7 @@ export class IPAssetClient {
nftMetadataURI: request.ipMetadata?.nftMetadataURI || "",
nftMetadataHash: request.ipMetadata?.nftMetadataHash || zeroHash,
},
terms: licenseTerm,
terms: licenseTerms,
royaltyShares,
},
);
Expand All @@ -1888,13 +1899,13 @@ export class IPAssetClient {
hash: txHash,
});
const { ipId, tokenId } = this.getIpIdAndTokenIdsFromEvent(txReceipt)[0];
const licenseTermsId = await this.getLicenseTermsId([licenseTerm]);
const licenseTermsIds = await this.getLicenseTermsId(licenseTerms);
const { ipRoyaltyVault } =
this.royaltyModuleEventClient.parseTxIpRoyaltyVaultDeployedEvent(txReceipt)[0];
return {
txHash,
ipId,
licenseTermsId: licenseTermsId[0],
licenseTermsIds,
ipRoyaltyVault,
tokenId,
};
Expand Down
10 changes: 5 additions & 5 deletions packages/core-sdk/src/types/resources/ipAsset.ts
Original file line number Diff line number Diff line change
Expand Up @@ -275,7 +275,7 @@ export type BatchRegisterResponse = {
export type RegisterIPAndAttachLicenseTermsAndDistributeRoyaltyTokensRequest = {
nftContract: Address;
tokenId: bigint | string | number;
terms: RegisterPILTermsRequest;
terms: RegisterPILTermsRequest[];
deadline?: string | number | bigint;
royaltyShares: RoyaltyShare[];
txOptions?: Omit<TxOptions, "encodedTxDataOnly">;
Expand All @@ -284,7 +284,7 @@ export type RegisterIPAndAttachLicenseTermsAndDistributeRoyaltyTokensResponse =
registerIpAndAttachPilTermsAndDeployRoyaltyVaultTxHash: Hex;
distributeRoyaltyTokensTxHash: Hex;
ipId: Address;
licenseTermsId: bigint;
licenseTermsIds: bigint[];
ipRoyaltyVault: Address;
};
export type DistributeRoyaltyTokens = {
Expand Down Expand Up @@ -318,7 +318,7 @@ export type RegisterDerivativeAndAttachLicenseTermsAndDistributeRoyaltyTokensReq
} & IPMetadataInfo;

export type RegisterDerivativeAndAttachLicenseTermsAndDistributeRoyaltyTokensResponse = {
registerDerivativeAndAttachLicenseTermsAndDistributeRoyaltyTokensTxHash: Address;
registerDerivativeIpAndAttachLicenseTermsAndDistributeRoyaltyTokensTxHash: Address;
distributeRoyaltyTokensTxHash: Address;
ipId: Address;
tokenId: bigint;
Expand All @@ -327,7 +327,7 @@ export type RegisterDerivativeAndAttachLicenseTermsAndDistributeRoyaltyTokensRes

export type MintAndRegisterIpAndAttachPILTermsAndDistributeRoyaltyTokensRequest = {
spgNftContract: Address;
terms: RegisterPILTermsRequest;
terms: RegisterPILTermsRequest[];
royaltyShares: {
author: Address;
percentage: number;
Expand All @@ -339,7 +339,7 @@ export type MintAndRegisterIpAndAttachPILTermsAndDistributeRoyaltyTokensRequest
export type MintAndRegisterIpAndAttachPILTermsAndDistributeRoyaltyTokensResponse = {
txHash: Hex;
ipId?: Address;
licenseTermsId?: bigint;
licenseTermsIds?: bigint[];
ipRoyaltyVault?: Address;
tokenId?: bigint;
};
Expand Down
Loading
Loading