Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Learn-NEAR/NCD.L1.sample--thanks
Say "thanks!" to other students of the NCD by calling their instance of this contract. You can optionally attach tokens to your message, or even leave an anonymous tip.
https://github.com/Learn-NEAR/NCD.L1.sample--thanks
assemblyscript blockchain near-protocol
Last synced: 3 months ago
JSON representation
Say "thanks!" to other students of the NCD by calling their instance of this contract. You can optionally attach tokens to your message, or even leave an anonymous tip.
- Host: GitHub
- URL: https://github.com/Learn-NEAR/NCD.L1.sample--thanks
- Owner: Learn-NEAR
- Created: 2021-04-04T07:09:54.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2022-08-30T10:41:28.000Z (over 2 years ago)
- Last Synced: 2024-07-29T16:58:26.053Z (6 months ago)
- Topics: assemblyscript, blockchain, near-protocol
- Language: TypeScript
- Homepage:
- Size: 399 KB
- Stars: 10
- Watchers: 1
- Forks: 20
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Thanks
Say "thanks!" to other students of the NCD by calling _their_ instance of this contract.
You can optionally attach tokens to your message, or even leave an anonymous tip.
Of course keep in mind that your signing account will be visible on the blockchain via NEAR Explorer even if you send an anonymous message.
## ⚠️ Warning
Any content produced by NEAR, or developer resources that NEAR provides, are for educational and inspiration purposes only. NEAR does not encourage, induce or sanction the deployment of any such applications in violation of applicable laws or regulations.
## Contract
```ts
// ------------------------------------
// contract initialization
// ------------------------------------/**
* initialize contract with owner ID and other config data
*
* (note: this method is called "constructor" in the singleton contract code)
*/
function init(owner: AccountId, allow_anonymous: bool = true): void// ------------------------------------
// public methods
// ------------------------------------/**
* give thanks to the owner of the contract
* and optionally attach tokens
*/
function say(message: string, anonymous: bool): bool// ------------------------------------
// owner methods
// ------------------------------------/**
* show all messages and users
*/
function list(): Array/**
* generate a summary report
*/
function summarize(): Contract/**
* transfer received funds to owner account
*/
function transfer(): void
```## Usage
### Development
To deploy the contract for development, follow these steps:
1. clone this repo locally
2. run `yarn` to install dependencies
3. run `./scripts/1.dev-deploy.sh` to deploy the contract (this uses `near dev-deploy`)**Your contract is now ready to use.**
To use the contract you can do any of the following:
_Public scripts_
```sh
2.say-thanks.sh # post a message saying thank you, optionally attaching NEAR tokens
2.say-anon-thanks.sh # post an anonymous message (otherwise same as above)
```_Owner scripts_
```sh
o-report.sh # generate a summary report of the contract state
o-transfer.sh # transfer received funds to the owner account
```### Production
It is recommended that you deploy the contract to a subaccount under your MainNet account to make it easier to identify you as the owner
1. clone this repo locally
2. run `./scripts/x-deploy.sh` to rebuild, deploy and initialize the contract to a target accountrequires the following environment variables
- `NEAR_ENV`: Either `testnet` or `mainnet`
- `OWNER`: The owner of the contract and the parent account. The contract will be deployed to `thanks.$OWNER`3. run `./scripts/x-remove.sh` to delete the account
requires the following environment variables
- `NEAR_ENV`: Either `testnet` or `mainnet`
- `OWNER`: The owner of the contract and the parent account. The contract will be deployed to `thanks.$OWNER`