Skip to content
/ CMS Public
forked from BikramChhetri/CMS

This application is a simple contact CRUD sample.

Notifications You must be signed in to change notification settings

rsdelapaz/CMS

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 

Repository files navigation

CMS

This application is a basic CRUD application, which maintain the Contact CRUD operations. The application is made up of MVC and WEB API 2 under the same project. The main idea of creating the MVC and WEB API is that: MVC acted as a client and WEB API acted as a server in which MVC client make a call to the MVC Controller which calls the API controller and API handle the request accordingly. MVC Clinnt is a simple Scaffolding application, didn't have much changes. The main focus is to the WEB API side.

#Application Environments
Application Developed in:
Visual studio 2015.
.Net framework 4.6
MVC 5
Web API 2
SQL 2016

Prerequisites

To run the application

  1. Provide initialCatalog and baseApiPath in web.config application Setting.
  2. Provide your connectionString settings in web.config file.

Architecture style / Design pattern / Principles used in the application.

MVC 5 : Acted as a client.
Web API 2 : Acted as a server.
Unity 5 : IOC for Dependency injection.
LogWriter : custom class which log the exception in the .txt file date wise.Very basic(only the concept of exception handling is covered).
EntityFramework 6 : ORM.
Factory Method pattern: used to create a context according to the initialCatalog provid.
Unit test cases: Could not get time to write(I can write if time provided.).

functionalities covered.

PhoneNumber should be provide in a proper format(10 digit), otherwie error thrown and redirected to the error page.

This is to show the handled error, and error will log in the given path .txt file.

But the phoneNumber is kept non-mandatory, can create the contact without the phoneNumber.

  1. Get the list of Contacts(all contacts: no filter with inactive or acctive).
  2. Add contact.
  3. Edit contact.
  4. Delete(Activate/Deactivate) only soft deletethe contact.

Known issue.

The below explanation may help you to understand why the issue is persisting.

The issue is because of enabled of entity-framework code first migration enabled.So that for the first time the table Contacts in created by its own(initialize the database and entity), if some entity property changes make then the above issue persists. if the below issue occours: #The model backing the context has changed since the database was created. then please uncomment the code.

      //protected override void OnModelCreating(DbModelBuilder modelBuilder)
    //{
    //    Database.SetInitializer<ContactContext>(null);
    //    base.OnModelCreating(modelBuilder);
    //}<br/>

lies in the path: CMS/CMSApp/CMSApp/Models/DataAccessLayer/ContactContext.cs.

About

This application is a simple contact CRUD sample.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 49.4%
  • C# 48.8%
  • HTML 1.2%
  • Other 0.6%