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

feat(gnoland): Define NoopMsg to facilitate the creation of sponsor transaction (gasless transaction) #2209

Open
wants to merge 24 commits into
base: master
Choose a base branch
from

Conversation

linhpn99
Copy link
Contributor

@linhpn99 linhpn99 commented May 27, 2024

Update 2024-06-19 : This PR is in the process of refactoring the sponsor transaction section. It will be open for review when completed
Update 2024-06-26 : Ready to review
Update 2024-07-25 : The sponsor transaction section has been moved to #2630

From Proposal #2152:

This PR Introduces a new message type vm.MsgNoop: a type of message that does not trigger any logic processing in the vmHandler

Related Pull Requests:

  1. feat(examples): Implement sponsors (p+r) for sponsor service management #2411: This pull request introduces a set (p+r) to manage onchain sponsor services
  2. feat(gnoland): Define and implement SponsorTransaction concept #2630: This pull request enhances the gnoclient by introducing the ability to create and send a sponsor transaction through the definition of a noopMsg
Contributors' checklist...
  • Added new tests, or not needed, or not feasible
  • Provided an example (e.g. screenshot) to aid review or the PR is self-explanatory
  • Updated the official documentation or not needed
  • No breaking changes were made, or a BREAKING CHANGE: xxx message was included in the description
  • Added references to related issues and PRs
  • Provided any useful hints for running manual tests
  • Added new benchmarks to generated graphs, if any. More info here.

@linhpn99 linhpn99 marked this pull request as draft May 27, 2024 06:53
@github-actions github-actions bot added the 📦 ⛰️ gno.land Issues or PRs gno.land package related label May 27, 2024
@linhpn99 linhpn99 changed the title WIP: define NoopMsg feat(gnovm):define NoopMsg May 27, 2024
@linhpn99 linhpn99 changed the title feat(gnovm):define NoopMsg feat(gnovm): define NoopMsg May 27, 2024
Copy link

codecov bot commented May 27, 2024

Codecov Report

Attention: Patch coverage is 68.75000% with 15 lines in your changes missing coverage. Please review.

Files with missing lines Patch % Lines
tm2/pkg/sdk/testutils/testutils.go 46.15% 7 Missing ⚠️
gno.land/pkg/sdk/vm/msgs.go 53.84% 6 Missing ⚠️
tm2/pkg/std/tx.go 83.33% 1 Missing and 1 partial ⚠️

📢 Thoughts on this report? Let us know!

@linhpn99
Copy link
Contributor Author

linhpn99 commented May 27, 2024

From issue #2182
@moul should i implement MsgNoop like this PR ?
If you have free time, please take a look and give me feedback if there is anything unreasonable so we can move forward

@thehowl
Copy link
Member

thehowl commented May 27, 2024

Can you explain why you need this?

@linhpn99
Copy link
Contributor Author

linhpn99 commented May 27, 2024

Can you explain why you need this?

I want a feature where a user who owns the native token (sponsor) can cover the gas fees for a user who does not own the native token (sponsoree), allowing them to perform on-chain actions with their messages (such as calling a realm function)

detail here : #2152 & #2630

@moul moul changed the title feat(gnovm): define NoopMsg feat(gnoland): define NoopMsg May 27, 2024
Copy link
Member

@moul moul left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The goal of NoopMsg is to be a message that does nothing and is as small as possible once transmitted and stored.
Then, we can use it in multi-message transactions to experiment with gas sponsorship.

@linhpn99 linhpn99 requested a review from moul May 28, 2024 03:40
@linhpn99 linhpn99 marked this pull request as ready for review May 28, 2024 16:26
@linhpn99 linhpn99 requested review from jaekwon and piux2 as code owners May 29, 2024 05:32
@github-actions github-actions bot added the 📦 🌐 tendermint v2 Issues or PRs tm2 related label May 29, 2024
@linhpn99 linhpn99 requested a review from a team as a code owner May 29, 2024 16:57
@linhpn99 linhpn99 changed the title feat(gnoland): define NoopMsg feat(gnoland): define NoopMsg for gnoclient May 30, 2024
@linhpn99 linhpn99 changed the title feat(gnoland): define NoopMsg for gnoclient feat(gnoclient): define NoopMsg to Support Creating Gas-Free Transactions May 30, 2024
@linhpn99 linhpn99 changed the title feat(gnoclient): define NoopMsg to Support Creating Gas-Free Transactions feat(gnoclient): define NoopMsg to support creating gasless transactions May 30, 2024
@linhpn99 linhpn99 requested a review from a team as a code owner June 4, 2024 03:29
@linhpn99 linhpn99 changed the title feat(gnoclient): define NoopMsg to support creating gasless transactions feat(gnoclient): define NoopMsg to support creating sponsorship transactions Jun 4, 2024
@linhpn99 linhpn99 changed the title feat(gnoclient): define NoopMsg to support creating sponsorship transactions feat(gnoclient): Define NoopMsg to facilitate the creation of sponsorship transactions Jun 4, 2024
Copy link

github-actions bot commented Dec 4, 2024

This PR is stale because it has been open 3 months with no activity. Remove stale label or comment or this will be closed in 3 months.

@github-actions github-actions bot added the Stale label Dec 4, 2024
@Gno2D2
Copy link
Collaborator

Gno2D2 commented Dec 4, 2024

I'm a bot that assists the Gno Core team in maintaining this repository. My role is to ensure that contributors understand and follow our guidelines, helping to streamline the development process.

The following requirements must be fulfilled before a pull request can be merged.
Some requirement checks are automated and can be verified by the CI, while others need manual verification by a staff member.

These requirements are defined in this configuration file.

Automated Checks

🟢 Maintainers must be able to edit this pull request
🔴 The pull request head branch must be up-to-date with its base

Manual Checks

  • The pull request description provides enough details
Debug
Automated Checks
Maintainers must be able to edit this pull request

If

🟢 Condition met
└── 🟢 On every pull request

Then

🟢 Requirement satisfied
└── 🟢 Maintainer can modify this pull request

The pull request head branch must be up-to-date with its base

If

🟢 Condition met
└── 🟢 On every pull request

Then

🔴 Requirement not satisfied
└── 🔴 Head branch (linhpn99:define-MsgNoop) is up to date with base (master): behind by 201 / ahead by 24

Manual Checks
The pull request description provides enough details

If

🟢 Condition met
└── 🟢 Not (🔴 Pull request author is a member of the team: core-contributors)

Can be checked by

  • team core-contributors

@github-actions github-actions bot removed the Stale label Dec 5, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
📦 🌐 tendermint v2 Issues or PRs tm2 related 📦 ⛰️ gno.land Issues or PRs gno.land package related 📦 🤖 gnovm Issues or PRs gnovm related 🧾 package/realm Tag used for new Realms or Packages.
Projects
Status: In Progress
Status: 🫂 Chores
Status: In Review
Development

Successfully merging this pull request may close these issues.

5 participants