From cc7161590e5c0f4818b60eaf5748cb8a01c4f534 Mon Sep 17 00:00:00 2001 From: Damjan Dimitrov Date: Mon, 2 Dec 2024 14:51:09 +0100 Subject: [PATCH 1/2] Remove await parameter from CLI --- build/6-apillon-cli.md | 1 - 1 file changed, 1 deletion(-) diff --git a/build/6-apillon-cli.md b/build/6-apillon-cli.md index 185f8ce5..073cfecd 100644 --- a/build/6-apillon-cli.md +++ b/build/6-apillon-cli.md @@ -376,7 +376,6 @@ Upload contents of a local folder to specified bucket. - `-b, --bucket-uuid `: UUID of the bucket to upload files to. - `-w, --wrap`: Wrap uploaded files to an IPFS directory - `-p, --path `: Path to upload files to (e.g. main/subdir). Required when --wrap is supplied. -- `--await`: await file CIDs to be resolved **Example** From 03c8d7e8f54eca28e6994bd0b3769ebcbaa735c5 Mon Sep 17 00:00:00 2001 From: Damjan Dimitrov Date: Tue, 3 Dec 2024 14:26:20 +0100 Subject: [PATCH 2/2] Update smart contract docs --- ...racts-api.md => 14-smart-contracts-api.md} | 36 +++++++-------- web3-services/10-web3-contracts.md | 25 ----------- web3-services/12-web3-smart-contracts.md | 45 +++++++++++++++++++ 3 files changed, 63 insertions(+), 43 deletions(-) rename build/{13-contracts-api.md => 14-smart-contracts-api.md} (99%) delete mode 100644 web3-services/10-web3-contracts.md create mode 100644 web3-services/12-web3-smart-contracts.md diff --git a/build/13-contracts-api.md b/build/14-smart-contracts-api.md similarity index 99% rename from build/13-contracts-api.md rename to build/14-smart-contracts-api.md index 92989d87..58302352 100644 --- a/build/13-contracts-api.md +++ b/build/14-smart-contracts-api.md @@ -1,4 +1,4 @@ -# Contracts API +# Smart Contracts API API for creation and management of smart contracts through Apillon wallets on supported EVM chains. @@ -360,7 +360,7 @@ Array item(s) format depends on value of `solidityJson` passed as query paramete ```sh -curl --location 'https://api.apillon.io/contracts/:uuid/deploy' \ +curl --location 'https://api.apillon.io/contracts/:uuid/deploy' \ --header 'Authorization: Basic :credentials' --data-raw '{ "name": "Test Contract 2", @@ -641,7 +641,7 @@ All query parameters from [listing request](1-apillon-api.md#listing-requests) p Response is a list of items (shorter version) described [under Response Fields above](#response-fields). -Item is a shorter version because it is a flat object and it doesn't include nested `contractVersion` (with `abi`, +Item is a shorter version because it is a flat object and it doesn't include nested `contractVersion` (with `abi`, `methods` and `contract`), instead it exposes some details from this table: ##### Response Fields @@ -857,7 +857,7 @@ All query parameters from [listing request](1-apillon-api.md#listing-requests), | 40300000 | Not allowed to access deployed contract. | #### Response -Endpoint returns ABI methods as an array. +Endpoint returns ABI methods as an array. Array item(s) format depends on value of `solidityJson` passed as query parameter (human-readable ABI or ABI in Solidity JSON format). @@ -1020,21 +1020,21 @@ Endpoint returns transactions for deployed contract based on filters. | Name | Type | Description | |-------------------------|------------|-------------------------------------| -| `contractUuid` | `string` | UUID of the contract. | -| `projectUuid` | `string` | UUID of the associated project. | -| `name` | `string` | Name of the contract. | -| `description` | `string` | Description of the contract. | -| `chainType` | `number` | Type of blockchain chain. | -| `chain` | `number` | ID of the blockchain. | -| `versionId` | `number` | Version ID of the contract. | -| `constructorArguments` | `any[]` | Arguments for the constructor. | -| `contractStatus` | `number` | Status of the contract deployment. | -| `contractAddress` | `string` | Deployed contract address. | -| `deployerAddress` | `string` | Address of the deployer. | -| `transactionHash` | `string` | Transaction hash of deployment. | +| `contractUuid` | `string` | UUID of the contract. | +| `projectUuid` | `string` | UUID of the associated project. | +| `name` | `string` | Name of the contract. | +| `description` | `string` | Description of the contract. | +| `chainType` | `number` | Type of blockchain chain. | +| `chain` | `number` | ID of the blockchain. | +| `versionId` | `number` | Version ID of the contract. | +| `constructorArguments` | `any[]` | Arguments for the constructor. | +| `contractStatus` | `number` | Status of the contract deployment. | +| `contractAddress` | `string` | Deployed contract address. | +| `deployerAddress` | `string` | Address of the deployer. | +| `transactionHash` | `string` | Transaction hash of deployment. | | `contractVersion` | `string` | Version of the contract (nullable). | -| `createTime` | `Datetime` | Creation time of the contract. | -| `updateTime` | `Datetime` | Last update time of the contract. | +| `createTime` | `Datetime` | Creation time of the contract. | +| `updateTime` | `Datetime` | Last update time of the contract. | diff --git a/web3-services/10-web3-contracts.md b/web3-services/10-web3-contracts.md deleted file mode 100644 index 6c4df7c4..00000000 --- a/web3-services/10-web3-contracts.md +++ /dev/null @@ -1,25 +0,0 @@ -# Contracts - -The Apillon Contract Service enables efficient deployment and comprehensive management of smart contracts across multiple -blockchain networks, providing a seamless and scalable solution for developers and enterprises. - -This service currently supports deploying smart contracts on various EVM-compatible blockchain networks, including: -- [Astar Network](https://docs.astar.network/docs/build/introduction/astar_family) -- [Moonbeam Network](https://docs.moonbeam.network/builders/get-started/networks/moonbeam/) -- [Moonbase Network](https://docs.moonbeam.network/builders/get-started/networks/moonbase/) - -## Contract Deployment - -Deploying a smart contract is straightforward with Apillon's streamlined process. To deploy a smart contract, follow these steps: - -1. Log in to your [Apillon account](https://app.apillon.io/register). -2. Navigate to the "Contracts" section from the menu on the left and click on "New Smart Contract." -3. Select the desired smart contract for deployment. -4. Customize the contract through the provided configuration form and initiate the deployment. -5. Once deployed, utilize read and write methods to interact directly with the contract. - -## Contract Versioning - -To ensure ongoing security and feature enhancements, Apillon employs versioned smart contracts. Each deployed contract -maintains a version to guarantee that the appropriate ABI (Application Binary Interface) is used during interactions, -safeguarding compatibility and providing a stable experience for contract users. \ No newline at end of file diff --git a/web3-services/12-web3-smart-contracts.md b/web3-services/12-web3-smart-contracts.md new file mode 100644 index 00000000..d399b545 --- /dev/null +++ b/web3-services/12-web3-smart-contracts.md @@ -0,0 +1,45 @@ +# Smart Contracts + +The Apillon Contract Service enables efficient deployment and comprehensive management of smart contracts across multiple +blockchain networks, providing a seamless and scalable solution for developers and enterprises. + +This service currently supports deploying smart contracts on various EVM-compatible blockchain networks, including: +- [Astar Network](https://docs.astar.network/docs/build/introduction/astar_family) +- [Moonbeam Network](https://docs.moonbeam.network/builders/get-started/networks/moonbeam/) +- [Moonbase Network](https://docs.moonbeam.network/builders/get-started/networks/moonbase/) + +## Smart Contract Deployment + +Deploying a smart contract is straightforward with Apillon's streamlined process. To deploy a smart contract, follow these steps: + +1. Log in to your [Apillon account](https://app.apillon.io/register). +2. Navigate to the "Contracts" section from the menu on the left and click on "New Smart Contract." +3. Select the desired smart contract for deployment. +4. Customize the contract through the provided configuration form and initiate the deployment. +5. Once deployed, utilize read and write methods to interact directly with the contract. + +## Smart Contract Versioning + +To ensure ongoing security and feature enhancements, Apillon employs versioned smart contracts. Each deployed contract +maintains a version to guarantee that the appropriate ABI (Application Binary Interface) is used during interactions, +safeguarding compatibility and providing a stable experience for contract users. + +## Supported Smart Contract Types + +Apillon supports various types of smart contracts to cater to different use cases and requirements. The currently supported smart contract types include ERC-20, ERC-721, and ERC-1155. + +### ERC-20 + +ERC-20 is a widely adopted standard for fungible tokens on the Ethereum blockchain. These tokens are interchangeable and have the same value, making them ideal for use cases such as cryptocurrencies, utility tokens, and other digital assets. Apillon's ERC-20 smart contracts allow for seamless token creation, transfer, and management, ensuring compatibility with a wide range of wallets and exchanges. + +### ERC-721 + +ERC-721 is the standard for non-fungible tokens (NFTs), which are unique and cannot be exchanged on a one-to-one basis like ERC-20 tokens. Each ERC-721 token has distinct properties and metadata, making them perfect for representing ownership of unique items such as digital art, collectibles, and real estate. Apillon's ERC-721 smart contracts provide robust functionality for minting, transferring, and managing NFTs, enabling developers to create and manage unique digital assets with ease. + +### ERC-1155 + +ERC-1155 is a versatile standard that supports both fungible and non-fungible tokens within a single contract. This multi-token standard allows for more efficient transactions and storage, as multiple token types can be managed under one contract. Apillon's ERC-1155 smart contracts are ideal for applications that require a combination of fungible and non-fungible tokens, such as gaming assets, where a single contract can handle in-game currencies, items, and unique collectibles. + +## Smart Contract API + +To read more about the Smart Contract API, please refer to the [Apillon Smart Contracts API documentation](../build/14-smart-contracts-api.md).