Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added Node Red project #2125

Closed
wants to merge 8 commits into from
Closed
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
164 changes: 164 additions & 0 deletions applications/NodeRed.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,164 @@
# Node Red Client for Polkadot

- **Team Name:** Zooper Corp
- **Payment Address:** 0x4776bbE1896D517BB81466b28D88e8dEd80ed110 (DAI) / 123VwdDkJeUd8K1g9gS5rZHKy1vQg1N64ZNcYYBk2J5ZEkfs (DOT)
- **[Level](https://github.com/w3f/Grants-Program/tree/master#level_slider-levels):** 2

## Project Overview :page_facing_up:

### Overview

Zooper Corp's Node Red Client for Polkadot is a project aimed at bridging the gap between advanced blockchain technologies and everyday users, particularly those who are not well-versed in coding. The project leverages the simplicity and flexibility of Node Red, a popular flow-based development tool, to create an intuitive interface for interacting with the Polkadot ecosystem. This integration is particularly significant in promoting the inclusion of non-technical individuals in blockchain activities, making it possible for them to participate in and benefit from the growing Polkadot ecosystem without requiring deep technical knowledge. Our Node Red client is designed to simplify complex blockchain operations, making it accessible for home automation enthusiasts, educators, and small business owners to integrate Polkadot functionalities into their operations. By providing a user-friendly platform, we enable users to manage blockchain-related tasks with ease, such as tracking cryptocurrency transactions, automating smart contracts, and monitoring blockchain events. The importance of our project in the Substrate ecosystem is underscored by the growing need for inclusive platforms that empower users at all technical levels.

### Project Details

- **Technology Stack:** NodeRed, JavaScript
- **Documentation:** Comprehensive documentation of core components and Node Red usage page
- **Prior Work:** https://flows.nodered.org/node/node-red-contrib-polkadot
- **Project Limitations:** Client supports Substrate only
- **Total Costs:** 25,000 DAI
- **Total Milestones:** 2

### Milestone 1 — Basic Functionality

- **Estimated Duration:** 3 months
- **FTE:** 1
- **Costs:** 10000 DAI

| Number | Deliverable | Specification |
| -----: | ----------- | ------------- |
| **0a.** | License | MIT |
| **0b.** | Documentation | We will provide both **inline documentation** of the code and a **tutorial** that explains how a user can use the nodes with examples for each single node and screenshots. |
| **0c.** | Testing and Testing Guide | Core functions will be fully covered by comprehensive unit tests to ensure functionality and robustness. |
| **0d.** | Docker | We will provide a modified Node Red Docker image that includes the plugin plus a few flows to quickly test the application. |
| 1. | Node Red Integration | Development of Node Red plugin that will provide visual "nodes" to connect to substrate based chains and perform basic interactions, initially plugin will support the following "nodes": configuration client (with sr25519 support only), raw chain storage query in the form of pallet.method(params...), chain info with decimals and runtime version, balance transfer and balance reading, raw trasaction in the form of pallet.method(params...) |
| 2. | Address issues | Assign, triage or address any pending issue on the github repo. |

### Milestone 2 — Metadata and EVM Chain Support

- **Estimated Duration:** 3 months
- **FTE:** 0.5
- **Costs:** 5000 DAI

| Number | Deliverable | Specification |
| -----: | ----------- | ------------- |
| **0a.** | License | MIT |
| **0b.** | Documentation | We will provide both **inline documentation** of the code and a **tutorial** that explains how a user can use the nodes with examples for each single node and screenshots. |
| **0c.** | Testing and Testing Guide | Core functions will be fully covered by comprehensive unit tests to ensure functionality and robustness. |
| **0d.** | Docker | We will provide a modified Node Red Docker image that includes the plugin plus a few flows to quickly test the application. |
| 1. | EVM Support | Adding support for EVM and ed25519 based chains, like Moonbeam. |
| 2. | Metadata Loading | Implementing automatic metadata loading and chain information inluding pallets and methods. |
| 3. | Proxy support | Add proxy support to transfer and transact nodes. |

### Milestone 3 — Block Event Subscription Node

- **Estimated Duration:** 3 months
- **FTE:** 0.5
- **Costs:** 5000 DAI

| Number | Deliverable | Specification |
| -----: | ----------- | ------------- |
| **0a.** | License | MIT |
| **0b.** | Documentation | We will provide both **inline documentation** of the code and a basic **tutorial** that explains how a user can use the nodes with examples for each single node and screenshots. |
| **0c.** | Testing and Testing Guide | Core functions will be fully covered by comprehensive unit tests to ensure functionality and robustness. |
| **0d.** | Docker | We will provide a modified Node Red Docker image that includes the plugin plus a few flows to quickly test the application. |
| 1. | Block Event Node | Development of a new node for subscribing to block events with extrinsic or address filtering. This could be very useful to use Node Red to be notified for a given transaction|

### Milestone 4 — Pallet/Function Selection and Payload Input

- **Estimated Duration:** 3 months
- **FTE:** 0.5
- **Costs:** 5000 DAI

| Number | Deliverable | Specification |
| -----: | ----------- | ------------- |
| **0a.** | License | MIT |
| **0b.** | Documentation | We will provide both **inline documentation** of the code and a basic **tutorial** that explains how a user can use the nodes with examples for each single node and screenshots. |
| **0c.** | Testing and Testing Guide | Core functions will be fully covered by comprehensive unit tests to ensure functionality and robustness. |
| **0d.** | Docker | We will provide a modified Node Red Docker image that includes the plugin plus a few flows to quickly test the application. |
| 1. | Pallet/Function Node | Creating a node allowing users to query chain by selecting pallets/functions and input payload, similar to the JS client. |


### Ecosystem Fit

- **Fit into the Ecosystem:** Enhances user interaction within the Polkadot ecosystem.
- **Target Audience:** Developers and end-users in the Polkadot community.
- **Needs Met:** Simplifies and enhances interactions with Polkadot.
- **Similar Projects:** None

## Team :busts_in_silhouette:

### Team members

- Franz

### Contact

- **Contact Name:** Franz
- **Contact Email:** johnuopini@gmail.com
- **Website:** [Zooper Corp HQ](https://corp.zooper.org/)

### Legal Structure

- **Registered Address:** No legal structure yet
- **Registered Legal Entity:** No legal structure yet

### Team's experience

Zooper Corp has a rich history as a blockchain validator team, contributing to various blockchain platforms with a strong focus on security and efficiency. Our team boasts extensive experience in developing a wide range of solutions, from sophisticated Android applications to robust backend systems and innovative cloud-based SaaS solutions. Our multi-faceted expertise positions us uniquely in the blockchain space, enabling us to deliver high-quality, comprehensive solutions for the Polkadot ecosystem.

### Team Code Repos

- https://github.com/Zooper-Corp/NodeRed-Polkadot

## Maintenance Grant :wrench:

- **Repo(s) needing maintenance:** https://github.com/Zooper-Corp/NodeRed-Polkadot
- **Reason for support:** The project is in active use by projects like [PolkaWatch](https://twitter.com/polkawatch/status/1654124259374145537) requiring ongoing development and maintenance (library updates, changes due to chain runtime upgrades).
- **Overview of contributions:** Enhancing features, fixing existing issues, aligning with the latest Polkadot versions.
- **Project owner's consent:** Confirmed consent from project owners for maintenance and enhancements.
- **Max budget per month:** 500 DOT

## Development Status :open_book:

Library is currently on its first milestone, its usable but lacks proper documentation and extended support for metadata. Also there is no regular update currently when base JS clients is updated.

## Maintenance Responsibilities :nut_and_bolt:

We own the project and we will keep updating it

### Issues we want to address:

1. **Up-to-date Documentation:** The existing documentation is sparse and outdated. We plan to develop comprehensive and user-friendly documentation.
2. **Code Comments and Clarity:** The current codebase lacks sufficient comments, making it challenging for new developers. We will add detailed comments and improve code readability.
3. **Bug Fixes and Feature Enhancements:** We aim to add new features, such as dynamic loading of metadata, to align with the latest updates in the Polkadot ecosystem.
4. **Community Engagement:** Actively engage with the community by responding to issues, discussions, and assisting contributors with their pull requests.

> ⚠️ *All code will keep current MIT license.*

### Maintenance Overview

- **Start Date:** 01/01/2024
- **Sprint/Period Duration:** Typically 8 weeks per sprint
- **Total Duration:** The contract is planned for 1 year
- **Full-Time Equivalent (FTE):** Approximately 0.5 FTE
- **Max budget per sprint/period:** 500 DOT per month
- **Hourly rate:** 100 DOT acknowledging the variable workload each sprint may require

> ⚠️ *At the end of each sprint, a comprehensive report detailing the work done will be provided. This includes a list of addressed issues/bugs/pull requests, time spent on each, and the associated cost. The report format will follow the Milestone Delivery structure, and payments will be processed post successful review and merge of each report by the Web3 Foundation.*

## Additional Information :heavy_plus_sign:

**How did you hear about the Maintenance Grants Program?** Our team learned about the Maintenance Grants Program through the Web3 Foundation

In addition to the information already provided, we would like to highlight some pertinent aspects:

- **Work Already Done:** The Node Red Client for Polkadot is a product of our dedicated efforts in the past. It has evolved from a basic concept to a functional tool that is currently in use within the Polkadot ecosystem.

- **Backward Payment Request:** Recognizing the value and impact of the work already completed, we respectfully request a backward payment of 2,000 DOT. This request is made in consideration of the substantial time and effort invested by our team in developing the Node Red Client for Polkadot to its current state. This payment would significantly aid in covering the initial development costs and provide a solid foundation for continued maintenance and enhancement of the project.

- **Collaboration and Contributions:** While Zooper Corp has been the primary developer of the Node Red Client for Polkadot, we have engaged with various community members and stakeholders for feedback and testing. However, to date, no other teams have financially contributed to the project.

- **Previous Grants:** This is our first application for a grant within the Web3 Foundation ecosystem. We have not previously applied for or received any grants for this project.

We believe that our ongoing commitment to the Node Red Client for Polkadot aligns well with the goals of the Maintenance Grants Program, and we are eager to continue our contributions to the Polkadot ecosystem.
Loading