Now, we will create our Application. I hope, you will like this.
 
 Background
 
 Normally, we call Google Geolocation API, either from the Server side or from Client side, right? Today, we use the Server side. It is fully dynamic. We will use two  tools, one is Postman and other one is Fiddler. Both are used to test Web API.  This Google Geolocation API depends on latitude and longitude. Both will  control our client. They will give the value.
 
 Creating Database
 
 The following query can be used to create a database in your SQL Server.
 
- CREATE DATABASE SalesTracking;  
 The following query can be used to create a table in your SQL Server. 
- CREATE TABLE [dbo].[crm_DailySalesTask](  
- [DailySalesTaskID] [bigint] NOT NULL,  
- [UserID] [bigint] NULL,  
- [BuyerName] [nvarchar](max) NULL,  
- [Description] [nvarchar](max) NULL,  
- [Achivement] [nvarchar](max) NULL,  
- [Latitude] [nvarchar](max) NULL,  
- [Longitude] [nvarchar](max) NULL,  
- [Address] [nvarchar](max) NULL,  
- [company_name] [nvarchar](max) NULL,  
- [CreateDate] [datetime] NULL,  
- CONSTRAINT [PK_crm_DailySalesTask] PRIMARY KEY CLUSTERED   
- (  
- [DailySalesTaskID] ASC  
- )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]  
- ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]  
- GO  
 
 Start Virtual Studio File>New>Project and click. New Project window will  be shown on your monitor. Select Web and select ASP.NET Web Application (.NET  Framework), give the name and click OK button. Again, a new Window will be shown  on your monitor. From the following pop up, select Web API and click OK  button once. 
![web Application]() Figure:
  Figure: Web API Template with add folders and core references for MVC and Web  API.
 A project as MVC folder structure with core references will be created for you. 
![structure]() Create Entity Data Model
  Create Entity Data Model
  Right click on your model folder and click new, select ADO.NET Entity Data  Model. Follow the steps given. Once you have done the process, you can see the  EDMX file and other files in your model folder. Here I gave  SalesTrackingEntities for our Entity data model name. Now you can see a file  with EDMX extension has been created.  
Create ResponseModel Class
 
 We will create ResponseModel class in Model folder. Actually, this class will  be used for the return type. The code is given below: 
- public class ResponseModel  
-   {  
-       public string Message { set; get; }  
-       public bool Status { set; get; }  
-       public object Data { set; get; }  
-   }  
 
 We will create a virtual class in Model folder and the query is given bellow: 
- public class vmTask  
-    {  
-        public Int64 UserID { get; set; }  
-        public string BuyerName { get; set; }  
-        public string Achivement { get; set; }  
-        public string Latitude { get; set; }  
-        public string Longitude { get; set; }  
-        public string Address { get; set; }          
-        public string Description { get; set; }  
-    }  
 
 Right click on Controllers folder, add >controller, select Web API 2  Controller-Empty and give the name of the controller. Click OK once. 
- public class TaskController : ApiController  
-     {  
-         SalesTrackingEntities _dbContext = null;  
-   
-           
-         public TaskController()  
-         {  
-             _dbContext = new SalesTrackingEntities();  
-         }  
-           
-         [HttpPost]  
-         public ResponseModel SaveTask(vmTask _vmTask)  
-         {  
-             ResponseModel _modelObj = new ResponseModel;  
-             int result = SaveTaskDetails(_vmTask);  
-             if (result == 1)  
-             {  
-                 _modelObj.Status = true;  
-                 _modelObj.Message = "Task Saved";  
-             }  
-             else  
-             {  
-                 _modelObj.Status = false;  
-                 _modelObj.Message = "Task Saved faill";  
-             }  
-             return _modelObj;  
-         }  
-   
-         [HttpGet]  
-           
-         public ResponseModel GetTaskList(Int64 userID)  
-         {  
-             ResponseModel _modelObj = new ResponseModel();  
-             List<vmTask> taskes = GetTaskDetails(userID);  
-             if (taskes.Count > 0)  
-             {  
-                 _modelObj.Data = taskes;  
-                 _modelObj.Status = true;  
-                 _modelObj.Message = "Data get successfully.";  
-             }  
-             else  
-             {  
-                 _modelObj.Data = taskes;  
-                 _modelObj.Status = false;  
-                 _modelObj.Message = "Data not found.";  
-             }  
-             return _modelObj;  
-         }  
-         private List<vmTask> GetTaskDetails(long userID)  
-         {  
-             List<vmTask> taskes = null;  
-             try  
-             {  
-                 taskes = (from ds in _dbContext.crm_DailySalesTask  
-                           where ds.UserID == userID  
-                           select new vmTask  
-                           {  
-                               UserID = ds.UserID ?? 0,  
-                               BuyerName = ds.BuyerName,  
-                               Achivement = ds.Achivement,  
-                               Description = ds.Description,  
-                               Address = ds.Address  
-                           }).ToList();  
-                 return taskes;  
-             }  
-             catch  
-             {  
-                 taskes = null;  
-   
-             }  
-             return taskes;  
-         }  
-         private int SaveTaskDetails(vmTask _vmTask)  
-         {  
-             crm_DailySalesTask _objSalesTask = new crm_DailySalesTask();  
-             int result = 0;  
-             string Address = "";  
-             try  
-             {   
-                  Int64 nextRow = _dbContext.crm_DailySalesTask.Count() + 1;  
-                 _objSalesTask.DailySalesTaskID = nextRow;               
-                 _objSalesTask.UserID = _vmTask.UserID;  
-                 _objSalesTask.BuyerName = _vmTask.BuyerName;  
-                 _objSalesTask.Description = _vmTask.Description;  
-                 _objSalesTask.Achivement = _vmTask.Achivement;  
-                 _objSalesTask.Latitude = _vmTask.Latitude;  
-                 _objSalesTask.Longitude = _vmTask.Longitude;  
-                 Address = GetAddress(_objSalesTask.Latitude, _objSalesTask.Longitude);  
-                 _objSalesTask.Address = Address;  
-                 _dbContext.crm_DailySalesTask.Add(_objSalesTask);  
-                 _dbContext.SaveChanges();  
-                 result = 1;  
-             }  
-             catch  
-             {  
-                 result = 0;  
-   
-             }  
-             return result;  
-         }  
-           
-         private string GetAddress(string latitude, string longitude)  
-         {  
-             string locationName = "";  
-             string url = string.Format("http://maps.googleapis.com/maps/api/geocode/xml?latlng={0},{1}&sensor=false", latitude, longitude);  
-             XElement xml = XElement.Load(url);  
-             if (xml.Element("status").Value == "OK")  
-             {  
-                 locationName = string.Format("{0}",  
-                     xml.Element("result").Element("formatted_address").Value);  
-             }  
-             return locationName;  
-         }  
-     }  
 We are going to demonstrate our TaskController. First of all I want to say  that in this project, I do not use any repository pattern or any multi layer. I  have done all the coding in TaskController. 
- SalesTrackingEntities _dbContext = null; 
 We have just pointed _dbContext instance. 
-   
-        public TaskController()  
-        {  
-            _dbContext = new SalesTrackingEntities();  
-        }  
 We have created instance of SalesTarackingEntities in TaskController constructor  because it will access all the tables and use linq. 
-   
-        [HttpPost]  
-        public ResponseModel SaveTask(vmTask _vmTask)  
-        {  
-            ResponseModel _modelObj = new ResponseModel();  
-            int result = SaveTaskDetails(_vmTask);  
-            if (result == 1)  
-            {  
-                _modelObj.Status = true;  
-                _modelObj.Message = "Task Saved";  
-            }  
-            else  
-            {  
-                _modelObj.Status = false;  
-                _modelObj.Message = "Task Saved faill";  
-            }  
-            return _modelObj;  
-        }  
 We use HttpPost for SaveTask method. We get vmTask object as a parameter from out world. When we will test this method, using Fiddler of Postman,  we will see,  how to pass vmTask object. We call SaveTaskDetails method for  saving. This method exists in TaskController. 
- private int SaveTaskDetails(vmTask _vmTask)  
-     {  
-         crm_DailySalesTask _objSalesTask = new crm_DailySalesTask();  
-         int result = 0;  
-         string Address = "";  
-         try  
-         {  
-             Int64 nextRow = _dbContext.crm_DailySalesTask.Count() + 1;  
-            _objSalesTask.DailySalesTaskID = nextRow;  
-             _objSalesTask.UserID = _vmTask.UserID;  
-             _objSalesTask.BuyerName = _vmTask.BuyerName;  
-             _objSalesTask.Description = _vmTask.Description;  
-             _objSalesTask.Achivement = _vmTask.Achivement;  
-             _objSalesTask.Latitude = _vmTask.Latitude;  
-             _objSalesTask.Longitude = _vmTask.Longitude;  
-             Address = GetAddress(_objSalesTask.Latitude, _objSalesTask.Longitude);  
-             _objSalesTask.Address = Address;  
-             _dbContext.crm_DailySalesTask.Add(_objSalesTask);  
-             _dbContext.SaveChanges();  
-             result = 1;  
-         }  
-         catch  
-         {  
-             result = 0;  
-   
-         }  
-         return result;  
-     }  
 We can see the method, shown above, we just save in the database, using linq and we have called  GetAddress Method with two parameters. The code is given below: 
- private string GetAddress(string latitude, string longitude)  
-         {  
-             string locationName = "";  
-             string url = string.Format("http://maps.googleapis.com/maps/api/geocode/xml?latlng={0},{1}&sensor=false", latitude, longitude);  
-             XElement xml = XElement.Load(url);  
-             if (xml.Element("status").Value == "OK")  
-             {  
-                 locationName = string.Format("{0}",  
-                     xml.Element("result").Element("formatted_address").Value);  
-             }  
-             return locationName;  
-         }  
 In this method, we use Google API with the two parameters- latitude and longitude to get the address. We have used XElement class and Loaded static mehtod for geting API's  response. After getting the location name, we have returned the location name. 
 Get task list by userID: 
- private List<vmTask> GetTaskDetails(long userID)  
-         {  
-             List<vmTask> taskes = null;  
-             try  
-             {  
-                 taskes = (from ds in _dbContext.crm_DailySalesTask  
-                           where ds.UserID == userID  
-                           select new vmTask  
-                           {  
-                               UserID = ds.UserID ?? 0,  
-                               BuyerName = ds.BuyerName,  
-                               Achivement = ds.Achivement,  
-                               Description = ds.Description,  
-                               Address = ds.Address  
-                           }).ToList();  
-                 return taskes;  
-             }  
-             catch  
-             {  
-                 taskes = null;  
-   
-             }  
-             return taskes;  
-         }  
 Our code is ready. Thus, we will check. 
 Check by Postman  For HttpPost: 
![HttpPost]() 
  Wow, its work is done. Let's go for HttpGet.
![HttpGet]() 
  It will always work now.
 Check by Fiddler
 For HttpPost: 
![HttpPost]() 
  Output result is given below:
![Output]() 
  Wow its work is done. Let's go for HttpGet.
![HttpGet]()