mguinness / MetaWeblog

An ASP.NET Core Middleware Component for Implementing MetaWeblog API

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

#WilderMinds.MetaWeblog

Build Status: Build status

To install, use the Nuget "WilderMinds.MetaWeblog":

  PM> Install-Package WilderMinds.MetaWeblog

This project is an ASP.NET Core 2.0 Middleware component to support the MetaWeblog API that WordPress and Windows LiveWriter uses to support adding and editing of content in blogs.

To support MetaWeblog, you must first create a class that implements the IMetaWeblogProvider interface:

  public class TestMetaWeblogService : IMetaWeblogProvider
  {
    public UserInfo GetUserInfo(string key, string username, string password)
    {
      throw new NotImplementedException();
    }

    public BlogInfo[] GetUsersBlogs(string key, string username, string password)
    {
      throw new NotImplementedException();
    }

    public Post GetPost(string postid, string username, string password)
    {
      throw new NotImplementedException();
    }

    public Post[] GetRecentPosts(string blogid, string username, string password, int numberOfPosts)
    {
      throw new NotImplementedException();
    }

    public string AddPost(string blogid, string username, string password, Post post, bool publish)
    {
      throw new NotImplementedException();
    }

    public bool DeletePost(string key, string postid, string username, string password, bool publish)
    {
      throw new NotImplementedException();
    }

    public bool EditPost(string postid, string username, string password, Post post, bool publish)
    {
      throw new NotImplementedException();
    }

    public CategoryInfo[] GetCategories(string blogid, string username, string password)
    {
      throw new NotImplementedException();
    }

    public MediaObjectInfo NewMediaObject(string blogid, string username, string password, MediaObject mediaObject)
    {
      throw new NotImplementedException();
    }

    public int AddCategory(string key, string username, string password, NewCategory category)
    {
      throw new NotImplementedException();
    }

    public Page GetPage(string blogid, string pageid, string username, string password)
    {
      throw new NotImplementedException();
    }

    public Page[] GetPages(string blogid, string username, string password, int numPages)
    {
      throw new NotImplementedException();
    }

    public Author[] GetAuthors(string blogid, string username, string password)
    {
      throw new NotImplementedException();
    }

    public string AddPage(string blogid, string username, string password, Page page, bool publish)
    {
      throw new NotImplementedException();
    }

    public bool EditPage(string blogid, string pageid, string username, string password, Page page, bool publish)
    {
      throw new NotImplementedException();
    }

    public bool DeletePage(string blogid, string username, string password, string pageid)
    {
      throw new NotImplementedException();
    }
  }

Once you've implemented the class, you can register the middleware by first adding MetaWeblog in ConfigureServices supplying the name of the implemented service class:

    public void ConfigureServices(IServiceCollection svcs)
    {
      //...

      // Supporting Live Writer (MetaWeblogAPI)
      svcs.AddMetaWeblog<TestMetaWeblogService>();

      //...
    }

Finally, you have to add MetaWeblog in the Configure call to specify the endpoint to listen on when waiting for the MetaWeblog calls:

    public void Configure(IApplicationBuilder app,
                          ILoggerFactory loggerFactory,
                          WilderInitializer initializer)
    {
      //...

      // Support MetaWeblog API
      app.UseMetaWeblog("/livewriter");

      //...
    }

This simply handles the routing to your methods. It does not implement the service at all.

About

An ASP.NET Core Middleware Component for Implementing MetaWeblog API

License:Apache License 2.0


Languages

Language:C# 100.0%