Skip to content

Commit dcc357b

Browse files
authored
Merge branch 'develop' into feature/add-gitbook-provider
2 parents 83a2850 + 2f3f7cb commit dcc357b

File tree

11 files changed

+450
-18
lines changed

11 files changed

+450
-18
lines changed

CODE_OF_CONDUCT.md

+128
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,128 @@
1+
# Contributor Covenant Code of Conduct
2+
3+
## Our Pledge
4+
5+
We as members, contributors, and leaders pledge to make participation in our
6+
community a harassment-free experience for everyone, regardless of age, body
7+
size, visible or invisible disability, ethnicity, sex characteristics, gender
8+
identity and expression, level of experience, education, socio-economic status,
9+
nationality, personal appearance, race, religion, or sexual identity
10+
and orientation.
11+
12+
We pledge to act and interact in ways that contribute to an open, welcoming,
13+
diverse, inclusive, and healthy community.
14+
15+
## Our Standards
16+
17+
Examples of behavior that contributes to a positive environment for our
18+
community include:
19+
20+
* Demonstrating empathy and kindness toward other people
21+
* Being respectful of differing opinions, viewpoints, and experiences
22+
* Giving and gracefully accepting constructive feedback
23+
* Accepting responsibility and apologizing to those affected by our mistakes,
24+
and learning from the experience
25+
* Focusing on what is best not just for us as individuals, but for the
26+
overall community
27+
28+
Examples of unacceptable behavior include:
29+
30+
* The use of sexualized language or imagery, and sexual attention or
31+
advances of any kind
32+
* Trolling, insulting or derogatory comments, and personal or political attacks
33+
* Public or private harassment
34+
* Publishing others' private information, such as a physical or email
35+
address, without their explicit permission
36+
* Other conduct which could reasonably be considered inappropriate in a
37+
professional setting
38+
39+
## Enforcement Responsibilities
40+
41+
Community leaders are responsible for clarifying and enforcing our standards of
42+
acceptable behavior and will take appropriate and fair corrective action in
43+
response to any behavior that they deem inappropriate, threatening, offensive,
44+
or harmful.
45+
46+
Community leaders have the right and responsibility to remove, edit, or reject
47+
comments, commits, code, wiki edits, issues, and other contributions that are
48+
not aligned to this Code of Conduct, and will communicate reasons for moderation
49+
decisions when appropriate.
50+
51+
## Scope
52+
53+
This Code of Conduct applies within all community spaces, and also applies when
54+
an individual is officially representing the community in public spaces.
55+
Examples of representing our community include using an official e-mail address,
56+
posting via an official social media account, or acting as an appointed
57+
representative at an online or offline event.
58+
59+
## Enforcement
60+
61+
Instances of abusive, harassing, or otherwise unacceptable behavior may be
62+
reported to the community leaders responsible for enforcement at
63+
[discord server](https://discord.gg/ai16z).
64+
All complaints will be reviewed and investigated promptly and fairly.
65+
66+
All community leaders are obligated to respect the privacy and security of the
67+
reporter of any incident.
68+
69+
## Enforcement Guidelines
70+
71+
Community leaders will follow these Community Impact Guidelines in determining
72+
the consequences for any action they deem in violation of this Code of Conduct:
73+
74+
### 1. Correction
75+
76+
**Community Impact**: Use of inappropriate language or other behavior deemed
77+
unprofessional or unwelcome in the community.
78+
79+
**Consequence**: A private, written warning from community leaders, providing
80+
clarity around the nature of the violation and an explanation of why the
81+
behavior was inappropriate. A public apology may be requested.
82+
83+
### 2. Warning
84+
85+
**Community Impact**: A violation through a single incident or series
86+
of actions.
87+
88+
**Consequence**: A warning with consequences for continued behavior. No
89+
interaction with the people involved, including unsolicited interaction with
90+
those enforcing the Code of Conduct, for a specified period of time. This
91+
includes avoiding interactions in community spaces as well as external channels
92+
like social media. Violating these terms may lead to a temporary or
93+
permanent ban.
94+
95+
### 3. Temporary Ban
96+
97+
**Community Impact**: A serious violation of community standards, including
98+
sustained inappropriate behavior.
99+
100+
**Consequence**: A temporary ban from any sort of interaction or public
101+
communication with the community for a specified period of time. No public or
102+
private interaction with the people involved, including unsolicited interaction
103+
with those enforcing the Code of Conduct, is allowed during this period.
104+
Violating these terms may lead to a permanent ban.
105+
106+
### 4. Permanent Ban
107+
108+
**Community Impact**: Demonstrating a pattern of violation of community
109+
standards, including sustained inappropriate behavior, harassment of an
110+
individual, or aggression toward or disparagement of classes of individuals.
111+
112+
**Consequence**: A permanent ban from any sort of public interaction within
113+
the community.
114+
115+
## Attribution
116+
117+
This Code of Conduct is adapted from the [Contributor Covenant][homepage],
118+
version 2.0, available at
119+
https://www.contributor-covenant.org/version/2/0/code_of_conduct.html.
120+
121+
Community Impact Guidelines were inspired by [Mozilla's code of conduct
122+
enforcement ladder](https://github.com/mozilla/diversity).
123+
124+
[homepage]: https://www.contributor-covenant.org
125+
126+
For answers to common questions about this code of conduct, see the FAQ at
127+
https://www.contributor-covenant.org/faq. Translations are available at
128+
https://www.contributor-covenant.org/translations.

packages/client-twitter/src/utils.ts

+1-1
Original file line numberDiff line numberDiff line change
@@ -247,7 +247,7 @@ export async function sendTweet(
247247
sentTweets.push(finalTweet);
248248
previousTweetId = finalTweet.id;
249249
} else {
250-
console.error("Error sending chunk", chunk, "repsonse:", body);
250+
console.error("Error sending chunk", chunk, "response:", body);
251251
}
252252

253253
// Wait a bit between tweets to avoid rate limiting issues

packages/plugin-story/src/actions/attachTerms.ts

+3-3
Original file line numberDiff line numberDiff line change
@@ -4,9 +4,9 @@ import {
44
generateObjectDeprecated,
55
HandlerCallback,
66
ModelClass,
7-
type IAgentRuntime,
8-
type Memory,
9-
type State,
7+
IAgentRuntime,
8+
Memory,
9+
State,
1010
} from "@elizaos/core";
1111
import { WalletProvider } from "../providers/wallet";
1212
import { attachTermsTemplate } from "../templates";

packages/plugin-story/src/actions/getAvailableLicenses.ts

+3-3
Original file line numberDiff line numberDiff line change
@@ -4,9 +4,9 @@ import {
44
generateObjectDeprecated,
55
HandlerCallback,
66
ModelClass,
7-
type IAgentRuntime,
8-
type Memory,
9-
type State,
7+
IAgentRuntime,
8+
Memory,
9+
State,
1010
} from "@elizaos/core";
1111
import { getAvailableLicensesTemplate, licenseIPTemplate } from "../templates";
1212
import { Address } from "viem";

packages/plugin-story/src/actions/getIPDetails.ts

+3-3
Original file line numberDiff line numberDiff line change
@@ -4,9 +4,9 @@ import {
44
generateObjectDeprecated,
55
HandlerCallback,
66
ModelClass,
7-
type IAgentRuntime,
8-
type Memory,
9-
type State,
7+
IAgentRuntime,
8+
Memory,
9+
State,
1010
} from "@elizaos/core";
1111
import { getIPDetailsTemplate } from "../templates";
1212
import { Address } from "viem";

packages/plugin-story/src/actions/licenseIP.ts

+3-3
Original file line numberDiff line numberDiff line change
@@ -4,9 +4,9 @@ import {
44
generateObjectDeprecated,
55
HandlerCallback,
66
ModelClass,
7-
type IAgentRuntime,
8-
type Memory,
9-
type State,
7+
IAgentRuntime,
8+
Memory,
9+
State,
1010
} from "@elizaos/core";
1111
import { WalletProvider } from "../providers/wallet";
1212
import { licenseIPTemplate } from "../templates";

packages/plugin-story/src/actions/registerIP.ts

+3-3
Original file line numberDiff line numberDiff line change
@@ -4,9 +4,9 @@ import {
44
generateObjectDeprecated,
55
HandlerCallback,
66
ModelClass,
7-
type IAgentRuntime,
8-
type Memory,
9-
type State,
7+
IAgentRuntime,
8+
Memory,
9+
State,
1010
} from "@elizaos/core";
1111
import pinataSDK from "@pinata/sdk";
1212
import { RegisterIpResponse } from "@story-protocol/core-sdk";

packages/plugin-story/src/index.ts

+1-1
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ export * from "./actions/getIPDetails";
66
export * from "./providers/wallet";
77
export * from "./types";
88

9-
import type { Plugin } from "@elizaos/core";
9+
import { Plugin } from "@elizaos/core";
1010
import { storyWalletProvider } from "./providers/wallet";
1111
import { registerIPAction } from "./actions/registerIP";
1212
import { licenseIPAction } from "./actions/licenseIP";

packages/plugin-story/src/providers/wallet.ts

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
import type { IAgentRuntime, Provider, Memory, State } from "@elizaos/core";
1+
import { IAgentRuntime, Provider, Memory, State } from "@elizaos/core";
22
import {
33
createPublicClient,
44
createWalletClient,

packages/plugin-ton/Readme.md

+124
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,124 @@
1+
# Plugin TON
2+
3+
A plugin for handling TON (Telegram Open Network) blockchain operations, such as wallet management and transfers.
4+
5+
## Overview and Purpose
6+
7+
The Plugin TON provides a streamlined interface to interact with the TON blockchain. It simplifies wallet management and facilitates secure, efficient transfers while maintaining compatibility with TypeScript and modern JavaScript development practices.
8+
9+
## Installation
10+
11+
Install the plugin using npm:
12+
13+
```bash
14+
npm install plugin-ton
15+
```
16+
17+
## Configuration Requirements
18+
19+
Ensure your environment is set up with the necessary configuration files and environment variables. Update the `src/enviroment.ts` file or set environment variables directly for sensitive information.
20+
21+
### Environment Variables
22+
23+
| Variable Name | Description |
24+
| ------------------------ | ------------------------------------- |
25+
| `TON_API_ENDPOINT` | API endpoint for interacting with TON |
26+
| `TON_WALLET_PRIVATE_KEY` | Private key for wallet operations |
27+
28+
## Usage Examples
29+
30+
### Importing the Plugin
31+
32+
```typescript
33+
import { WalletProvider, TransferAction } from 'plugin-ton';
34+
35+
// Initialize wallet provider
36+
const wallet = new WalletProvider('YOUR_PRIVATE_KEY');
37+
38+
// Fetch wallet balance
39+
const balance = await wallet.getBalance();
40+
console.log('Wallet Balance:', balance);
41+
42+
// Transfer TON coins
43+
const transfer = new TransferAction(wallet);
44+
await transfer.execute({
45+
to: 'RECIPIENT_ADDRESS',
46+
amount: 10,
47+
});
48+
console.log('Transfer successful');
49+
```
50+
51+
## API Reference
52+
53+
### WalletProvider
54+
55+
#### Methods:
56+
57+
- `constructor(privateKey: string)` - Initializes the wallet with a private key.
58+
- `getBalance(): Promise<number>` - Retrieves the wallet balance.
59+
60+
### TransferAction
61+
62+
#### Methods:
63+
64+
- `constructor(wallet: WalletProvider)` - Initializes the transfer action.
65+
- `execute({ to: string, amount: number }): Promise<void>` - Executes a transfer of TON coins.
66+
67+
## Common Issues/Troubleshooting
68+
69+
### Issue: Balance Fetching Failure
70+
71+
- **Cause**: Incorrect API endpoint or private key.
72+
- **Solution**: Verify `TON_API_ENDPOINT` and private key in your configuration.
73+
74+
### Issue: Transfer Fails
75+
76+
- **Cause**: Insufficient balance or invalid recipient address.
77+
- **Solution**: Ensure sufficient funds and a valid recipient address.
78+
79+
## Additional Documentation
80+
81+
### Examples Folder Documentation
82+
83+
The examples folder includes sample scripts demonstrating wallet initialization, balance checking, and transfers. Use these as a starting point for your integration.
84+
85+
### Testing Guide Expansion
86+
87+
Run tests using the following command:
88+
89+
```bash
90+
npm test
91+
```
92+
93+
The `src/tests/wallet.test.ts` file provides unit tests for wallet functionality. Add tests for additional features as needed.
94+
95+
### Plugin Development Guide
96+
97+
1. Clone the repository.
98+
2. Run `npm install` to install dependencies.
99+
3. Use `tsup` for building the project: `npm run build`.
100+
4. Add new features in the `src` directory.
101+
102+
### Security Best Practices
103+
104+
- **Key Management**: Use environment variables for sensitive information like private keys.
105+
- **Testing**: Validate all inputs to prevent injection attacks.
106+
- **Dependencies**: Regularly update dependencies to patch vulnerabilities.
107+
108+
### Performance Optimization Guide
109+
110+
- Use efficient data structures for large transactions.
111+
- Avoid unnecessary API calls by caching frequent responses.
112+
- Use async/await for optimal asynchronous operations.
113+
114+
## Contributing
115+
116+
1. Fork the repository.
117+
2. Create your feature branch (`git checkout -b feature/amazing-feature`).
118+
3. Commit your changes (`git commit -m 'Add some amazing feature'`).
119+
4. Push to the branch (`git push origin feature/amazing-feature`).
120+
5. Open a Pull Request.
121+
122+
## License
123+
124+
MIT

0 commit comments

Comments
 (0)