2011-02-07 19:48:44 +13:00
# Module Development
## Introduction
Creating a module is a good way to re-use abstract code and templates across multiple projects. SilverStripe already has
certain modules included, for example "sapphire" and "cms". These three modules are the core functionality and
templating for any initial installation. If you're wanting to add generic functionality that isn't specific to your
project, like a forum, an ecommerce package or a blog you can do it like this;
1. Create another directory at the root level (same level as "sapphire" and "cms")
2. You must create an _config.php inside your module directory, else SilverStripe will not include it
3. Inside your module directory, follow our [directory structure guidelines ](/topics/directory-structure#module_structure )
## Tips
Try and keep your module as generic as possible - for example if you're making a forum module, your members section
shouldn't contain fields like 'Games You Play' or 'Your LiveJournal Name' - if people want to add these fields they can
2011-04-15 19:35:30 +10:00
sub-class your class, or extend the fields on to it.
2011-02-07 19:48:44 +13:00
If you're using Requirements to include generic support files for your project like CSS or Javascript, and want to
override these files to be more specific in your project, the following code is an example of how to do so using the
init() function on your module controller classes:
:::php
class Forum_Controller extends Page_Controller {
2012-01-30 23:13:42 +01:00
public function init() {
2011-02-07 19:48:44 +13:00
if(Director::fileExists(project() . "/css/forum.css")) {
Requirements::css(project() . "/css/forum.css");
}else{
Requirements::css("forum/css/forum.css");
}
parent::init();
}
}
2011-03-09 10:05:51 +13:00
This will use `<projectname>/css/forum.css` if it exists, otherwise it falls back to using `forum/css/forum.css` .
2011-02-07 19:48:44 +13:00
## Publication
If you wish to submit your module to our public directory, you take responsibility for a certain level of code quality,
adherence to conventions, writing documentation, and releasing updates. See [contributing ](/misc/contributing ).
## Reference
**How To:**
2011-03-09 10:05:51 +13:00
2011-02-07 19:48:44 +13:00
* [Add a link to your module in the main SilverStripe Admin Menu ](/reference/leftandmain )
2011-03-09 10:05:51 +13:00
**Useful Links:**
* [Modules ](modules )
* [Module Release Process ](module-release-process )
2011-02-07 19:48:44 +13:00
* [Debugging methods ](/topics/debugging )
2011-04-15 19:35:30 +10:00
* [URL Variable Tools ](/reference/urlvariabletools ) - Lists a number of <20> <> <EFBFBD> page options<6E> <73> <EFBFBD> , <20> <> <EFBFBD> rendering tools<6C> <73> <EFBFBD> or <20> <> <EFBFBD> special
URL variables<65> <73> <EFBFBD> that you can use to debug your sapphire applications