- 
              - Installation
- Creating a project
- Choosing an Ethereum client
- Compiling contracts
- Running migrations
- Testing your contracts
- Writing tests in JavaScript
- Writing tests in Solidity
- Interacting with your contracts
- Package management via EthPM
- Package management via NPM
- Debugging your contracts
- Using Truffle Develop and the console
- Writing external scripts
- Using the build pipeline
- Contact the developers
 
Getting Started
Advanced
Ganache
Truffle Boxes
Creating a box
To create a Truffle Box you'll need a few things:
- A GitHub repository
- A configuration file
- Optionally, small and large images for the box's listing
The configuration file and images belong in the top-level directory of your repo. With these files in place, and your repo on GitHub, the unbox command will be: truffle unbox {USER_NAME || ORG_NAME}/{REPO_NAME}
If you're starting from scratch, we've created a blueprint box containing a configuration file with common values, as well as template versions of the small and large images.
If you're using an existing project, download the files here and extract them into your project.
Configuration file
All truffle boxes include a configuration file, truffle-box.json. This file has three attributes: ignore, commands, and hooks.
 ignore (array)
An array of files or relative paths you'd like Truffle to ignore when unboxing. Common files include the readme.md or .gitignore.
"ignore": [
  "README.md",
  ".gitignore"
]
 commands (object)
An object who's key/value pairs are a descriptor and console command respectively. These pairs will be shown to users once your box is successfully unboxed. Think of these as quick instructions.
For example, consider the object below. We've given our users all they need to compile, migrate and test their smart contracts, along with commands for developing the front-end.
"commands": {
  "Compile": "truffle compile",
  "Migrate": "truffle migrate",
  "Test contracts": "truffle test",
  "Test dapp": "npm test",
  "Run dev server": "npm run start",
  "Build for production": "npm run build"
}
 hooks (object)
An object containing console commands to execute once unboxed. Since we're working in Node.js, most commonly this will contain npm install.
"hooks": {
  "post-unpack": "npm install"
}
Images
The large box image is a 512px square with 32px of padding on each side.

The small box image is 735px x 100px. There is 32px of padding on the left side of the banner, and it's minimum size (described in the template as "Min Banner Width") is 290px, including the left padding. The banners are fixed to the left side and crop off the right side as the window narrows.

If no images are provided in a box, we default to banners containing the Truffle logo:


Truffle site listing
Before being listed on the Truffle website, all boxes undergo a screening process to ensure compatibility with Truffle. To start the pre-screening process, send us an email with your desired box name and brief description, along with a link to its GitHub repo to: info@trufflesuite.com.