Skip to content

Latest commit

 

History

History
118 lines (88 loc) · 4.93 KB

README.md

File metadata and controls

118 lines (88 loc) · 4.93 KB

VeChain App-Hub - Submit Form

Awesome

First off, thanks for making the awesome app on VeChain and taking the time to contribute 💪

The following is a set of guidelines for contributing to AppHub. These are just guidelines, not rules. Use your best judgment and feel free to propose changes to this document in a pull request.

Rules

  1. The app must run on Mainnet
  2. Support Connex
  3. Logo is required
  4. The id must be unique
  5. Short and simple descriptions
  6. Comply with directory & contents rules
  7. One application per submission

Adding your app

To add your application, you need to create your app details and make a pull request for the maintainers to review your app and merge into AppHub.

Recommended workflow:

  • Fork the AppHub
  • Create a new branch
  • Create your app details and upload to the proper directory
  • Make the pull request

Ref:

Create a directory

Once the AppHub is forked, create a new directory in the apps directory with unique id and include a manifest.json file and logo.png file. To create a unique id, you can append the name of the application to the reversed domain such as com.example.your-app-name. Your app directory structure should be look like this

├── apps
│   └── com.example.your-app-name
│       ├── logo.png
│       └── manifest.json

Create a JSON File & Rules

Create a manifest.json file includes app details.

//manifest.json
{
    "name": "your app name",
    "href": "https://link-to-your-app",
    "desc": "This is an awesome app",
    "category": "utilities",
    "tags": ["tools","development"],
    "repo": "https://github.com/example/projectName",
    "contracts": [
        "0x1234567890123456789012345678901234567890",
        "0x0987654321098765432109876543210987654321"
    ],
    "isVeWorldSupported": false,
    "veBetterDaoId": "0x821a9ae30590c7c11e0ebc03b27902e8cae0f320ad27b0f5bde9f100eebcb5a7"
}
  • name is required.
  • href is required, and must be a fully-qualified URL.
  • desc is required.
  • category is required, and must be one of the provided category.
  • tags is required, should be an array if provided.
  • isVeWorldSupported is required, set this to true if your dApp supports the VeWorld browser extension, enabling its use within the VeWorld mobile wallet. Your dApp will then be listed in the dApp section of the VeWorld mobile discovery.
  • repo is optional, and must be a fully-qualified URL.
  • contracts is optional, should be an array and lower cases if provided
  • veBetterDaoId is optional, it represents the ID of the VeBetterDAO DApp.
  • No fields should be left blank.

Categories

category is required and must be one of the following values:

  • collectibles
  • defi
  • games
  • marketplaces
  • utilities

Import the Logo & Rules

Import your app logo into the directory and name it logo.

A logo is a symbol made up of text and images that identifies an application.

  • Must be a .png
  • Must be 512px by 512px
  • Must not be a copy of another company's or application's logo
  • Must not contain any marketing information (including but not limited to social media links/sale date)

Submission Guidelines

  • The pull request should have a clean git history.
  • Don't use another company's trademarks (icon, logo or name) without supplying evidence of prior permission
  • Create a directory under /apps/ and contains the manifest.json and the logo.png
  • Keep description short and simple, but descriptive.
  • Check your spelling and grammar.
  • URL must have schemes of http or https.
  • Logo complies with the logo rules

If the maintainers/reviewer notice anything that we'd like changed, we'll ask you to edit your PR before we merge it.

Last but not least

When users interact with your application, the function names and parameters are encoded as hex values in clause data field which is not very human-readable. You can submit the ABIs on b32 to help the user understand more about the interaction details.