Skip to content

Commit

Permalink
Merge pull request #16 from Jason-Gregoire/master
Browse files Browse the repository at this point in the history
Add unit tests examples suite organization
  • Loading branch information
Jason-Gregoire authored Feb 14, 2024
2 parents 9c4baaf + a901ed6 commit 558725a
Show file tree
Hide file tree
Showing 112 changed files with 5,991 additions and 1,593 deletions.
12 changes: 12 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
# General
.dart_tool/
.packages
build/
doc/api/

# IDE
.vscode/

# OS
.DS_Store
Thumbs.db
137 changes: 65 additions & 72 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,107 +1,100 @@

# Accumulate Dart Client
# Accumulate Dart SDK


![Pub Version](https://img.shields.io/pub/v/accumulate_api)
![GitHub](https://img.shields.io/github/license/kompendium-ano/accumulate-dart-client)
[![Tests](https://github.com/kompendium-ano/accumulate-dart-client/actions/workflows/dart.yml/badge.svg)](https://github.com/kompendium-ano/accumulate-dart-client/actions/workflows/dart.yml)
[![Pub Version](https://img.shields.io/pub/v/accumulate_api)](https://pub.dev/packages/accumulate_api)
[![GitHub License](https://img.shields.io/github/license/kompendium-ano/accumulate-dart-client)](LICENSE)
[![Build Status](https://github.com/kompendium-ano/accumulate-dart-client/actions/workflows/dart.yml/badge.svg)](https://github.com/kompendium-ano/accumulate-dart-client/actions/workflows/dart.yml)

Dart client for [Accumulate](https://github.com/AccumulateNetwork/accumulate) blockchain, a novel blockchain network designed to be hugely scalable while maintaining security.
This library supports all API class and basic data types that reflect network types and structures and utility functions to ease up creation of specific requests.
The Dart SDK for the Accumulate blockchain provides developers with the tools needed to interact with the Accumulate network. This SDK supports all Accumulate API classes, basic data types, and utility functions for creating specific requests, aiming to simplify the development process for applications leveraging the Accumulate blockchain's scalable and secure infrastructure.

Full API reference available here: https://docs.accumulatenetwork.io/accumulate/developers/api/api-reference
The Accumulate Dart SDK repositiory is organized with three main strucutres:
- Client library: [lib](/lib/src/)
- Test Suite: [tests](/test/README.md/)
- Accumulate Usage Examples Collection: [examples](/examples/SDK_Usage_Examples/README.md/)

## Installation

With Dart:
```
$ dart pub add accumulate_api
```
### Dart

With Flutter:
```
$ flutter pub add accumulate_api
```bash
dart pub add accumulate_api
```

This will add a line like this to your package's pubspec.yaml (and run an implicit dart pub get):
This adds `accumulate_api` to your package's `pubspec.yaml` file and runs an implicit `dart pub get`.

```
dependencies:
accumulate_api: any
```
Alternatively, your editor might support dart pub get or flutter pub get. Check the docs for your editor to learn more.
Import it
### Flutter

Now in your Dart code, you can use:
```bash
flutter pub add accumulate_api
```
import 'package:accumulate_api/accumulate_api.dart';
```

## Usage

For both Dart and Flutter, ensure your `pubspec.yaml` reflects the correct dependency:

```yaml
dependencies:
accumulate_api: ^version
```
### 1. Generate Lite Identity
Replace `^version` with the latest version of `accumulate_api`.

```dart
ACMEClient client = ACMEClient("https://testnet.accumulatenetwork.io/v2");
var lid = LiteIdentity(Ed25519KeypairSigner.generate());
```
### Import the SDK

### 2. Add ACME token from Faucet
In your Dart code, import the package with:

```dart
ACMEClient client = ACMEClient("https://testnet.accumulatenetwork.io/v2");
var lid = LiteIdentity(Ed25519KeypairSigner.generate());
final res = await client.faucet(lid.acmeTokenAccount);
import 'package:accumulate_api/accumulate_api.dart';
```

## Practical Usage Examples

### 3. Add Credits to Lite Identity
The Accumulate Dart SDK enables you to access nearly all the features and fucnitonality that accumualte offers.
Explore practical examples in the [Examples](/examples/SDK_Usage_Examples/) section to start building with the Accumulate Dart SDK. This repository provides a suite of examples designed to demonstrate the capabilities and functionalities of the Accumulate protocol, offering developers a hands-on experience to better understand how to interact with the network effectively.

```dart
int creditAmount = 60000;
AddCreditsParam addCreditsParam = AddCreditsParam();
addCreditsParam.recipient = lid.url;
addCreditsParam.amount = (creditAmount * pow(10, 8)) ~/ oracle;
addCreditsParam.oracle = await client.valueFromOracle();
await client.addCredits(lid.url, addCreditsParam, lid);
```
The Usage Example Suite currently consists of 6 collections of example sets:
#### 1. Lite Identities and Lite Token Accounts
- Create/manage Lite Identities/Accounts for ACME tokens
- Acquire testnet ACME tokens via faucet
- Add credits to Lite Identities
- Create Lite Token Accounts for ACME
- Transfer ACME tokens between Lite Accounts

#### 2. Accumulate Digital Identifier (ADI)
- Create ADI Identity
- Add credits to Key Page

### 4. Send ACME token to another Lite ACME token account
#### 3. ADI Token Accounts
- Create ADI Token Accounts for ACME
- Transfer ACME tokens between ADI Accounts and to Lite Accounts

```dart
int sendToken = 10000;
final recipient =
LiteIdentity(Ed25519KeypairSigner.generate()).acmeTokenAccount;
SendTokensParam sendTokensParam = SendTokensParam();
TokenRecipientParam tokenRecipientParam = TokenRecipientParam();
tokenRecipientParam.amount = sendToken * pow(10, 8);
tokenRecipientParam.url = recipient;
sendTokensParam.to = List<TokenRecipientParam>.from([tokenRecipientParam]);
await client.sendTokens(lid.acmeTokenAccount, sendTokensParam, lid);
#### 4. ADI Data Accounts
- Create/manage ADI Data Accounts
- Write/manage data entries
- Utilize scratch data entries and lite data accounts

```
#### 5. Custom Tokens
- Create custom tokens under ADI
- Create custom token accounts and issue tokens
- Transfer custom tokens between ADI Custom Token Accounts

### 5. Create ADI
```dart
final identitySigner = Ed25519KeypairSigner.generate();
var identityUrl = "acc://custom-adi-name";
final bookUrl = identityUrl + "/custom-book-name";
CreateIdentityParam createIdentityParam = CreateIdentityParam();
createIdentityParam.url = identityUrl;
createIdentityParam.keyBookUrl = bookUrl;
createIdentityParam.keyHash = identitySigner.publicKeyHash();
await client.createIdentity(lid.url, createIdentityParam, lid);
```
#### 6. Key Management
- Manage keys for security/identity (ADI)
- Create/additional/custom Key Books/Pages
- Update Key Page (add keys)


## Contributions
The Library developed by Kompendium, LLC in partnership with [Kelecorix, Inc](https://github.com/kelecorix) and [Sergey Bushnyak](https://github.com/sigrlami). Contributions are welcome, open new PR or submit new issue.

#### Library developers:
* Sergey Bushnyak <sergey.bushnyak@kelecorix.com>
* Jimmy Jose <theguywhomakesapp@gmail.com>
We welcome contributions from the community. To contribute, please submit a pull request or open an issue for discussion.

### Maintainers

- Sergey Bushnyak (sergey.bushnyak@kelecorix.com)
- Jimmy Jose (theguywhomakesapp@gmail.com)
- Jason Gregoire (jason@kompendiumllc.co)

This library is developed by Kompendium, LLC in partnership with Kelecorix, Inc, and individual contributors like Sergey Bushnyak. Your contributions and feedback are welcome.

## License

This project is licensed under the [MIT License](LICENSE).
Empty file.
Empty file removed example/features/create_token.dart
Empty file.
126 changes: 126 additions & 0 deletions examples/SDK_Usage_Examples/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,126 @@
# Accumulate SDK Examples for Dart

This repository provides a suite of examples for using the Dart SDK with the Accumulate network. These examples are designed to demonstrate the capabilities and functionalities of the Accumulate protocol, offering developers a hands-on experience to better understand how to interact with the network effectively.

The Usage Example Suite currently consists of 6 example sets:
- SDK_Examples_file_1_lite_identities.dart
- SDK_Examples_file_2_Accumulate_Identities_(ADI).dart
- SDK_Examples_file_3_ADI_Token_Accounts.dart
- SDK_Examples_file_4_Data_Accounts_and_Entries.dart
- SDK_Examples_file_5_Custom_Tokens.dart
- SDK_Examples_file_6_Key_Management.dart

## 🚀 Getting Started

To get started with these examples, ensure that Dart is installed on your system. These standalone examples demonstrate various features of the Accumulate protocol, enabling safe interactions with the blockchain through the Accumulate testnet.

Accumulate maintains multiple testnets (stable and developmental). This example suite was tested against the Accumulate Kermit testnet (stable) in February 2024, using the endpoint `https://testnet.accumulatenetwork.io/v2`.

### Prerequisites

- **Dart SDK**: Required to run the examples. If you haven't already, [install Dart](https://dart.dev/get-dart).
- **Accumulate Testnet**: The examples are configured for the Accumulate testnet environment to minimize risks while exploring the functionalities.

## 📁 Example Files Overview

Each file in the suite is designed to introduce different aspects of the Accumulate protocol.

### 1. **Lite Identities and Accounts**

**File**: `SDK_Examples_file_1_lite_identities.dart`

Lite identities serve as the entry point into the Accumulate network, offering a traditional blockchain address format. Lite identities can hold data and credits, which are used as a "gas-like" mechanism to pay for network transactions. Additionally, a lite identity can manage a lite token account for ACME tokens, the native token of the Accumulate network.

**Highlights**:
- Creation and management of Lite Identities and Accounts
- Acquiring and transferring ACME tokens
- Adding credits to Lite Token Accounts

To run Lite Identities and Accounts examples
```bash
dart run SDK_Examples_file_1_lite_identities.dart
```

### 2. **ADI Identity**

**File**: `SDK_Examples_file_2_Accumulate_Identities_(ADI).dart`

Accumulate Digital Identifiers (ADIs) are versatile and dynamic, allowing comprehensive management and authorization functionalities. ADIs can control various account types, including token accounts, data accounts, and custom tokens, offering a broad range of business and data functionalities.

**Focuses on**:
- Creation of ADI identities
- Management of key books and key pages
- Adding credits to key pages

To run ADI Identity examples
```bash
dart run SDK_Examples_file_2_Accumulate_Identities_(ADI).dart
```

### 3. **ADI Token Accounts**

**File**: `SDK_Examples_file_3_ADI_Token_Accounts.dart`

ADI Token Accounts are human-readable and controlled by an ADI's key book, facilitating ACME token transactions in a secure and efficient manner.

**Teaches**:
- Creation and management of ADI Token Accounts
- Transactions between ADI Token Accounts and Lite Token Accounts

To run ADI Token Accounts
```bash
dart run SDK_Examples_file_3_ADI_Token_Accounts.dart
```

### 4. **ADI Data Accounts**

**File**: `SDK_Examples_file_4_Data_Accounts_and_Entries.dart`

Accumulate's unique data account features enable easy data entry into the blockchain, supporting both legacy data constructs from the Factom Protocol and new scratch data entries for temporary storage.

**Covers**:
- Creation of ADI Data Accounts
- Data entry management within Data Accounts

To run Data and Lite Data Account Examples
```bash
dart run SDK_Examples_file_4_Data_Accounts_and_Entries.dart
```

### 5. **Custom Tokens**

**File**: `SDK_Examples_file_5_Custom_Tokens.dart`

Creating, issuing, and transferring custom tokens is simplified with Accumulate, requiring no smart contracts and offering flexibility for both business and personal use.

**Explores**:
- Custom token creation under an ADI
- Account management and token issuance

To run Custom Tokens Examples
```bash
dart run SDK_Examples_file_5_Custom_Tokens.dart
```

### 6. **Key Management**

**File**: `SDK_Examples_file_6_Key_Management.dart`

This example demonstrates key management functionalities essential for security and identity management within the Accumulate network.

**Explores**:
- Creation and management of Key Books and Key Pages
- Addition and updating of keys for enhanced security

To run ADI Key Management Examples
```bash
dart run SDK_Examples_file_6_Key_Management.dart
```

## 🤝 Support

For support or further clarification, consult the [Accumulate official documentation](https://docs.accumulatenetwork.io/) or join the Accumulate community on [Discord](https://discord.gg/2kBcaxrB).

## 📄 License

These examples are shared under the MIT License, encouraging open and collaborative development.
Loading

0 comments on commit 558725a

Please sign in to comment.