Skip to main content

WCF Syndication RSS/Atom

1 Create a RESTful WCF Service 

  • Open Visual Studio
  • Select File New Project
  • Select WCF Service Library template under Visual C# > WCF templates
  • Change the name to ProductServiceLibrary and click OK
  • Visual studio will add reference to System.ServiceModel, System.Runtime.Serialization and will add some files with sample code. 
  • Delete IService1.cs and Service1.cs
  • Add reference to System.ServiceModel.Web
  • Add a new class called ProductService

1.1 Create the Data Contract 

  • Open ProductService.cs file that you created.
  • Add using System.Runtime.Serialization;
  • Add using System.ServiceModel;
  • Add using System.ServiceModel.Web;
  • Add using using System.ServiceModel.Syndication;
  • Add the following code in the ProductService.cs class
    [DataContract]
    public class ProductReview 
    {
        [DataMember]
        public string Id { get; set; }
        [DataMember]
        public string ProductCode { get; set; }
        [DataMember]
        public string ProductName { get; set; }
        [DataMember]
        public string Review {get; set; }
    }

1.2 Create the Service Contract 

  • Add the following code in the ProductService.cs class
   [ServiceContract] 
    public interface IProductService
    {
        [WebInvoke(Method="POST", UriTemplate="productreview")]
        [OperationContract]
        void SubmitReview (ProductReview pr);

        [ServiceKnownType(typeof(Rss20FeedFormatter))]
        [ServiceKnownType(typeof(Atom10FeedFormatter))]
        [WebGet(UriTemplate = "productreviews/feed/{type}")]
        [OperationContract]
        SyndicationFeedFormatter GetFeed(string type);
    }

1.3 Service Implementation

  • Add the following code in the ProductService.cs class
 [ServiceBehavior(InstanceContextMode=InstanceContextMode.Single)]
    public class ProductService : IProductService
    {
        List<ProductReview> Reviews = new List<ProductReview>();

        void IProductService.SubmitReview(ProductReview pr)
        {
            Reviews.Add(pr);
        }

        public SyndicationFeedFormatter GetFeed(string type)
        {
            SyndicationFeed feed = new SyndicationFeed()
            {
                Title = new TextSyndicationContent("Product reviews"),
                Description = new TextSyndicationContent("Product reviews submitted by buyers"),
                Items =
                    from review in Reviews
                    select new SyndicationItem()
                    {
                        Title = new TextSyndicationContent(review.ProductName),
                        Content = new TextSyndicationContent(review.Review)
                    }
            };

            if (type.Equals("rss"))
            {
                return new Rss20FeedFormatter(feed);
            }
            else
            {
                return new Atom10FeedFormatter(feed);
            }
        }
    }

1.4 Update App.config 

  • Updated the name of the service in App.config as given below:
     <service name="ProductServiceLibrary.ProductService">

1.5 Test Service 

  • Run the Service. 

2 Create a RESTful WCF Service Host

  1. Add a new project to the current solution: Right click Solution on Solution Explorer > Add > Add New Project
  2. Select Console Application template under Visual C# > Windows templates
  3. Change the project name to ConsoleHost and click OK
  4. In Solution Explorer, under ConsoleHost project, right click References and select Add Reference... 
  5. In the Reference Manager window, add reference to System.ServiceModelSystem.ServiceModel.Weband ProductServiceLibrary solution
  6. Add using System.ServiceModel;
  7. Add using System.ServiceModel.Web;
  8. Add using ProductServiceLibrary;
  9. Add the following code in Program.cs file
class Program
    {
        static void Main(string[] args)
        {
            WebServiceHost host = new WebServiceHost(typeof(ProductService));

            try
            {
                host.Open();
                Console.ReadKey();
                host.Close();
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
                host.Abort();
                
            }
            Console.ReadKey();
        }
    }

2.1 Configure Service

  1. Open App.config and add the following code
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
     <system.serviceModel>
        <services>
            <service name="ProductServiceLibrary.ProductService">
                <host>
                    <baseAddresses>
                        <add baseAddress="http://localhost:8733/Design_Time_Addresses/ProductServiceLibrary/ProductService" />
                    </baseAddresses>
                </host>
            </service>
        </services>
    </system.serviceModel>
</configuration>

2.2 Test the application 

  1. Right click on the ConsoleHost project and Set as StartUp project.
  2. Run Service Host


    3 Create a RESTful WCF Service Client

    1. Add a new project to the current solution: Right click Solution on Solution Explorer > Add > Add New Project
    2. Select Console Application template under Visual C# > Windows templates
    3. Change the project name to ConsoleClient and click OK
    4. In Solution Explorer, under ConsoleClient project, right click References and select Add Reference... 
    5. Add reference to ProductServiceLibrary, System.ServiceModel and System.ServiceModel.Web
    6. In the Program.cs file, 
      • add using System.ServiceModel; 
      • add using System.ServiceModel.Web;
      • add using System.ServiceModel.Web;
      • add using ProductServiceLibrary; 
    7. Add the following code
      class Program
      {
            static void Main(string[] args)
            {
                
                WebChannelFactory<IProductService> factory = new WebChannelFactory<IProductService>(
                    new Uri("http://localhost:8733/Design_Time_Addresses/ProductServiceLibrary/ProductService"));
                
    IProductService client = factory.CreateChannel();

                Console.WriteLine("Press 1 to Add | 2 to List All | 3 to List by Product | 0 to Exit");
                Console.Write("Select an option : ");
                string opt = Console.ReadLine();

                while (!opt.Equals("0"))
                {
                    switch (opt)
                    {
                        case "1":
                            Console.Write("Id:");
                            string id = Console.ReadLine();
                            Console.Write("Product Code:");
                            string code = Console.ReadLine();
                            Console.Write("Product Name:");
                            string name = Console.ReadLine();
                            Console.Write("Your Review:");
                            string review = Console.ReadLine();

                            ProductReview pr = new ProductReview();
                            pr.Id = id;
                            pr.ProductCode = code;
                            pr.ProductName = name;
                            pr.Review = review;

                            client.SubmitReview(pr);

                            Console.WriteLine("Thank you for your product review.");
                            break;
                       
                        default:
                            Console.WriteLine("Invalid option");
                            break;
                    }
                    Console.WriteLine();
                    Console.WriteLine("Press 1 to Add | 2 to List All | 3 to List by Product | 0 to Exit");
                    Console.Write("Select an option : ");
                    opt = Console.ReadLine();
                }
            }
        }

    3.1 Enabling Multiple StartUp projects 

    1. In solution explorer, right click on the solution and select Properties
    2. Select Multiple Startup Projects option in Common Properties > Startup Project
    3. For ConsoleHost project change the action to Start and for ConsoleClient project change the action to Start.
    4. Reorder ConsoleHost so that it is above ConsoleClient, therefore starts before ConsoleClient. 

    3.2 View using Internet Explorer 

    1. Open Internet explorer
    2. go to http://localhost:8733/Design_Time_Addresses/ProductServiceLibrary/ProductService/productreviews/feed/rss
    3. you should be able to see the feed. 


    References

    Popular posts from this blog

    CUMIPMT and CUMPRINC function

    CUMIPMT Cumulative interest payment function allows you to calculate the interest paid for a loan or from an investment from period A to period B. When getting a loan, CUMIPMT function can be used to calculate the total amount of interest paid in the first five months or from period 12 to period 20. A period can be a month, a week or two week. Loan Amount : 350,000.00 APR: 4.5% Down payment: 0.00 Years: 25 Payment per year: 12 From the above data, we can calculate the following: No of Period: 25 × 12 = 300 Periodic Rate: 4.5/12 = 0.375% Here is how you will substitute these values into the function. = CUMIPMT (periodic rate, No of period, vehicle price, start period, end period,  ) = CUMIPMT (0.375, 300, 350000, 1, 5, 0) In an excel worksheet, we use cell address instead of actual values as shown below: Here is the formula view of the worksheet: CUMPRINC Another related function is CUMPRINC. CUMPRINC function is used to calculate cumul

    Excel PMT Function

    PMT function is very useful for calculating monthly payment required to payback a loan or mortgage at a fixed rate. This function require a minimum of three inputs, periodic rate, number of periods, present value or the loan amount. Here is a simple example. Home Loan: 350,000.00 Interest rate: 4.5% Number of years to repay the loan: 25 Note: To calculate monthly payment, we need to find the monthly rate and number of months as shown above. Then it is simply a matter of substituting the values into the payment function, as shown in the formula view below.

    BCG's Brand Advocacy Index

    The Boston Consulting Group's (BCG) Brand Advocacy Index (BAI) is a metric developed to help companies measure the degree of customer advocacy for their brands. BAI focuses on the likelihood of customers to recommend a brand to others, which is a powerful indicator of brand strength and customer loyalty. Unlike other customer satisfaction or loyalty metrics, BAI emphasizes the importance of customer referrals and word-of-mouth marketing. BAI is calculated based on a survey where customers are asked about their willingness to recommend a brand to their friends, family, or colleagues. The responses are then used to compute a score, which ranges from -100 to 100. A higher BAI score indicates that a brand has more advocates who are likely to recommend the brand to others, while a lower score suggests that the brand has fewer advocates or even a higher number of detractors. BCG's research has shown that companies with higher BAI scores tend to experience higher growth rates and bett