@mojito-inc/core-service
Version:
Mojito Core API service for auction, payment, token
1,988 lines (1,614 loc) • 74 kB
Markdown
<br />
<h1 align="center">☁️ Mojito Modules - Core Service</h1>
<br /><br />
<p align="center">
👨💻 React components for the Mojito Platform, Reference App and third-party projects, including Mojito's core service
<br />
<p align="center">
Version: 1.0.0
</p>
<br />
## Using this library in your project Core Service
You can install this project with one of these commands:
npm i @mojito-inc/core-service
yarn add @mojito-inc/core-service
<br />
## In order to use this package you must install this dependency
You can install the package with one of these commands:
npm i graphql
yarn add graphql
<br />
Once the package is installed, you can import the library using import;
Two way of integration Core API provider uri or apollo client, if pass both param priority is client only.
### For development URL
baseURL = https://api.mojito.xyz/query
### For production URL
baseURL = https://api-dev.mojito.xyz/query
```
import { CoreServiceProvider } from "@mojito-inc/core-service";
<CoreServiceProvider uri={ baseURL } token={ 'Bearer <Token>' }>
{ children }
</CoreServiceProvider>
```
</br>
|Param |type | Description
|:--- | --- | :---:|
|uri| string|skip this param, if client param passed
|client| [Apollo Client](#https://www.apollographql.com/docs/react/get-started#step-3-initialize-apolloclient) | skip this param, if uri param passed
|token| string| Optional
</br>
## useAuth Hook to check whether session is Expired or Active
```
import { useAuth } from '@mojito-inc/core-service';
const { sessionStatus } = useAuth();
```
After setup with CoreServiceProvider, API can be access via hooks
following the api are
1. [GetSignature Message](#GetSignatureMessage)
2. [LoginWithSignature](#LoginWithSignature)
3. [RedeemClaimable Code](#RedeemClaimableCode)
4. [Redeem Earnable Item](#redeemEarnableItem)
5. [getInvoiceDetails](#getInvoiceDetails)
6. [Redeem Earnable Code](#redeemEarnableCode)
7. [SignUpWithSignature](#SignUpWithSignature)
8. [get Contract Details](#getContractDetails)
9. [complete Onchain Claim](#completeOnchainClaim)
### GetSignatureMessage
It will provide a message that should be used for in signing process
```
import { useClaims, Response, GetSignatureData } from "@mojito-inc/core-service";
const { getSignatureMessage } = useClaims();
const response: Response<GetSignatureData> = await getSignatureMessage({
orgId: <ORG_ID>,
networkID: <NETWORK_ID>,
walletAddress: <WALLET_ADDRESS>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgId| UUID1|✅|
|networkID| UUID1 |✅|
|walletAddress| string |✅|
##### Response
```
{
"data: {
"getSignatureMessage": "This message is used for signature validation for organization caa and wallet address 0x6588ec22a85d611c8c3cd254d0c063d0be78a6c1 at 2023-02-22T04:39:23Z"
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
</br>
### LoginWithSignature
The request receiver retrieves the Signature security token
```
import { useClaims, Response, LoginWithSignatureData } from "@mojito-inc/core-service";
const { loginWithSignature } = useClaims();
const response: Response<LoginWithSignatureData> = await loginWithSignature({
challenge: <GET_SIGNATURE_MESSAGE>,
signature: <CROSS_MINT_SIGNATURE>,
signer: <SIGNER_ADDRESS>,
chainId: <CHAIN_ID>,
orgId: <ORG_ID>
});
```
</br>
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|challenge| String|✅|
|signature| String |✅|
|signer| String |✅|
|chainId| Int |✅| Int can represent values between -(2^31) and 2^31 - 1
|orgId| UUID1 |✅|
##### Response
```
{
"data": {
"loginWithSignature": {
"token": "344fbc51-b6d4-4428-9783-b09dd9df95fb"
}
}
}
```
##### Error
- Challenge is too old, please request a new one
</br>
### RedeemClaimableCode
Redeem a claimable code
```
import { useClaims, Response, RedeemClaimableCodeData } from "@mojito-inc/core-service";
const { redeemClaimableCode } = useClaims();
const response: Response<RedeemClaimableCodeData> = await redeemClaimableCode({
code: discountCode,
destAddr: address,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|code| string|✅|
|destAddr| string |✅|
##### Response
```
{
"data": {
"redeemClaimableCode": {
"success": true
}
}
}
```
##### Error
- Challenge is too old, please request a new one
</br>
### redeemEarnableItem
Redeem Earnable Item.
```
import { useClaims, RedeemEarnableItemData, Response } from '@mojito-inc/core-service';
const { redeemEarnableItem } = useClaims();
const response: Response<RedeemEarnableItemData> = await redeemEarnableItem({
claimableItemId: claimableItemId,
destAddr: destAddr,
gating: gating
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|claimableItemId|string|✅|
|destAddr| string| |
|gating| object| |[gating](#gating)
#### gating
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|ruleId| string|✅|
|contractAddress| string|✅|
|tokenId| string|✅|
|ownerWallet| string|✅|
##### Error
- Invalid claimableItemId.
</br>
### getInvoiceDetails
Get the Invoice detail of the Given invoice id.
```
import { useClaims, Response, GetClaimInvoiceDetailData } from '@mojito-inc/core-service';
const { getInvoiceDetails } = useClaims();
const response: Response<GetClaimInvoiceDetailData> = await getInvoiceDetails({
invoiceID: invoiceID
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|invoiceID|string|✅|
#### error
- Invalid Invoice id
</br>
### redeemEarnableCode
Redeem a claimable code
```
import { useClaims, Response, RedeemEarnableCodeData } from "@mojito-inc/core-service";
const { redeemEarnableCode } = useClaims();
const response: Response<RedeemEarnableCodeData> = await redeemEarnableCode({
code: discountCode,
destAddr: address,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|code| string|✅|
|destAddr| string | |
##### Response
```
{
"data": {
"redeemEarnableCode": {
"redeemInitiated": true,
"invoiceID": "278806fb-d82c-4d9c-bda0-ace148452c00"
}
}
}
```
##### Error
- Invalid code
</br>
### SignUpWithSignature
The request receiver retrieves the Signature security token
```
import { useClaims, Response, SignUpWithSignatureData } from "@mojito-inc/core-service";
const { signUpWithSignature } = useClaims();
const response: Response<SignUpWithSignatureData> = await signUpWithSignature({
challenge: <GET_SIGNATURE_MESSAGE>,
signature: <CROSS_MINT_SIGNATURE>,
signer: <SIGNER_ADDRESS>,
chainId: <CHAIN_ID>,
orgId: <ORG_ID>,
firstName: <FIRST_NAME>,
lastName: <LAST_NAME>,
email: <EMAIL>
});
```
</br>
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|challenge| String|✅|
|signature| String |✅|
|signer| String |✅|
|chainId| Int |✅| Int can represent values between -(2^31) and 2^31 - 1
|orgId| UUID1 |✅|
|firstName| String |✅|
|lastName| String |✅|
|email| String |✅|
##### Response
```
{
"data": {
"signUpWithSignature": {
"token": "344fbc51-b6d4-4428-9783-b09dd9df95fb"
}
}
}
```
##### Error
- Challenge is too old, please request a new one
</br>
### getContractDetails
It will provide a contract details
```
import { useClaims, Response, GetContractDetailsData } from "@mojito-inc/core-service";
const { getContractDetails } = useClaims();
const response: Response<GetContractDetailsData> = await getContractDetails({
orgId: <ORG_ID>,
networkId: <NETWORK_ID>,
contractType: <CONTRACT_TYPE>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgId| UUID1|✅|
|networkId| UUID1 |✅|
|contractType| string |✅|
##### Response
```
{
"data: {
"getContractDetails": {
"id": "",
}
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
</br>
### completeOnchainClaim
Complete onchain claim
```
import { useClaims, Response, CompleteOnchainClaimData } from "@mojito-inc/core-service";
const { completeOnchainClaim } = useClaims();
const response: Response<CompleteOnchainClaimData> = await completeOnchainClaim({
invoiceId: <invoiceId>,
txHash: <txHash>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|invoiceId| string|✅|
|txHash| string |✅|
##### Response
```
{
"data": {
"completeOnchainClaim": true
}
}
```
##### Error
- error getting invoice by id: <invoiceID> record not found
</br>
### GetUsdConversion
will receives 1 unit crypto equivalent USD price
```
import { useConversion, Response, USDConversionData } from '@mojito-inc/core-service';
const { getUSDConversion } = useConversion();
const response: Response<USDConversionData> = await getUSDConversion({ cryptoCurrencyCode: <cryptoCurrencyCode> });
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|cryptoCurrencyCode| enum|✅| [CryptoCurrencyCode](#CryptoCurrencyCode)|
##### CryptoCurrencyCode
##### enum
|Enum Variable |value |
|:--- | --- |
|ETH| ETH|
|MATIC | MATIC |
|WETH| WETH|
|WMATIC | WMATIC |
##### Response
```
{
"data": {
"getUSDPrice": {
"amount": "1799.34",
"currency": "USD",
"base": "ETH",
}
}
}
```
##### Error
- Expected type CryptoCurrenyCode!, found "".
### GetSupportedCurrency
will receives list of supported currency by id
```
import { useConversion, Response, GetSupportedCurrenciesData } from '@mojito-inc/core-service';
const { getSupportedCurrency, GetSupportedCurrenciesData } = useConversion();
const response: Response<GetSupportedCurrenciesData> = await getSupportedCurrency({ nftTokenId: '514fedfe-165b-451b-b2f6-63667e66c096', orgId: 'f2f5c627-5421-4c40-9913-edfd09dd98b3' });
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|nftTokenId| UUID|✅|
|orgId| UUID|✅|
##### Response
```
{
"data": {
"getSupportedCurrencies": [
{
"id": "8b2343d6-8a8b-11ed-9e0a-42010a940031",
"name": "ETH",
"networkId": "c41db347-0ee3-4212-943a-ca213b8e0ea8",
"symbol": "ETH",
"contractAddress": "0x0000000000000000000000000000000000000000",
"secondaryMarketplaceContractAddress": "0xB658b650F0B2Dacd90aF58Ad78b3a6F8eb9BdF21",
"network": {
"id": "c41db347-0ee3-4212-943a-ca213b8e0ea8",
"name": "Goerli Testnet",
"chainID": 5,
"wethAddress": "0xB4FBF271143F4FBf7B91A5ded31805e42b2208d6",
"paymentCurrency": "WETH"
}
},
]
}
}
```
##### Error
- error getting token by ID:<orgId> record not found.
### AuctionDetails
Auction Details and Auction History
```
import { useAuction } from '@mojito-inc/core-service';
const { auctionDetails } = useAuction();
const response: Response<AuctionData> = await auctionDetails({ id: <ID> });
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|id| UUID|✅| |
##### Response
```
{
"data": {
"collectionItemById": {
"id": "8ed1783c-c4c4-47f1-9384-5ff64f2ebc97",
"name": "POCA During Sale 2",
"artist": null,
"status": "Active",
"description": null,
"details": {
"id": "68d2fee2-db56-48f4-9e10-e703e9054ae6",
"startingBid": 0.0001,
"startDate": "2023-03-22T05:00:00Z",
"endDate": "2023-03-22T11:00:00Z",
"currentBid": {
"userId": "afca6cad-782c-4338-b71d-9193b14b736d",
"currentBid": 0.0002,
"isMine": false,
"walletAddress": "0x669dbFF9c68CAC7b52C4B789f5Ebc3b5293D0a73",
"marketplaceUser": {
"id": "afca6cad-782c-4338-b71d-9193b14b736d",
"username": null,
"avatar": null,
},
},
"myBid": null,
"bids": [
{
"id": "9b407667-fc96-4022-a892-8c5d2fea4e52",
"amount": 0.0002,
"createdAt": "2023-03-22T09:32:15Z",
"maximumBid": null,
"marketplaceAuctionLotId": "68d2fee2-db56-48f4-9e10-e703e9054ae6",
"walletAddress": "0x669dbFF9c68CAC7b52C4B789f5Ebc3b5293D0a73",
"txHash": "0xa6d9d6474e759134bd85d9111376366a3e8360f93eafc723646967c63d675422",
"marketplaceUser": {
"id": "afca6cad-782c-4338-b71d-9193b14b736d",
"username": null,
"avatar": null,
},
}
],
},
}
}
}
```
##### Error
- uuid: incorrect UUID length.
### VerifyOnchainBid
Receive tax and contract address
```
import { useAuction, OnChainBidResponse } from '@mojito-inc/core-service';
const { verifyOnChainBid } = useAuction();
const response: Response<OnChainBidResponse> = await verifyOnChainBid({
lotID=<lotID>,
orgID=<orgID>,
walletAddress=<walletAddress>,
amount: <amount>, });
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|lotID| UUID|✅| |
|orgID| UUID|✅| |
|walletAddress| string|✅| |
|amount| Int|✅| |
##### Response
```
{
"data": {
"verifyOnchainBid": {
"amount": 0.0003,
"tax": 0.000055575933397801415,
"onChainAuctionContractAddress": "0xeed7f3e16a6018d65dffd63bc30ac252c034edc1",
"commissionFee": 0.000005999999999999999,
"platformFee": 0.000005999999999999999,
"__typename": "OnChainBidResponse"
}
}
}
```
##### Error
- jwt token invalid or has been expired
- uuid: incorrect UUID length
- error fetching user wallet: wallet by address by not found: record not found
- amount is less then current bid + min increment
### confirmOnchainBid
Auction submit
```
import { confirmOnChainBid, BidsItemData } from '@mojito-inc/core-service';
const { confirmOnChainBid } = useAuction();
const response: Promise<Response<BidsItemData>> = await confirmOnChainBid({
lotID=<lotID>
orgID=<orgID>
walletAddress=<walletAddress>
amount=<amount>
tax=<tax>
txhash=<txhash>
commissionFee=<commissionFee>
platformFee<platformFee<> });
```
##### Response
```
{
"data": {
"confirmOnchainBid": {
"amount": 0.0005,
"tax": 0.00007216969871926542,
"__typename": "MarketplaceAuctionBid"
}
}
}
```
##### Error
- jwt token invalid or has been expired
- uuid: incorrect UUID length
- error fetching user wallet: wallet by address by not found: record not found
- error creating marketplace auction bid: bid amount is below the current bid
### createMarketplaceAuctionBid
Create Auction Bid
```
import { createMarketplaceAuctionBid, CreateMarketplaceAuctionBidData } from '@mojito-inc/core-service';
const { createMarketplaceAuctionBid } = useAuction();
const response: Promise<Response<CreateMarketplaceAuctionBidData> = await createMarketplaceAuctionBid({
marketplaceAuctionLotId=<marketplaceAuctionLotId>
amount=<amount> });
```
##### Response
```
{
"data": {
"createMarketplaceAuctionBid": {
"id": "95962a20-2194-493e-ba2d-7abc5cea93bf",
"marketplaceAuctionLotId": "95962a20-2194-493e-ba2d-7abc5cea93bf",
"amount": 0.0005,
}
}
}
```
##### Error
- jwt token invalid or has been expired
- uuid: incorrect UUID length
- error creating marketplace auction bid: bid amount is below the current bid
User API can be access via hooks
following the api are
1. [me](#me)
2. [updateUserOrgSettings](#updateUserOrgSettings)
### me
It will provide a active user data
```
import { useUser, GetUserData } from "@mojito-inc/core-service";
const { currentUser } = useUser();
const response: Response<GetUserData> = await currentUser({
orgId: <ORG_ID>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgId| UUID1|✅|
##### Response
```
{
"data: {
"me": {
"id": "d1a59f7e-8626-46f9-b0ca-b70477910c8c",
"userOrgs": [
{
"id": "30ec5163-90bc-4b6a-a0a1-8696cc19c327",
"role": "Admin",
"organizationId": "d086ea16-d40d-454c-84a4-64b5e940670a",
"organization": {
"purchaseLimitWithoutKYC": 0
},
"kycStatus": "Clear",
"w8Form": true,
"isBlacklisted": false,
"bidAllowed": true,
"avatar": null,
"username": "020704f2-cb16-4c26-bed0-4ac0dbdf67bb",
"settings": null,
"reason": ""
}
]
}
}
}
```
##### Error
- access denied
### updateUserOrgSettings
It can able to update the user details
```
import { useUser, updateUserOrgSettingsData } from "@mojito-inc/core-service";
const { updateUserOrgSettings } = useUser();
const response: Response<updateUserOrgSettingsData> = await updateUserOrgSettings({
userOrgId: <USER_ORG_ID>,
username: <USER_NAME>,
avatar: <AVATAR>,
settingsJson: <SETTING_JSON>,
profilePic: <PROFILE_PIC>
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|userOrgId| UUID1|✅|
|username| String|✅|
|avatar| String|✅|
|settingsJson| String|
|profilePic| String|
##### Response
```
{
"data: {
"updateUserOrgSettings": {
"id": "d1a59f7e-8626-46f9-b0ca-b70477910c8c",
"username": "test",
"avatar": "U0BpDFXLEKmMNPly",
}
}
}
```
##### Error
- user is not authorized to update record within userOrgID <userOrgId>
KYC API can be access via hooks
following the api are
1. [createApplicant](#createApplicant)
2. [createCheck](#createCheck)
3. [getApplicant](#getApplicant)
4. [getSDKToken](#getSDKToken)
5. [updateApplicant](#updateApplicant)
### createApplicant
It can able to create form to complete KYC
```
import { useKYC } from "@mojito-inc/core-service";
const { createApplicant } = useKYC();
const response: Response<CreateApplicantData> = await createApplicant({
orgID: <ORG_ID>,
input: {
firstName: <FIRST_NAME>,
lastName: <LAST_NAME>,
dob: <DATE_OF_BIRTH>,
address: {
country: <COUNTRY>,
state: <STATE>,
town: <TOWN>,
postcode: <POSTAL_CODE>
}
},
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgID| UUID1|✅|
|input| ApplicantRequest|✅|
##### Response
```
{
"data: {
"createApplicant": {
"id": "7578afa6-cb7e-45cc-82ef-5c5821ebec42",
"firstName": "test",
"lastName": "test",
"email": "",
"dob": "1998-12-22",
"href": "/v3.2/applicants/7578afa6-cb7e-45cc-82ef-5c5821ebec42",
"idNumbers": null,
"address": {
"flatNumber": null,
"buildingNumber": "12",
"buildingName": null,
"street": "test road",
"subStreet": null,
"town": "new york",
"postcode": "12345",
"country": "US",
"line1": null,
"line2": null,
"line3": null,
"state": "new york"
}
}
}
}
```
##### Error
- error getting user organization KYC by applicant id: <OrgId> record not found
### createCheck
It can able to check the details
```
import { useKYC } from "@mojito-inc/core-service";
const { createCheck } = useKYC();
const response: Response<CreateCheckData> = await createCheck({
applicantID: <APPLICANT_ID>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|applicantID| UUID1|✅|
##### Response
```
{
"data: {
"createCheck": {
"id": "c2854107-93b6-4200-a1f7-ad28beaa9d1d",
"success": true
}
}
}
```
##### Error
- error getting user organization KYC by applicant id:<applicantID> record not found
### getApplicant
It can able to get user kyc details
```
import { useKYC } from "@mojito-inc/core-service";
const { getApplicant } = useKYC();
const response: Response<GetApplicantData> = await getApplicant({
organizationID: <ORGANIZATION_ID>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|organizationID| UUID1|✅|
##### Response
```
{
"data: {
"getApplicant": {
"id": "262f085c-474b-44be-8568-e1b58a16c97f",
"firstName": "test",
"lastName": "test",
"email": "",
"dob": "1998-12-22",
"href": "/v3.2/applicants/7578afa6-cb7e-45cc-82ef-5c5821ebec42",
"idNumbers": null,
"address": {
"flatNumber": null,
"buildingNumber": "12",
"buildingName": null,
"street": "test road",
"subStreet": null,
"town": "new york",
"postcode": "12345",
"country": "US",
"line1": null,
"line2": null,
"line3": null,
"state": "new york"
}
}
}
}
```
##### Error
- error getting user organization KYC by applicant id: <OrgId> record not found
### getSDKToken
It can able to get sdk token
```
import { useKYC } from "@mojito-inc/core-service";
const { getSDKToken } = useKYC();
const response: Response<GetSDKTokenData> = await getSDKToken({
applicantID: <APPLICANT_ID>,
referrer: <REFERRER>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|applicantID| UUID1|✅|
|referrer| String|✅|
##### Response
```
{
"data: {
"getSDKToken": {
"token": "eyJhbGciOiJFUzUxMiJ9.eyJleHAiOjE2ODExMTgzNjEsInBheWxvYWQiOnsiYXBwIjoiNzU3OGFmYTYtY2I3ZS00NWNjLTgyZWYtNWM1ODIxZWJlYzQyIiwiY2xpZW50X3V1aWQiOiIyMmQyYzQ1NC0zNzMxLTQ4N2UtYmUzYS05N2I4NmQ4NWYzOWMiLCJpc19zYW5kYm94Ijp0cnVlLCJpc19zZWxmX3NlcnZpY2VfdHJpYWwiOmZhbHNlLCJpc190cmlhbCI6ZmFsc2UsInJlZiI6Imh0iHBzOi8vd2hpc2tleWV4Y2hhbmdlLWRldi5uZXRsaWZ5LmFwcC8iLCJzYXJkaW5lX3Nlc3Npb24iOiI1NzkxMGUyMC0yMTljLTQxZTItOTUzOS1lYjJhYjFmZDdiZTQifSwidXVpZCI6InBsYXRmb3JtX3N0YXRpY19hcGlfdG9rZW5fdXVpZCIsInVybHMiOnsiZGV0ZWN0X2RvY3VtZz50X3VybCI6Imh0dHBzOi8vc2RrLnVzLm9uZmlkby5jb20iLCJzeW5jX3VybCI6Imh0dHBzOi8vc3luYy5vbmZpZG8uY29tIiwiaG9zdGVkX3Nka191cmwiOiJodHRwczovL2lkLm9uZmlkby5jb20iLCJhdXRoX3VybCI6Imh0dHBzOi8vYXBpLnVzLm9uZmlkby5jb20iLCJvbmZpZG9fYXBpX3VybCI6Imh0dHBzOi8vYXBpLnVzLm9uZmlkby5jb20iLCJ0ZWxlcGhvbnlfdXJsIjoiaHR0cHM6Ly9hcGkudXMub25maWRvLmNvbSJ9fQ.MIGIAkIAtiM1UkIpaTKIGeTn6sYfX3GR4fTWPq_AeU1RxwQDQu5S7K3NM1z5hzh01sTo3KK_elpMh27XC0mhR9MkLt3kkroCQgG9gAW4w0vO1k1dXJKzbq3WDpklTqXtjT3plDbe5_bM8QujgjlbaW7nkASg68BYqa7P5UHOI5p-_QBayflaU3wXa"
}
}
}
```
##### Error
- error getting user organization KYC by applicant id:<applicantID> record not found
### updateApplicant
It can able to update the user kyc details
```
import { useKYC } from "@mojito-inc/core-service";
const { updateApplicant } = useKYC();
const response: Response<UpdateApplicantData> = await updateApplicant({
orgID: <ORG_ID>,
input: {
firstName: <FIRST_NAME>,
lastName: <LAST_NAME>,
dob: <DATE_OF_BIRTH>,
address: {
country: <COUNTRY>,
state: <STATE>,
town: <TOWN>,
postcode: <POSTAL_CODE>
}
},
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgID| UUID1|✅|
|input| ApplicantRequest|✅|
##### Response
```
{
"data: {
"updateApplicant": {
"id": "7578afa6-cb7e-45cc-82ef-5c5821ebec42",
"firstName": "test",
"lastName": "test",
"email": "",
"dob": "1998-12-22",
"href": "/v3.2/applicants/7578afa6-cb7e-45cc-82ef-5c5821ebec42",
"idNumbers": null,
"address": {
"flatNumber": null,
"buildingNumber": "12",
"buildingName": null,
"street": "test road",
"subStreet": null,
"town": "new york",
"postcode": "12345",
"country": "US",
"line1": null,
"line2": null,
"line3": null,
"state": "new york"
}
}
}
}
```
##### Error
- error getting user organization KYC by applicant id: <OrgId> record not found
Connect wallet API can be access via hooks
following the api are
1. [connectExternalWallet](#connectExternalWallet)
2. [getActiveWalletsContent](#getActiveWalletsContent)
3. [getSupportedNetworks](#getSupportedNetworks)
### connectExternalWallet
It can able to connect wallet
```
import { useConnectWallet, ConnectExternalWalletData } from "@mojito-inc/core-service";
const { connectExternalWallet } = useConnectWallet();
const response: Response<ConnectExternalWalletData> = await connectExternalWallet({
signature: <SIGNATURE>,
message: <MESSAGE>,
address: <ADDRESS>,
orgID: <ORG_ID>,
networkID: <NETWORK_ID>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgID| UUID1|✅|
|networkID| UUID1|✅|
|message| String|✅|
|signature| String|✅|
|address| String|✅|
##### Response
```
{
"data": {
"connectExternalWallet": true
}
}
```
##### Error
- challenge is too old, please request a new one
### getActiveWalletsContent
It can able to get wallet data
```
import { useConnectWallet, GetActiveWalletsContentData } from "@mojito-inc/core-service";
const { getActiveWalletsContent } = useConnectWallet();
const response: Response<GetActiveWalletsContentData> = await getActiveWalletsContent({
orgID: <ORG_ID>,
networkId: <NETWORK_ID>,
walletAddress: <WALLET_ADDRESS>,
filters: <FILTERS>,
refreshCache: <REFRESH_CACHE>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgID| UUID1|✅|
|networkId| UUID1|✅|
|walletAddress| String|✅|
|filters| ActiveWalletFilterInput|
|refreshCache| Boolean|
##### Response
```
{
"data": {
"getActiveWalletsContent": {
"tokens": [
{
"contractAddress": "0xd0e2fd21764f643fa32b06a4c7d7924f43138d90",
"id": "6",
"network": "Goerli Testnet",
"tokenType": "ERC1155",
"title": "BasedHead #6",
"tokenURI": "https://drops.api.topdogstudios.io/basedAf/token/6",
"nftTokenId": "5bc739a6-f5d3-4417-b4af-91687e0af525",
"mintedAt": "2023-01-25T14:18:02Z",
"status": "SALE_PENDING",
"metadata": {
"name": "BasedHead #6",
"description": "This PFP will be affiliated to the Fraz corporation.\n\nFraz is believed to have begun in the mid-1800s as the JP Fraz and Sons Tinctures and Cure-all Company. However, the lack of any supporting evidence that TrashLand existed before the 1980s suggests that this may not be factually correct. Fraz makes a variety of different food items, all alcoholic beverages, which are distilled from edible shore drift sourced on the island. In 2022, Fraz was announced as the official drink of the Metaverse.\n\n[Download V0 BasedHead](https://ipfs.io/ipfs/QmWiDG1zG7vncPYXMEVSkRYcn2gsujAACSyUsbXvD33ezC)",
"image": "https://ipfs.io/ipfs/QmQJBFoLqcgxDogd5pLgbMKn6u4RPiu1djUfecuZxMhdzk",
"animationURL": "",
"openSeaImageURL": ""
},
"contractName": "test",
"artistName": "Test",
},
]
}
}
}
```
##### Error
- wallet by address by id not found: record not found
### getSupportedNetworks
It can able to get the supported networks list
```
import { useConnectWallet, GetSupportedNetworksData } from "@mojito-inc/core-service";
const { getSupportedNetworks } = useConnectWallet();
const response: Response<GetSupportedNetworksData> = await getSupportedNetworks({
orgId: <ORG_ID>,
includeTestnets: <INCLUDE_TESTNETS>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgId| UUID1|✅|
|includeTestnets| Boolean|
##### Response
```
{
"data": {
"getSupportedNetworks": [
{
"id": "f7babe75-2dfc-434a-9e3b-a28e101c4863",
"name": "Ethereum Mainnet",
"chainID": 1,
"isTestnet": false
},
{
"id": "c41db347-0ee3-4212-943a-ca213b8e0ea8",
"name": "Goerli Testnet",
"chainID": 5,
"isTestnet": true
},
]
}
}
```
##### Error
- encoding/hex: invalid byte: U+002D '-'
List item API can be access via hooks
following the api are
1. [createSignatureToListNFTForSale](#createSignatureToListNFTForSale)
2. [removeListing](#removeListing)
3. [submitProofOfApproval](#submitProofOfApproval)
### createSignatureToListNFTForSale
It can able to create list item for sale
```
import { useListItem, CreateSignatureToListNFTForSaleData } from "@mojito-inc/core-service";
const { createSignatureToListNFTForSale } = useListItem();
const response: Response<CreateSignatureToListNFTForSaleData> = await createSignatureToListNFTForSale({
orgId: <ORG_ID>,
nftTokenId: <NFT_TOKEN_ID>,
tokenType: <TOKEN_TYPE>,
quantity: <QUANTITY>,
nftOwnerAddress: <NFT_OWNER_ADDRESS>,
fixedPrice: <FIXED_PRICE>,
paymentToken: <PAYMENT_TOKEN>,
currencyId: <CURRENCY_ID>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgId| UUID1|✅|
|nftTokenId| UUID1|✅|
|tokenType| TokenType|✅|
|quantity| Int|✅|
|nftOwnerAddress| String|✅|
|fixedPrice| Float|✅|
|paymentToken| String|✅|
|currencyId| UUID1|✅|
##### Response
```
{
"data": {
"createSignatureToListNFTForSale": {
"messageToSign": "0xc061ed6367ab12e87d93ac081487f069e4c8ba3b6bc100fec2a1afffd937f632",
"order": {
"id":"32dc6e44-79f3-4d2f-8068-94639e543a6e"
"nftTokenId":"6bd80dcd-9cc8-4078-a7e2-02c5164d7ab4"
"tokenContract":"0xd0e2fd21764f643fa32b06a4c7d7924f43138d90"
"tokenId":"15"
"tokenType":"ERC1155"
"quantity":1
"nftOwnerAddress":"0xC7e893488A039A341d935959E52f86085976F865"
"fixedPrice":0.04
"paymentToken":"0x0000000000000000000000000000000000000000"
"orderType":"LISTING"
}
}
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
### removeListing
It can able to remove listing an item
```
import { useListItem, RemoveListingData } from "@mojito-inc/core-service";
const { createSignatureToListNFTForSale } = useListItem();
const response: Response<RemoveListingData> = await removeListing({
orgID: <ORG_ID>,
nftTokenId: <NFT_TOKEN_ID>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgID| UUID1|✅|
|nftTokenId| UUID1|✅|
##### Response
```
{
"data": {
"removeListing": "Listing removed."
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
### submitProofOfApproval
It can able to submit approval for listing an item
```
import { useListItem, SubmitProofOfApprovalData } from "@mojito-inc/core-service";
const { submitProofOfApproval } = useListItem();
const response: Response<SubmitProofOfApprovalData> = await submitProofOfApproval({
orgID: <ORG_ID>,
nftTokenId: <NFT_TOKEN_ID>,
signature: <SIGNATURE>,
quantity: <QUANTITY>,
fixedPrice: <FIXED_PRICE>,
paymentToken: <PAYMENT_TOKEN>,
currencyId: <CURRENCY_ID>,
creatorFee: <CREATOR_FEE>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgID| UUID1|✅|
|nftTokenId| UUID1|✅|
|signature| String|✅|
|quantity| Int|
|fixedPrice| Float|
|paymentToken| String|
|currencyId| UUID1|
|creatorFee| TokenType|
##### Response
```
{
"data": {
"submitProofOfApproval":"Signature updated."
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
Tax and fee API can be access via hooks
following the api are
1. [estimateTaxAndRoyaltyFee](#estimateTaxAndRoyaltyFee)
2. [getTaxQuote](#getTaxQuote)
### estimateTaxAndRoyaltyFee
It can able to get tax and fee data
```
import { useFee, EstimateTaxAndRoyaltyFeeData } from "@mojito-inc/core-service";
const { estimateTaxAndRoyaltyFee } = useFee();
const response: Response<EstimateTaxAndRoyaltyFeeData> = await estimateTaxAndRoyaltyFee({
orgId: <ORG_ID>,
estimateType: <ESTIMATE_TYPE>,
nftTokenId: <NFT_TOKEN_ID>,
orderId: <ORDER_ID>,
price: <PRICE>,
country: <COUNTRY>,
postalCode: <POSTAL_CODE>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgId| UUID1|✅|
|estimateType| TaxEstimateType|✅|
|nftTokenId| UUID1|
|orderId| UUID1|
|price| Float|
|country| String|
|postalCode| String|
##### Response
```
{
"data": {
"estimateTaxAndRoyaltyFee": {
"taxPercentage": 0,
"royaltyFee": 0,
"platformFee": 2.5,
"taxResponse": {
"cryptoTaxPrice": 0,
"cryptoTotalPrice": 1,
"USDUnitprice": 1920.88,
"taxPercentage": 0
}
}
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
### getTaxQuote
It can able to get tax and fee data
```
import { useFee, GetTaxQuoteData } from "@mojito-inc/core-service";
const { getTaxQuote } = useFee();
const response: Response<GetTaxQuoteData> = await getTaxQuote({
orgID: <ORG_ID>,
taxablePrice: <TAXABLE_PRICE>,
street1: <STREET>,
city: <CITY>,
state: <STATE>,
postalCode: <POSTAL_CODE>,
country: <COUNTRY>,
currencyCode: <CURRENCY_CODE>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgID| UUID1|✅|
|taxablePrice| Float|✅|
|street1| String|✅|
|city| String|✅|
|state| String|✅|
|postalCode| String|✅|
|country| String|✅|
|currencyCode| String|
##### Response
```
{
"data": {
"getTaxQuote": {
"verifiedAddress": {
"street1": "",
"state": "Tamil Nadu",
"postalCode": "",
"country": "IN",
"currencyCode": "USD"
},
"taxablePrice": 76.6724,
"totalTaxedPrice": 76.6724,
"totalTaxAmount": 0
}
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
NFT API can be access via hooks
following the api are
1. [getNFTFavoriteListByUser](#getNFTFavoriteListByUser)
2. [addNFTToFavorite](#addNFTToFavorite)
3. [removeNFTFromFavorite](#removeNFTFromFavorite)
4. [getAllRegistryTokens](#getAllRegistryTokens)
5. [getNFTDetails](#getNFTDetails)
6. [getNFTHistory](#getNFTHistory)
7. [getNFTAttributesRarity](#getNFTAttributesRarity)
8. [initiateBuyNFT](#initiateBuyNFT)
9. [updateTransactionHash](#updateTransactionHash)
10. [generateSecondaryInvoice](#generateSecondaryInvoice)
11. [userOrderActivity](#userOrderActivity)
12. [transferNFT](#transferNFT)
13. [getAllInvoices](#getAllInvoices)
14. [generatePrimaryInvoice](#generatePrimaryInvoice)
15. [getFileSignedURL](#getFileSignedURL)
### getNFTFavoriteListByUser
It can able to get favorite NFT list
```
import { useNFT, GetNFTFavoriteListByUserData } from "@mojito-inc/core-service";
const { getNFTFavoriteListByUser } = useNFT();
const response: Response<GetNFTFavoriteListByUserData> = await getNFTFavoriteListByUser({
orgId: <ORG_ID>,
searchKey: <SEARCH_KEY>,
filter: <FILTER>,
limit: <LIMIT>,
offset: <OFFSET>,
buyerAddress: <BUYER_ADDRESS>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgId| UUID1|✅|
|searchKey| Number|
|filter| enum| |[SavedNFTFilterInput](#SavedNFTFilterInput)|
|limit| Int|
|offset| Int|
|buyerAddress| String|
##### SavedNFTFilterInput
##### enum
|Enum Variable |value |
|:--- | --- |
|recently_listed| recently_listed|
|recently_minted | recently_minted |
|initially_minted| initially_minted|
|price_low_to_high | price_low_to_high |
|most_saved| most_saved|
|purchased_from_org | purchased_from_org |
##### Response
```
{
"data": {
"getNFTFavouriteListByUser": {
"totalCount": 1,
"data": [
{
"id":"6"
"title":"BasedHead #6"
"status":"OPEN_FOR_SALE"
"network":"Goerli Testnet"
"networkID":"c41db347-0ee3-4212-943a-ca213b8e0ea8"
"tokenURI":"https://drops.api.topdogstudios.io/basedAf/token/6"
}
]
}
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
### addNFTToFavorite
It can able to add NFT to favorite
```
import { useNFT, AddNFTToFavoriteData } from "@mojito-inc/core-service";
const { addNFTToFavorite } = useNFT();
const response: Response<AddNFTToFavoriteData> = await addNFTToFavorite({
orgID: <ORG_ID>,
tokenId: <TOKEN_ID>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgId| UUID1|✅|
|tokenId| UUID1|✅|
##### Response
```
{
"data": {
"addNFTToFavourite": true,
}
}
```
##### Error
- error getting token by ID: record not found
### removeNFTFromFavorite
It can able to remove NFT from favorite
```
import { useNFT, RemoveNFTFromFavoriteData } from "@mojito-inc/core-service";
const { removeNFTFromFavorite } = useNFT();
const response: Response<RemoveNFTFromFavoriteData> = await removeNFTFromFavorite({
orgID: <ORG_ID>,
tokenId: <TOKEN_ID>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgId| UUID1|✅|
|tokenId| UUID1|✅|
##### Response
```
{
"data": {
"removeNFTFromFavourite": true,
}
}
```
##### Error
- error getting token by ID: record not found
### getAllRegistryTokens
It can able to get NFT list
```
import { useNFT, GetAllRegistryTokensData } from "@mojito-inc/core-service";
const { getAllRegistryTokens } = useNFT();
const response: Response<GetAllRegistryTokensData> = await getAllRegistryTokens({
orgID: <ORG_ID>,
searchKey: <SEARCH_KEY>,
filter: <FILTER>,
limit: <LIMIT>,
offset: <OFFSET>,
marketplaceID: <MARKETPLACE_ID>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgID| UUID1|✅|
|searchKey| Number|
|filter| enum| |[RegistryTokenFilterInput](#RegistryTokenFilterInput)|
|limit| Int|
|offset| Int|
|buyerAddress| String|
|sort| RegistryTokenSortInput|
|artistID| UUID1|
|registryID| UUID1|
|categorySlug| String|
|artistSlug| String|
##### RegistryTokenFilterInput
##### enum
|Enum Variable |value |
|:--- | --- |
|recently_listed| recently_listed|
|recently_minted | recently_minted |
|initially_minted| initially_minted|
|price_low_to_high | price_low_to_high |
|price_high_to_low| price_high_to_low|
##### Response
```
{
"data": {
"getAllRegistryTokens": {
"totalCount": 1,
"data": [
{
"ID":"7992bcb2-1d34-4158-b07b-e8725016b1d1"
"TokenName":"BasedHead #15"
"TokenID":"15"
"Status":"OPEN_FOR_SALE"
"TokenURI":"https://drops.api.topdogstudios.io/basedAf/token/15"
"NFTTokenID":"6bd80dcd-9cc8-4078-a7e2-02c5164d7ab4"
}
]
}
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
### getNFTDetails
It can able to get NFT list
```
import { useNFT, GetNFTDetailsData } from "@mojito-inc/core-service";
const { getNFTDetails } = useNFT();
const response: Response<GetNFTDetailsData> = await getNFTDetails({
orgId: <ORG_ID>,
contractAddress: <CONTRACT_ADDRESS>,
onChainTokenID: <ONCHAIN_TOKEN_ID>,
ownerAddress: <OWNER_ADDRESS>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgId| UUID1|✅|
|contractAddress| String|
|onChainTokenID| BigInt|
|ownerAddress| String|
|buyerAddress| String|
|editionNumber| Int|
|nftTokenId| UUID1|
|networkId| UUID1|
##### Response
```
{
"data": {
"getNFTDetails": {
"contractAddress":"0xd0e2fd21764f643fa32b06a4c7d7924f43138d90"
"tokenId":"7"
"network":"Goerli Testnet"
"networkID":"c41db347-0ee3-4212-943a-ca213b8e0ea8"
"contractName":"test"
"tokenType":"ERC1155"
"mintedAt":"2023-01-25T06:40:22Z"
"status":"SALE_PENDING"
}
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
### getNFTHistory
It can able to get NFT history
```
import { useNFT, GetNFTHistoryData } from "@mojito-inc/core-service";
const { getNFTHistory } = useNFT();
const response: Response<GetNFTHistoryData> = await getNFTHistory({
orgId: <ORG_ID>,
contractAddress: <CONTRACT_ADDRESS>,
tokenId: <TOKEN_ID>,
networkId: <NETWORK_ID>,
ownerAddress: <OWNER_ADDRESS>,
nftTokenId: <NFT_TOKEN_ID>,
limit: <LIMIT>,
offset: <OFFSET>
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|orgId| UUID1|✅|
|contractAddress| String|✅|
|networkId| UUID1|✅|
|tokenId| BigInt|✅|
|nftTokenId| UUID1|
|ownerAddress| String|
|limit| Int|
|offset| Int|
##### Response
```
{
"data": {
"getNFTHistoryV2": {
"totalCount": 30,
"data": [
{
"hash":"0xd3cc350c9020a32f699bea54824b90aa5adad6fbc5e09a0dbc2b78ce1415ae03",
"from":"0xa77915a574e1f9b88db152525ceBfEAA8c71bAa4",
"to":"test"
"blockTimestamp":"2023-01-27T12:41:23Z"
"eventType":"Sale"
"fromUserAvatar":"qvx3wQZawwkDtws2"
}
]
}
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
### getNFTAttributesRarity
It can able to get NFT Traits
```
import { useNFT, GetNFTAttributesRarityData } from "@mojito-inc/core-service";
const { getNFTAttributesRarity } = useNFT();
const response: Response<GetNFTAttributesRarityData> = await getNFTAttributesRarity({
contractAddress: <CONTRACT_ADDRESS>,
tokenID: <TOKEN_ID>,
networkID: <NETWORK_ID>,
refreshCatch: <REFRESH_CACHE>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|contractAddress| String|✅|
|networkID| UUID1|✅|
|tokenID| BigInt|✅|
|refreshCatch| Boolean|
##### Response
```
{
"data": {
"getNFTAttributesRarity": [
{
"traitType":"Brand",
"displayType":"",
"maxValue":0,
"prevalance":0,
"value": {
"__typename":"AttributeValueString",
"stringValue":"DGAF"
}
}
]
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
### initiateBuyNFT
It can able to get order details
```
import { useNFT, InitiateBuyNFTData } from "@mojito-inc/core-service";
const { initiateBuyNFT } = useNFT();
const response: Response<InitiateBuyNFTData> = await initiateBuyNFT({
nftTokenId: <NFT_TOKEN_ID>,
buyerAddress: <BUYER_ADDRESS>,
orgId: <ORG_ID>,
country: <COUNTRY>,
postalCode: <POSTAL_CODE>,
currencyId: <CURRENCY_ID>,
cryptoTax: <CRYPTO_TAX>,
taxAddress: <TAX_ADDRESS>
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|nftTokenId| UUID1|✅|
|buyerAddress| String|✅|
|orgId| UUID1|✅|
|country| String|
|postalCode| String|
|currencyId| UUID1|
|cryptoTax| CryptoTax|
|taxAddress| TaxAddressInput|
##### Response
```
{
"data": {
"initiateBuyNFT": {
"proofOfApproval":"0x28a9e439e3c091e737ff6209a1aa6f6022d8e7d16d738b2cbbc2fe8fad86630c341602d2653fcda2d02034278aee2a4fce9d6a48b7662ab67c5893c0fd857cf01c"
}
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
### updateTransactionHash
It can able to update the transaction hash
```
import { useNFT, UpdateTransactionHashData } from "@mojito-inc/core-service";
const { updateTransactionHash } = useNFT();
const response: Response<UpdateTransactionHashData> = await updateTransactionHash({
nftTokenId: <NFT_TOKEN_ID>,
orgId: <ORG_ID>,
buyerAddress: <BUYER_ADDRESS>,
transactionHash: <TRANSACTION_HASH>,
orderId: <ORDER_ID>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|nftTokenId| UUID1|✅|
|orgId| UUID1|✅|
|buyerAddress| String|✅|
|transactionHash| String|✅|
|orderId| UUID1|
##### Response
```
{
"data": {
"updateTransactionHash": {
"success":false,
"newNFTID":"2bb1fec0-94be-499c-989c-1a2a75ceb478"
}
}
}
```
##### Error
- error getting organization by id: <orgID> record not found
### generateSecondaryInvoice
It will give a url to download invoice as a PDF format
```
import { useNFT, GenerateSecondaryInvoiceData } from "@mojito-inc/core-service";
const { generateSecondaryInvoice } = useNFT();
const response: Response<GenerateSecondaryInvoiceData> =
await generateSecondaryInvoice({
invoiceID: <INVOICE_ID>,
orderID: <ORDER_ID>,
activityName: <ACTIVITY_NAME>,
invoiceResType: <INVOICE_RES_TYPE>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|invoiceID| UUID1|✅|
|orderID| UUID1|✅|
|activityName| enum|✅| [ActivityName](#ActivityName)|
|invoiceResType| enum|✅| [InvoiceResType](#InvoiceResType)|
##### ActivityName
##### enum
|Enum Variable |value |
|:--- | --- |
|Listed_Item| Listed_Item|
|Listed_Item_Removed | Listed_Item_Removed |
|Sold_Item| Sold_Item|
|Offered | Offered |
|Offer_Cancelled| Offer_Cancelled|
|Offer_Rejected | Offer_Rejected |
|Offer_Expired| Offer_Expired|
|Bought_Item | Bought_Item |
##### InvoiceResType
##### enum
|Enum Variable |value |
|:--- | --- |
|pdf| pdf|
|base64 | base64 |
##### Response
```
{
"data: {
"generateSecondaryInvoice": "https://storage.googleapis.com/mojito-dev-public/organizations/8fb128bd-f55d-4bcc-8b6c-0beb684e4d4e/invoices/208af15b-ae03-47c7-aa79-27ce453bcb2d_buyer.pdf"
}
}
```
##### Error
- error getting invoice with id: <invoiceID> record not found
### generatePrimaryInvoice
It will give a url to download invoice as a PDF format
```
import { useNFT, GeneratePrimaryInvoiceData } from "@mojito-inc/core-service";
const { generatePrimaryInvoice } = useNFT();
const response: Response<GeneratePrimaryInvoiceData> =
await generatePrimaryInvoice({
invoiceID: <INVOICE_ID>,
invoiceResType: <INVOICE_RES_TYPE>,
});
```
|Param |type | Required | Description
|:--- | --- | :---:| :---:|
|invoiceID| UUID1|✅|
|invoiceResType| enum|✅| [InvoiceResType](#InvoiceResType)|
##### InvoiceResType
##### enum
|Enum Variable |value |
|:--- | --- |
|pdf| pdf|
|base64 | base64 |
##### Response
```
{
"data: {
"generatePrimaryInvoice": "https://storage.googleapis.com/mojito-dev-public/organizations/8fb128bd-f55d-4bcc-8b6c-0beb684e4d4e/invoices/208af15b-ae03-47c7-aa79-27ce453bcb2d_buyer.pdf"
}
}
```
##### Error
- error getting invoice with id: <invoiceID> record not found
### getUserOrderActivity
It will