Creating EPiServer Admin/Edit Plug-ins using MVC
Since version 6 R1, EPiServer CMS has had full support for MVC routing. This is what enables you to create OnlineCenter Gadgets in MVC.
What may not have been obvious is that you can also create Admin and Edit mode plug-ins using MVC instead of Web Forms.
You start by creating a controller with a default Index method, an index view and optionally a model. I am not going to go into the specifics of how MVC works as there are plenty of blog posts out there by MVC experts that explain it far better than I could. I recommend looking at the Microsoft ASP.NET MVC site to start with.
To make your MVC controller / view into an EPiServer Admin / Edit plug-in, you need to add an EPiServer.PlugIn.GuiPlugIn attribute to the controller class. You can read more about EPiServer Plug-ins in the EPiServer SDK and also see an example of creating one using Web Forms by Frederik Vig.
[EPiServer.PlugIn.GuiPlugIn(
Area=EPiServer.PlugIn.PlugInArea.AdminConfigMenu,
Url="/modules/Alloy/MyAdminPlugin/Index",
DisplayName="My MVC Admin Plugin")]
public class MyAdminPluginController : Controller
{
public ActionResult Index()
{
return View();
}
}
The crucial item here is the Url value:
/modules/Alloy/MyAdminPlugin/Index.
That tells EPiServer CMS what to execute to render the HTML for your plug-in.
How the Url is determined
To understand this we need to look in the EPiServer CMS web.config in the EPiServer Shell public modules section:
<episerver.shell>
<publicModules rootPath="~/modules/" autoDiscovery="Minimal">
<add name="Alloy">
<assemblies>
<add assembly="EPiServer.Templates.AlloyTech" />
</assemblies>
</add>
</publicModules>
</episerver.shell>
You will see that the rootPath value for public modules is “modules” and that I have added a module called “Alloy”. Those 2 values make up the first 2 parts of the Url to the plug-in. This works because EPiServer CMS adds these values to the ASP.NET routing table when the application starts.
The last 2 parts of the Url are the controller name (without the controller suffix) and the name of the method to execute on the controller, in this case “Index”. This is standard MVC convention based programming in action in terms of matching a route in the format {controller}/{method}. In fact, you can even remove the “Index” part as this is assumed to be the default action. In that case the Url would be:
/modules/Alloy/MyAdminPlugin/
Comments