Apr 15, 2010
visibility 5766
star star star star star
(0 votes)

Easier dependency injection with EPiMVP

EPiMVP is an implementation of the WebForms MVP pattern created by Mattias Johansson and Joel Abrahamsson. While my general impression and opinion about WebForms MVP is quite similar to that Rob Conery expressed here, that’s in the context of choosing between MVC and WebForms. As I’m sure you’re all aware that’s not a choice we get to make when working with episerver (unless you’ve found a business model that let’s you develop gadgets full time in which case you can please contact me with a job offer =)).

Anyway, this post will be a short one that sort of does the same thing as I did in my previous post.

 

The presenter factory

MVP uses a presenter factory that’s responsible for delivering presenters, similar to the controller factory in MVC. Since you can create your own factory this makes for a good root to use for your dependency injection since it’s called every time a presenter is requested.

EPIMVP, much to my joy, comes with a StructureMapPresenterFactory so we don’t have to create one our self. (It looks to also come with a implementation for Ninject and if you’re into another IoC container it shouldn’t be too much of  a hassle to create your own factory.)

To use the factory we must inform MVP to use it which we’ll do in Application_Start of global.asax.

   1: protected void Application_Start(Object sender, EventArgs e)
   2: {
   3:     WebFormsMvp.Binder.PresenterBinder.Factory = new EPiMVP.StructureMap.StructureMapPresenterFactory();
   4:     XFormControl.ControlSetup += new EventHandler(XForm_ControlSetup);
   5: }

 

Injecting the dependencies

Injecting dependencies is now as simple as declaring them in the constructor of our presenters. Using the example Joel wrote about here we’ll add a dependency to our IFoo interface in the FlatterPresenter.

   1: protected readonly IFoo foo;
   2:  
   3: public FlatterPresenter(IFlatterView view, 
   4:     FlatterPage pageData, IFoo foo)
   5:     : base(view, pageData)
   6: {
   7:     this.foo = foo;
   8:     View.Load += View_Load;
   9:     View.FlatterRequested += View_FlatterRequested;
  10: }

 

The interface and a implementation could look like this

   1: public interface IFoo
   2: {
   3:     string SomeString();
   4: }
   5:  
   6: public class Foo : IFoo
   7: {
   8:     public string SomeString()
   9:     {
  10:         return DateTime.Now.ToShortDateString();
  11:     }
  12: }

 

We’ll setup StructureMap to use the concrete class Foo whenever a type of IFoo is requested. This is also done in Application_Start in global.asax and the full method now looks like this.

   1: protected void Application_Start(Object sender, EventArgs e)
   2: {
   3:     ObjectFactory.Configure(x =>
   4:             {
   5:                 x.For<Presenters.IFoo>().Use<Presenters.Foo>();
   6:             }
   7:         );
   8:     WebFormsMvp.Binder.PresenterBinder.Factory = new EPiMVP.StructureMap.StructureMapPresenterFactory();
   9:     XFormControl.ControlSetup += new EventHandler(XForm_ControlSetup);
  10: }

 

Now we can use our IFoo implementation in our presenter class. It’s quite a nice change of pace compared to the Setter Injection / Build Up we have to do when using standard WebForms.

Apr 15, 2010

Comments

error Please login to comment.
Latest blogs
Finding Thomas Part 3 - The Moment of Recognition

Remember Thomas? In digital landscape, Thomas is the returning visitor who reads everything, opens every email, converts on nothing. In standard...

Ritu Madan | Jun 26, 2026

Add more scheduled job settings from the Optimizely CMS 12 admin UI -- with OptiScheduledJob.ExtraParameters

  Optimizely (EPiServer) CMS 12 ships a great scheduled-jobs framework, but it has one frustrating gap: a job has nowhere to store its own...

Binh Nguyen Thi | Jun 25, 2026

Automated Search & Navigation to Graph Migration with Claude Code

A Claude Code plugin that scans your S&N codebase, applies Graph SDK transformations, and validates the result. Install once, run one command. CMS ...

Connor Fortin | Jun 24, 2026

Migrating from Find to Graph: Lessons Learned from a Real CMS 13 Project

While migrating a search solution from Optimizely Search & Navigation (Find) to Optimizely Graph in CMS 13, I encountered several issues that were...

Binh Nguyen Thi | Jun 24, 2026

Optimizely: Upgrade Opti-ID and .NET 10 in CMS 12

Many Optimizely customers are planning their roadmap around a future migration to Optimizely CMS 13. As a result, upgrades such as Opti ID adoption...

Madhu | Jun 23, 2026 |

Understanding Optimizely Graph: Caching, Webhooks & Avoiding Stale Content (Optimizely SaaS CMS)

📌 Scope: This post covers Optimizely CMS (SaaS) only — using the official @optimizely/cms-sdk and @optimizely/cms-cli packages with Next.js 15. If...

Kiran Patil | Jun 23, 2026 |