-
Notifications
You must be signed in to change notification settings - Fork 2.1k
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
Polkadot Common Good Apps Hub Application #2033
Conversation
Thanks for the application @Albertpolkadot a couple of initial comments:
|
|
||
### Pallet Contracts and Custom Upload Development | ||
|
||
To reduce barriers for builders creating applications, we plan to implement pallet contracts that support ink! based smart contracts. This approach provides a more accessible avenue for builders to deploy applications without the need for developing a separate pallet. Crafting a pallet can sometimes be time-consuming as it necessitates adhering to runtime requirements, benchmarking, and other considerations. By offering pallet contracts, we're not dissuading the community from constructing their own pallets and integrating them into the parachain runtime. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure I understand this statement, because devs don't need to create a separate pallet for ink! contracts, there is already the pallet-contracts module that any parachain can use. There is also the substrate-contracts-node for testing.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Correct, that is not what that statement means to say.
What we wanted to clarify is that by offering the chance to developers to upload their applications as a smart contracts, we are not discouraging pallet development either.
Any of both are valid development paths and it's up to the developer to choose which method they want to take,
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I hope this comment also helps to clarify this: #2033 (comment)
|
||
### Project Objective | ||
|
||
The primary goal of our project is to establish a parachain tailored to support a diverse range of applications. These applications will play a pivotal role in making contributions to the network, such as bolstering the treasuries of both Polkadot and Kusama, ensuring a robust financial foundation for the ecosystem's continuous evolution, promoting governance voting, and facilitating any application that serves the greater good. We're committed to fostering an environment within this parachain where the community is empowered to create applications. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you explain how this concept is different from other chains that cater to app developers such as Astar or Aleph Zero?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The primary distinction is that Astar or Aleph Zero offers permissionless access to block space via smart contracts. This means that once developers possess the necessary funds to cover the costs of smart contract uploads, they are free to develop any type of application for their own benefit.
For applications intended to be hosted here, the primary objective should be to serve and contribute to the Polkadot (and Kusama) network. This can be achieved by augmenting the treasury funds, encouraging governance participation, or by introducing a technical solution that other applications on different parachains can depend on, such as an oracle. If a team wishes to deploy an application that doesn't adhere to this principle, the decision rests with the DOT/KSM token holders to either approve or reject the application. Additionally, the native token for this parachain will be DOT/KSM, and all fees (100%) will be directed to the Polkadot/Kusama treasury.
As highlighted in the document, another key difference is our aspiration to emulate the functioning of system parachains. Here, the parachain will be under the governance of Polkadot/Kusama (with the native asset for the parachain being DOT/KSM).
When discussing applications, they can take on one of two forms: a new pallet or an ink! smart contract. The primary distinction between these two lies in their deployment method, setting aside the differences in their development processes.
To introduce a new application to the parachain, it must first be deliberated and approved by the DOT/KSM token holders. This discussion can take place on platforms like Polkassembly. Subsequently, the community must cast their votes on OpenGov to sanction the runtime upgrade. For instance, if the application is a pallet, once the runtime upgrade is enacted, the application may be deemed deployed.
For applications based on ink! smart contracts the deployment works as follows:
- The referendum is approved, triggering an XCM Transact aimed at executing the 'authorize' extrinsic from the custom-contract-upload pallet, where the hash of the smart contract blob will be supplied.
- The chain acknowledges the XCM call, and since it originates from the relay chain governance, the origin is converted to Root.
- The hash of the approved contract is recorded in the custom-contract-upload pallet storage (this action requires Root origin).
- With the hash registered, any account can upload the contract via the custom-contract-upload.
This procedure closely mirrors how runtime upgrades are conducted for system chains:
- The runtime upgrade receives authorization from the relay chain governance.
- Any entity is permitted to enact (upload) the new runtime version
Updating payment option to USDT on Polkadot AssetHub
Thank you very much for your feedback @keeganquigley!
Ok. Payment method updated.
The Dummy Random Testing Pallet is a pallet designed exclusively for testing purposes and will not see deployment in a production environment. This pallet doesn't generate any random values by itself; instead, it reads the random value derived from the pallet-randomness, which is intended to be developed under this grant. The method this testing pallet uses to read the random value is by implementing the type Randomness from frame_support::traits::Randomness in its Config trait. It's vital to underscore that this pallet won't be utilized in production. Its sole purpose is to ensure that the pallet-randomness accurately implements the Randomness trait, allowing other applications to retrieve this value. |
Updating Dummy Random Testing pallet.
| **0a.** | License | Apache 2.0 | | ||
| **0b.** | Documentation | We will provide a user tutorial to visualize the random value generated from the pallet. | | ||
| 1. | Randmoness Pallet | Develop the specifications and details described in the pallet randomness section. | | ||
| 2. | Dummy Random Testing Pallet | A testing pallet for reading the random value generated form the randomness pallet. This pallet will test mostly the Randmoness trait implementaion. | |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@keeganquigley: I have updated this item to reflect the purpose of this testing pallet.
Thanks for the update @Albertpolkadot I will mark the application as ready for review so the rest of the committee can comment on it. In the meantime, I noticed that there is no physical address or business entity listed. We will need a physical address in order to pay you; could you update to include it? Or if you'd rather it be private, you can email it to us as well at grants@web3.foundation Thanks! |
Thank you very much for your answer. I will contact you by email with the details requested. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for your application, @Albertpolkadot.
I have a few concerns. One, this grant is asking for USD 30k for a node with one slightly modified pallet. From a technical perspective, this is not reasonable, and as a technical program, this is what we are mainly looking at. Two, while there are concerns about the state of the treasuries, I'm wondering how efficient this approach is to improving the situation. Have you engaged with potential teams or projects to deploy on your parachain? Other than "making contributions to the network", what would be the motivation to deploy on your chain, where any smart contract needs to be approved? I agree with you that a common good apps parachain would be useful, but it would also require a lot of pull to attract developers. Third, can you specify what constitutes "a pivotal role in making contributions to the network"?
Hello @semuelle ! Thanks for reaching out with your questions and concerns. We're more than happy to address them:
This grant encompasses a significant amount of development effort, as outlined below: Pallet Randomness: If you're referencing the slightly modified pallet as the Custom Authorization Uploader (or Contracts Authorization module): Currently, there's no mechanism in the pallet contract to selectively authorize contract uploads. A workaround exists using the pallet-proxy and the pallet utility, but it lacks granularity. Our new pallet aims to introduce this functionality as an extension to the pallet-contracts. Another notable feature is that this pallet can only be triggered via an XCM Transact, granting authorization solely to the relay chain governance. Destroy Asset Pallet: This pallet's primary function is to destroy pre-minted chain balances like DOT/KSM. The parachain will initially require these balances for its operations until a sufficient amount is reserved based on transfers or teleports from the relay chain. Test Randomness Pallet: This is essentially a testing platform to ensure that the XCM: Configuring XCM to meet our needs is intricate. At a minimum, one AssetTransactor must have a specific Moreover, setting up a parachain runtime and its associated pallets is intricate due to the numerous configurations and settings involved. Given the above, this grant aims to tackle challenging and substantial feature development.
We firmly believe that a specialized infrastructure to harness community creativity can significantly benefit the network. Currently, the treasury primarily grows from transaction fees and slashing, with other sources playing a minor role. Changing these sources is cumbersome, necessitating extended discussions and complex development, as illustrated by this example: https://forum.polkadot.network/t/kusama-treasury-follow-up-analysis-continued-budgeting-incompetence/3143 Our solution offers a platform for community-driven initiatives to augment the treasury without necessitating core protocol alterations. This concept could further extend to areas like governance incentives as well.
We've engaged with various stakeholders, such as developers and delegation collectives. Most concur that there's a lack of a neutral space to materialize ideas that can address specific network challenges. Deploying on existing parachains often leads to treasury contributions in native parachain tokens, rather than DOT/KSM. This example is worth exploring: The tool was designed for building a Polkadot builders DAO. However, since it was deployed on Moonbeam, the treasury funds are denominated in GLMR, rather than the expected DOT or KSM. On the technical side, if an application requires advanced XCM interoperability, current solutions like ink! don't natively support XCM calls. Thus, developers often default to pallet development, but this necessitates having a ready-to-deploy parachain and the associated infrastructure. This complexity can discourage pallet developers to being their ideas into life. Our chain's primary incentive is its alignment with Polkadot's core values and its dedication to benefiting the Polkadot network. It could even evolve into a common-good parachain if the community so decides. The restriction on smart contract uploads ensures that the chain remains a platform for community-approved, common-good applications.
The statement wasn't meant to suggest a drastic protocol change. Rather, by providing an infrastructure for common-good apps, we're opening avenues for developers to contribute in ways currently unavailable. Reflecting on the treasury's challenges, our main inspiration, such applications could revolutionize how the community engages with app proposals and developments that run parallel to the protocol, all for the network's benefit. Please let us know if this response adequately addresses all of your questions and concerns. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the application. As pointed out by @semuelle could update the deliverables/milestone tables in a way in which they only contain the concrete, unique technical development that you need to do as part of the grant. Feel free to include the things that you listed above and with as many details as possible. For example, "configure" could mean a lot of things, but generally, that's not something that we would support via grants as long as it's not helpful for other projects, since everyone has to configure his parachain, etc. Regarding randomness, have you looked at https://github.com/Cardinal-Cryptography/substrate/tree/randomness-beacon-m1/client/randomness-beacon as well as the other work by Aleph Zero?
Hello, we appreciate all the feedback provided in this grant. We value your insights and have decided to close this grant for now, to re-organize our development milestones and the design around our infrastructure components. We aim to resubmit a more robust proposal in the near future. |
Project Abstract
Grant level
Application Checklist
project_name.md
).@_______:matrix.org
(change the homeserver if you use a different one)