<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: orville wang</title>
    <description>The latest articles on DEV Community by orville wang (@orville_wang_d2758f1be203).</description>
    <link>https://dev.to/orville_wang_d2758f1be203</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.us-east-2.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3991699%2F2dfbd35a-3ea2-4438-92b1-090e2092789a.png</url>
      <title>DEV Community: orville wang</title>
      <link>https://dev.to/orville_wang_d2758f1be203</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/orville_wang_d2758f1be203"/>
    <language>en</language>
    <item>
      <title>Stop measuring Web3 growth with Web2 metrics — Contribution &gt; DAU</title>
      <dc:creator>orville wang</dc:creator>
      <pubDate>Sun, 21 Jun 2026 10:03:32 +0000</pubDate>
      <link>https://dev.to/orville_wang_d2758f1be203/stop-measuring-web3-growth-with-web2-metrics-contribution-dau-46ce</link>
      <guid>https://dev.to/orville_wang_d2758f1be203/stop-measuring-web3-growth-with-web2-metrics-contribution-dau-46ce</guid>
      <description>&lt;blockquote&gt;
&lt;p&gt;Disclosure: I work on Opennomos (linked at the end). This is a thinking-out-loud post about a problem we've spent the last year trying to model.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h2&gt;
  
  
  The numbers we report are mostly lies
&lt;/h2&gt;

&lt;p&gt;Ship a Web3 product launch and you've watched this play out:&lt;/p&gt;

&lt;p&gt;Week 1: 10,000 wallets connect, TVL spikes, Twitter +5K followers. The CFO smiles. The VC retweets.&lt;/p&gt;

&lt;p&gt;Week 8: daily active addresses drop to 300. TVL bleeds back to launch-day levels. The Discord is mostly bots talking to bots.&lt;/p&gt;

&lt;p&gt;You know the truth — most of those 10K wallets were airdrop hunters running scripts across three browsers. But you can't write "DAU 12,000 (11,000 are bots)" in the investor update. So we round, we squint, we ship the dashboard.&lt;/p&gt;

&lt;p&gt;This isn't any one team failing. It's that we're measuring a fundamentally different system with the wrong instruments.&lt;/p&gt;

&lt;h2&gt;
  
  
  The Web2 funnel quietly assumes three things Web3 broke
&lt;/h2&gt;

&lt;p&gt;&lt;code&gt;Acquisition → Activation → Retention → Revenue&lt;/code&gt;. It assumes:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;strong&gt;One &lt;code&gt;user_id&lt;/code&gt; ≈ one human.&lt;/strong&gt; Web3: wallets and humans are many-to-many. One person, ten wallets. Or ten people, one wallet.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Repeated usage signals value.&lt;/strong&gt; Web3: half the meaningful on-chain actions are one-shots (claim, bridge, swap once and leave).&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Behavior correlates with revenue.&lt;/strong&gt; Web3: there are ten translation layers between a user click and a protocol fee.&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Almost every Web3 dashboard in production is built on these broken assumptions, then patched with sybil filters and bot-detection on the way out. We keep trying to make Web2 metrics stop lying about Web3, instead of asking what we should be measuring in the first place.&lt;/p&gt;

&lt;h2&gt;
  
  
  Stop counting users. Start counting contribution.
&lt;/h2&gt;

&lt;p&gt;The reframe that unstuck us:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Don't measure &lt;strong&gt;"who showed up."&lt;/strong&gt; Measure &lt;strong&gt;"who did something, and what that something was worth to the ecosystem."&lt;/strong&gt;&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;This view rotates a few things:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;A real person operating 3 wallets making 3 meaningful actions has &lt;em&gt;more&lt;/em&gt; contribution than one wallet farming 3,000 claims. DAU can't see this. Contribution can.&lt;/li&gt;
&lt;li&gt;An AI agent that completes a complex on-chain strategy has measurable contribution — and in Web3 we can actually price and pay it, because wallets are identity and transfers are payment. Web2 filters agents out as "non-human traffic." Web3 should treat them as first-class participants.&lt;/li&gt;
&lt;li&gt;A community translation, a bug report, a governance vote — those are real contributions. The funnel model has no slot for them. A contribution model does.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;This isn't new economics — "contribution-based rewards" already exists in mechanism design literature. What's new is making it operational in code.&lt;/p&gt;

&lt;h2&gt;
  
  
  What "operational contribution" needs at the engineering layer
&lt;/h2&gt;

&lt;p&gt;Four hard problems, none of which ship in a weekend:&lt;/p&gt;

&lt;h3&gt;
  
  
  1. Full-stack event capture
&lt;/h3&gt;

&lt;p&gt;Not just on-chain tx. You need:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Off-chain product actions (clicks, views, dApp social shares)&lt;/li&gt;
&lt;li&gt;Community contributions (governance, content, support)&lt;/li&gt;
&lt;li&gt;Agent actions — the structural differentiator vs. Web2&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;In code: SDK + Webhook + Indexer + Agent SDK, four pipes converging into one normalized event table.&lt;/p&gt;

&lt;h3&gt;
  
  
  2. Auditable attribution
&lt;/h3&gt;

&lt;p&gt;Whose reward, why, traceable end-to-end. Black-box incentive distribution is just rug-pull-on-delay. The model needs at least:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Source attribution&lt;/strong&gt; — which channel brought this action in&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Multi-touch&lt;/strong&gt; — one conversion can split across multiple contributors with weights&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Time decay&lt;/strong&gt; — early contributors weighted higher than late-arriving airdrop arbitrageurs&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  3. A rule engine, not hardcoded &lt;code&gt;if/else&lt;/code&gt;
&lt;/h3&gt;

&lt;p&gt;"What counts as contribution" varies wildly per project: quests in gaming, repeat purchase in commerce, liquidity depth in DeFi, governance quality in a DAO. A growth or PM person needs to define and revise these rules without filing a PR each time. That means a DSL or a visual rule designer, not a Solidity if-tree.&lt;/p&gt;

&lt;h3&gt;
  
  
  4. Two-way: humans AND agents
&lt;/h3&gt;

&lt;p&gt;This will hit everyone in the next 12 months: a real fraction of your dApp's activity will come from agents — the user's, third-parties', protocol-deployed. Tracking agent contribution &lt;strong&gt;and rewarding agents directly&lt;/strong&gt; — with those rewards routable back to a human operator — is something Web3 can do that Web2 structurally can't.&lt;/p&gt;

&lt;h2&gt;
  
  
  What we built — Opennomos
&lt;/h2&gt;

&lt;p&gt;An open-source attempt at the above: &lt;strong&gt;&lt;a href="https://github.com/NomosGrowth/opennomos" rel="noopener noreferrer"&gt;github.com/NomosGrowth/opennomos&lt;/a&gt;&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;In one paragraph: ingest events (on-chain + product + agent), score contribution (rule engine + multi-touch attribution + sybil resistance), distribute rewards (points / tokens / NFT badges / airdrop weights — composable and auditable). The Studio lets a PM design "5 on-chain actions + 1 governance vote → tier X reward" without writing code.&lt;/p&gt;

&lt;p&gt;Current stage is early; the schema is still settling and we're integrating with a handful of partner projects to harden it. Issues, ideas, and "this doesn't match how my project actually works" notes are extremely welcome on the repo.&lt;/p&gt;

&lt;h2&gt;
  
  
  The open question
&lt;/h2&gt;

&lt;p&gt;Most of the interesting Web3 problems are at the seams where Web2 abstractions don't fit. Growth measurement is one of those seams.&lt;/p&gt;

&lt;p&gt;If you've shipped Web3 user incentives at any scale: &lt;strong&gt;what do you measure, beyond DAU, that actually correlates with the growth you care about?&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Drop a comment or open an issue on the repo. The harder the edge case, the more useful.&lt;/p&gt;




&lt;p&gt;&lt;strong&gt;Links:&lt;/strong&gt; &lt;a href="https://github.com/NomosGrowth/opennomos" rel="noopener noreferrer"&gt;GitHub&lt;/a&gt; · &lt;a href="https://opennomos.com" rel="noopener noreferrer"&gt;opennomos.com&lt;/a&gt;&lt;/p&gt;

</description>
      <category>webdev</category>
      <category>web3</category>
      <category>opensource</category>
      <category>showdev</category>
    </item>
  </channel>
</rss>
