Introduction
Welcome to the SharePoint 2013 REST Series. In my previous articles, we saw how to get web info for a SharePoint web application using the REST API.
This article explains how to get the list of Features enabled for a web application.
The SharePoint 2013 environment adds the ability for you to remotely interact with SharePoint sites using REST. So you can talk to SharePoint objects using any technology that supports standard REST capabilities. In this way, SharePoint data can be accessed anywhere and everywhere.
List of REST Access Points
The following is a list of access points that provide you entry into granular access points.
            http://server/site/_api/site
            http://server/site/_api/web
            http:// server/site/_api/SP.UserProfiles.PeopleManager
            http:// server/site/_api/search
            http:// server/site/_api/publishing
 List of REST End Points 
The following is a list of endpoints that are the most commonly used in a SharePoint list.
- http://server/site/_api/web/lists
- http://server/site/_api/lists/getbytitle('listname')
- http://server/site/_api/web/lists(‘guid’)
- http://server/site/_api/web/lists/getbytitle(‘Title’)
 Note: The following code is tested in my SP 2013 online environment.
Step 1 : Before writing your code, please ensure you have sufficient permission to access cross-domain requests. So I have given full permission to all the contents listed below.
| Tenant Full | Full Permission | 
| Site Collection | Full Permission | 
| Web Full Permission | Full Permission | 
| List Full Permission | Full Permission | 
 
    ![/List of REST End Points.jpg]()
Step 2 : Navigate to the App.js file and copy the following code and paste it in.
Code
-   var hostweburl;     
-   var appweburl;     
-        
-         
-         
-       $(document).ready(function () {    
-               
-                
-      hostweburl =     
-          decodeURIComponent(     
-             getQueryStringParameter("SPHostUrl"));     
-      appweburl =     
-          decodeURIComponent(     
-              getQueryStringParameter("SPAppWebUrl"));     
-                   
-            
-          var scriptbase = hostweburl + "/_layouts/15/";      
-       
-            
-            
-              
-             
-              $.getScript(scriptbase + "SP.RequestExecutor.js", execCrossDomainRequest);    
-               });    
-                  
-                 
-              
-            function execCrossDomainRequest() {    
-                
-                
-              var executor = new SP.RequestExecutor(appweburl);                            
-   
-                
-                
-                  
-                
-                
-                
-    executor.executeAsync(  
-      {  
-          url:  
-   
-              appweburl +   
-                
-              "/_api/SP.AppContextSite(@target)/web/Features?@target='" +      
-              hostweburl + "'",    
-          method: "POST",  
-        
-   
-              headers: { "Accept": "application/json; odata=verbose" },                   
-              success: function (data) {    
-                  alert("success: " + JSON.stringify(data));    
-              error: function (err) {    
-                  alert("error: " + JSON.stringify(err));    
-              }      
-   
-                  }              
-   
-              );                                
-   
-            }                      
-   
-        
-        
-          
-    
-       
-    
-    
-    
-  function getQueryStringParameter(paramToRetrieve) {     
-      var params =     
-          document.URL.split("?")[1].split("&");       
-      for (var i = 0; i < params.length; i = i + 1) {     
-          var singleParam = params[i].split("=");     
-          if (singleParam[0] == paramToRetrieve)     
-              return singleParam[1];     
-      }     
-  }     
 Step 3: When deploying, you will be prompted with the following screen. Press Trust it and proceed with the deployment.
![List of REST End Points 3.jpg]() 
Output
 
| WebInfo property | Description | 
| Created | Gets a value that specifies when the site was created. | 
| Description | Gets or sets the description for the site. | 
| Id | Gets a value that specifies the site identifier. | 
| Language | Gets a value that specifies the locale ID (LCID) for the language that is used
 | 
| LastItemModifiedDate | Gets a value that specifies when an item was last modified in the site.
 | 
| Title | Gets or sets the title for the site. | 
| WebTemplateId | Gets the identifier of the site template. | 
Code Walkthrough
The SharePoint 2013 REST service supports sending POST commands that include object definitions to endpoints that represent collections. In this example, Test List is a custom SharePoint list where list items are updated.
IF-MATCH headerProvides a way to verify that the object being changed has not been changed since it was last retrieved. Or, lets you specify to overwrite any changes, as shown in the following example: "IF-MATCH":"*".
The cross-domain library lets you interact with more than one domain in your remote app page through a proxy. SP.RequestExecutor.js acts as a cross-domain library to fetch or create a SharePoint list from your APP domain.
- 1.  function execCrossDomainRequest() {    
- 2.    
- 3.    
- 4.  var executor = new SP.RequestExecutor(appweburl); var metatdata = "{ '__metadata': { 'type': 'SP.Data.TestListListItem' }, 'Title': 'changelistitemtitle'}";    
  
Summary
I hope this article helps you.