Monday, 8 September 2014

SharePoint Repository Pattern Step By Step

This Post has been in my agenda for sometime but finally i got the time to write it:

I have done a lot of work with SharePoint API in my career path , and each time i see this code i become upset and feel angry even i  wrote this code many times :


             using (SPSite  site = new SPSite(path))
                {
                    using (SPWeb  web =  site.OpenWeb())
                    {
                          //Do work
                    }
              }


Problem:

Project  Solution (SPRepository)  will  consist of  three Projects:
  1. SPRepository.Core (class library): contains the Repository 
  2. SPRepository.Domin (class library) : Reference the (1) contains all entities 
  3. SPRepository.Portal (SharePoint Project). Reference  (1 and 2) and contains web parts(UI)




SPRepository.Core (class library): 


The class diagram for (SPRepository.Core) as below image (Figure1) 
Two weeks ago (today 3/10/2013) my manger asked me to make some changes on online Portal.
I got shocked on seeing hundreds of repeated codes.

I went to Google and start searching (sharepoint document repository).
But i didn’t find what i wants so i start reading and assembly parts to come up with complete solution that might help me and help others,
Of course i got some idea from other blogs.
Let's start talking about the Solution:


 Figure 1



Description of Class Diagram
class EntityBase
Is the base class of each entity  also please note that the entity represent SPList and contains the common Fields in SPList (ID , Title , Modified , Created, ModifiedBy , CreatedBy)


interface IMapper<TEntity>
Is the mapper that converts an entity of type (EntityBase) to and from SPListItem.
Its convert and SPListItem to EntityBase and vice versa


interface IRepository<TEntity>
contains all method that we need to work with SPList like Query , getting item and update item(SPListItem)


class Repository<TEntity> is the real implementation for IRepository<TEntity>

Let’s start by real example:

We have Department SPList with Fields
  1.    ID
  2.          Title
  3.           DeptCode

Also We have SPList called Employee with fields:
  1.                ID
  2.              Title
  3.               FirstName
  4.    LastName
  5.              Department (Lookup filed)





We will start by building Entity objects in the Project (SPRepository.Domin)
Add new class called Department inherited from Class EntityBase
and add Properties: (DeptCode , don't add other Properties because it's already in the base class EntityBase).



Add new class called Employee inherited from Class EntityBase
and add Properties:























 Okay don't upset it's very easy , we will start n example showing  step by step to how we can use the repository.




To be continue...

if you interested drop a comment











2 comments:

  1. Next steps? or a link to source code please.

    ReplyDelete
    Replies
    1. Sorry there is no code or blog , you can search for repository pattern in .net

      Delete