|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Web;
|
|
|
|
|
using System.Web.Security;
|
|
|
|
|
using System.Web.Http;
|
|
|
|
|
using Npgsql.Web.Blog;
|
|
|
|
|
using Yavsc.Model.Blogs;
|
* bg.gif:
* asc.gif:
* desc.gif:
* style.css: moved to App_Themes
* style.css:
* bg.gif:
* asc.gif:
* bg.png:
* rect.png:
* asc.png:
* desc.gif:
* jquery-ui.css:
* mdd_styles.css:
* croix.png:
* desc.png:
* style.css:
* jquery-ui.min.css:
* mdd_gripper.png:
* mdd_toolbar.png:
* jquery.timepicker.css:
* mdd_ajax_loader.gif:
* mdd_modal_background.png: moved to /App_Themes
* NpgsqlBlogProvider.cs: * Remove post by id
* Manage collections of entries on a couple (user,title), not a single
post
* NpgsqlCircleProvider.cs: Fixes the "Match" method.
* IDbModule.cs:
* Edit.aspx:
* Estimates.aspx:
* WorkFlowManager.cs:
* NpgsqlContentProvider.cs: refactoring
* NpgsqlMRPProviders.csproj: new NpgsqlUserName provider
* NpgsqlRoleProvider.cs: simpler init method
* NpgsqlUserNameProvider.cs: impements a UserNameProvider
* MyClass.cs: refactoring from Yavsc.Model
* BlogsController.cs: access control simplified
* FrontOfficeController.cs: Pdf generation made public ni case of
formatting exception
* mdd_styles.css: Theme -> App_Themes
* style.css: yet another style impact
* AccountController.cs: Fixes the user name modification
* BlogsController.cs: * Fixes the removal process
* On a title and user name, we get collection of posts, not only one.
* Implements an Access on circle
* FrontOfficeController.cs: * implements a new Get method.
* ensure a membership existence before delivering an estimate.
* GoogleController.cs: Fixes the user name modification on a Google
account
* ErrorHtmlFormatter.cs: nice error message in html (using Markdown
helper)
* FormatterException.cs: formatter exception exposes error and
standard output of the process
* TexToPdfFormatter.cs: * generates temporary files in the folder
returned by Path.GetTempPath()
* throws FormatterException
* Global.asax.cs: new route map:
Blogs/{action}/{user}/{title}
Blog/{user}/{title}
B/{id}
{controller}/{action}/{id}
* App.master: * refactoring: Theme moved to App_Themes
* a link to the logged user's blog
*
* NoLogin.master: refactoring: Theme moved to App_Themes
* Circles.aspx: refactoring : circles now are given as select items
* Login.aspx: fixes the html presentation
* Register.aspx: Fixes a Typo
* Index.aspx: Implements a blog index, due to M&C changes with this
commit
* RemovePost.aspx: links to the new route to the "RemovePost" action,
giving it a post id
* RemoveTitle.aspx: fixes a not yet linked page to remove a post
collection under a given title
* EventPub.aspx: code refactoring
* Writting.ascx: cleans the code
* Web.config: fills the config with new names in the space
* Web.config: configures the new NpgsqlUserNameProvider
* Web.csproj: refactoring and others
* BlogEntryCollection.cs: implement the BlogEntryCollection
* BlogManager.cs: the manager helps to filter on access
* BlogProvider.cs: The title is not unique anymore, and one can modify
it, post a lot under it, drop all posts under it.
A Post is deleted by id.
* UUBlogEntryCollection.cs: implements a collection of post under a
given user name.
* UUTBlogEntryCollection.cs: implements a collection of post under a
given couple (user name, title).
* ListItem.cs: ListItem is declared obsolete in this model, helpers
can build MVC SelectListItem on data returned by the manager.
* LocalizedText.Designer.cs:
* LocalizedText.fr.Designer.cs: autogenerated from xml
* LocalizedText.resx:
* LocalizedText.fr.resx: new labels
* ChangeUserNameProvider.cs: xml doc
* Profile.cs: the UserName property is read only, and comes from
authentication, to change it, we set a Name and validate it agains
the "Profile" method
* UserManager.cs: simpler code a init time
* IContentProvider.cs: implements the new IDataProvider interface
* IDataProvider.cs: defines the new IDataProvider interface
* YavscModel.csproj: includes new classes
* UserPosts.aspx: adds a link to remove a post
* UserPost.aspx: now uses the new BlogEntryCollection object
9 years ago
|
|
|
|
using System.IO;
|
|
|
|
|
using System.Net;
|
|
|
|
|
using System.Net.Http;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using System.Diagnostics;
|
|
|
|
|
using Yavsc.Formatters;
|
|
|
|
|
using Yavsc.Model;
|
|
|
|
|
|
|
|
|
|
namespace Yavsc.ApiControllers
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Blogs API controller.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public class BlogsController : YavscApiController
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Tag the specified model.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="model">Model.</param>
|
|
|
|
|
[Authorize,
|
|
|
|
|
AcceptVerbs ("POST")]
|
|
|
|
|
public void Tag (PostTag model) {
|
|
|
|
|
if (ModelState.IsValid) {
|
|
|
|
|
BlogManager.GetForEditing (model.PostId);
|
|
|
|
|
BlogManager.Tag (model.PostId, model.Tag);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
static string [] officalTags = new string[] { "Artistes", "Accueil", "Événements", "Mentions légales", "Admin", "Web" } ;
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Tags the specified pattern.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="pattern">Pattern.</param>
|
|
|
|
|
[ValidateAjaxAttribute]
|
|
|
|
|
public IEnumerable<string> Tags(string pattern)
|
|
|
|
|
{
|
|
|
|
|
return officalTags;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Untag the specified model.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="model">Model.</param>
|
|
|
|
|
[Authorize,
|
|
|
|
|
AcceptVerbs ("POST")]
|
|
|
|
|
public void Untag (PostTag model) {
|
|
|
|
|
if (ModelState.IsValid) {
|
|
|
|
|
BlogManager.GetForEditing (model.PostId);
|
|
|
|
|
BlogManager.Untag (model.PostId, model.Tag);
|
|
|
|
|
}
|
|
|
|
|
}
|
* bg.gif:
* asc.gif:
* desc.gif:
* style.css: moved to App_Themes
* style.css:
* bg.gif:
* asc.gif:
* bg.png:
* rect.png:
* asc.png:
* desc.gif:
* jquery-ui.css:
* mdd_styles.css:
* croix.png:
* desc.png:
* style.css:
* jquery-ui.min.css:
* mdd_gripper.png:
* mdd_toolbar.png:
* jquery.timepicker.css:
* mdd_ajax_loader.gif:
* mdd_modal_background.png: moved to /App_Themes
* NpgsqlBlogProvider.cs: * Remove post by id
* Manage collections of entries on a couple (user,title), not a single
post
* NpgsqlCircleProvider.cs: Fixes the "Match" method.
* IDbModule.cs:
* Edit.aspx:
* Estimates.aspx:
* WorkFlowManager.cs:
* NpgsqlContentProvider.cs: refactoring
* NpgsqlMRPProviders.csproj: new NpgsqlUserName provider
* NpgsqlRoleProvider.cs: simpler init method
* NpgsqlUserNameProvider.cs: impements a UserNameProvider
* MyClass.cs: refactoring from Yavsc.Model
* BlogsController.cs: access control simplified
* FrontOfficeController.cs: Pdf generation made public ni case of
formatting exception
* mdd_styles.css: Theme -> App_Themes
* style.css: yet another style impact
* AccountController.cs: Fixes the user name modification
* BlogsController.cs: * Fixes the removal process
* On a title and user name, we get collection of posts, not only one.
* Implements an Access on circle
* FrontOfficeController.cs: * implements a new Get method.
* ensure a membership existence before delivering an estimate.
* GoogleController.cs: Fixes the user name modification on a Google
account
* ErrorHtmlFormatter.cs: nice error message in html (using Markdown
helper)
* FormatterException.cs: formatter exception exposes error and
standard output of the process
* TexToPdfFormatter.cs: * generates temporary files in the folder
returned by Path.GetTempPath()
* throws FormatterException
* Global.asax.cs: new route map:
Blogs/{action}/{user}/{title}
Blog/{user}/{title}
B/{id}
{controller}/{action}/{id}
* App.master: * refactoring: Theme moved to App_Themes
* a link to the logged user's blog
*
* NoLogin.master: refactoring: Theme moved to App_Themes
* Circles.aspx: refactoring : circles now are given as select items
* Login.aspx: fixes the html presentation
* Register.aspx: Fixes a Typo
* Index.aspx: Implements a blog index, due to M&C changes with this
commit
* RemovePost.aspx: links to the new route to the "RemovePost" action,
giving it a post id
* RemoveTitle.aspx: fixes a not yet linked page to remove a post
collection under a given title
* EventPub.aspx: code refactoring
* Writting.ascx: cleans the code
* Web.config: fills the config with new names in the space
* Web.config: configures the new NpgsqlUserNameProvider
* Web.csproj: refactoring and others
* BlogEntryCollection.cs: implement the BlogEntryCollection
* BlogManager.cs: the manager helps to filter on access
* BlogProvider.cs: The title is not unique anymore, and one can modify
it, post a lot under it, drop all posts under it.
A Post is deleted by id.
* UUBlogEntryCollection.cs: implements a collection of post under a
given user name.
* UUTBlogEntryCollection.cs: implements a collection of post under a
given couple (user name, title).
* ListItem.cs: ListItem is declared obsolete in this model, helpers
can build MVC SelectListItem on data returned by the manager.
* LocalizedText.Designer.cs:
* LocalizedText.fr.Designer.cs: autogenerated from xml
* LocalizedText.resx:
* LocalizedText.fr.resx: new labels
* ChangeUserNameProvider.cs: xml doc
* Profile.cs: the UserName property is read only, and comes from
authentication, to change it, we set a Name and validate it agains
the "Profile" method
* UserManager.cs: simpler code a init time
* IContentProvider.cs: implements the new IDataProvider interface
* IDataProvider.cs: defines the new IDataProvider interface
* YavscModel.csproj: includes new classes
* UserPosts.aspx: adds a link to remove a post
* UserPost.aspx: now uses the new BlogEntryCollection object
9 years ago
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Removes the post.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="user">User.</param>
|
|
|
|
|
/// <param name="title">Title.</param>
|
|
|
|
|
[Authorize, ValidateAjaxAttribute, HttpPost]
|
|
|
|
|
public void RemoveTitle(string user, string title) {
|
|
|
|
|
if (Membership.GetUser ().UserName != user)
|
|
|
|
|
if (!Roles.IsUserInRole("Admin"))
|
|
|
|
|
throw new AuthorizationDenied (user);
|
* bg.gif:
* asc.gif:
* desc.gif:
* style.css: moved to App_Themes
* style.css:
* bg.gif:
* asc.gif:
* bg.png:
* rect.png:
* asc.png:
* desc.gif:
* jquery-ui.css:
* mdd_styles.css:
* croix.png:
* desc.png:
* style.css:
* jquery-ui.min.css:
* mdd_gripper.png:
* mdd_toolbar.png:
* jquery.timepicker.css:
* mdd_ajax_loader.gif:
* mdd_modal_background.png: moved to /App_Themes
* NpgsqlBlogProvider.cs: * Remove post by id
* Manage collections of entries on a couple (user,title), not a single
post
* NpgsqlCircleProvider.cs: Fixes the "Match" method.
* IDbModule.cs:
* Edit.aspx:
* Estimates.aspx:
* WorkFlowManager.cs:
* NpgsqlContentProvider.cs: refactoring
* NpgsqlMRPProviders.csproj: new NpgsqlUserName provider
* NpgsqlRoleProvider.cs: simpler init method
* NpgsqlUserNameProvider.cs: impements a UserNameProvider
* MyClass.cs: refactoring from Yavsc.Model
* BlogsController.cs: access control simplified
* FrontOfficeController.cs: Pdf generation made public ni case of
formatting exception
* mdd_styles.css: Theme -> App_Themes
* style.css: yet another style impact
* AccountController.cs: Fixes the user name modification
* BlogsController.cs: * Fixes the removal process
* On a title and user name, we get collection of posts, not only one.
* Implements an Access on circle
* FrontOfficeController.cs: * implements a new Get method.
* ensure a membership existence before delivering an estimate.
* GoogleController.cs: Fixes the user name modification on a Google
account
* ErrorHtmlFormatter.cs: nice error message in html (using Markdown
helper)
* FormatterException.cs: formatter exception exposes error and
standard output of the process
* TexToPdfFormatter.cs: * generates temporary files in the folder
returned by Path.GetTempPath()
* throws FormatterException
* Global.asax.cs: new route map:
Blogs/{action}/{user}/{title}
Blog/{user}/{title}
B/{id}
{controller}/{action}/{id}
* App.master: * refactoring: Theme moved to App_Themes
* a link to the logged user's blog
*
* NoLogin.master: refactoring: Theme moved to App_Themes
* Circles.aspx: refactoring : circles now are given as select items
* Login.aspx: fixes the html presentation
* Register.aspx: Fixes a Typo
* Index.aspx: Implements a blog index, due to M&C changes with this
commit
* RemovePost.aspx: links to the new route to the "RemovePost" action,
giving it a post id
* RemoveTitle.aspx: fixes a not yet linked page to remove a post
collection under a given title
* EventPub.aspx: code refactoring
* Writting.ascx: cleans the code
* Web.config: fills the config with new names in the space
* Web.config: configures the new NpgsqlUserNameProvider
* Web.csproj: refactoring and others
* BlogEntryCollection.cs: implement the BlogEntryCollection
* BlogManager.cs: the manager helps to filter on access
* BlogProvider.cs: The title is not unique anymore, and one can modify
it, post a lot under it, drop all posts under it.
A Post is deleted by id.
* UUBlogEntryCollection.cs: implements a collection of post under a
given user name.
* UUTBlogEntryCollection.cs: implements a collection of post under a
given couple (user name, title).
* ListItem.cs: ListItem is declared obsolete in this model, helpers
can build MVC SelectListItem on data returned by the manager.
* LocalizedText.Designer.cs:
* LocalizedText.fr.Designer.cs: autogenerated from xml
* LocalizedText.resx:
* LocalizedText.fr.resx: new labels
* ChangeUserNameProvider.cs: xml doc
* Profile.cs: the UserName property is read only, and comes from
authentication, to change it, we set a Name and validate it agains
the "Profile" method
* UserManager.cs: simpler code a init time
* IContentProvider.cs: implements the new IDataProvider interface
* IDataProvider.cs: defines the new IDataProvider interface
* YavscModel.csproj: includes new classes
* UserPosts.aspx: adds a link to remove a post
* UserPost.aspx: now uses the new BlogEntryCollection object
9 years ago
|
|
|
|
BlogManager.RemoveTitle (user, title);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Removes the tag.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="tagid">Tagid.</param>
|
|
|
|
|
[Authorize, ValidateAjaxAttribute, HttpPost]
|
|
|
|
|
public void RemoveTag([FromBody] long tagid) {
|
* bg.gif:
* asc.gif:
* desc.gif:
* style.css: moved to App_Themes
* style.css:
* bg.gif:
* asc.gif:
* bg.png:
* rect.png:
* asc.png:
* desc.gif:
* jquery-ui.css:
* mdd_styles.css:
* croix.png:
* desc.png:
* style.css:
* jquery-ui.min.css:
* mdd_gripper.png:
* mdd_toolbar.png:
* jquery.timepicker.css:
* mdd_ajax_loader.gif:
* mdd_modal_background.png: moved to /App_Themes
* NpgsqlBlogProvider.cs: * Remove post by id
* Manage collections of entries on a couple (user,title), not a single
post
* NpgsqlCircleProvider.cs: Fixes the "Match" method.
* IDbModule.cs:
* Edit.aspx:
* Estimates.aspx:
* WorkFlowManager.cs:
* NpgsqlContentProvider.cs: refactoring
* NpgsqlMRPProviders.csproj: new NpgsqlUserName provider
* NpgsqlRoleProvider.cs: simpler init method
* NpgsqlUserNameProvider.cs: impements a UserNameProvider
* MyClass.cs: refactoring from Yavsc.Model
* BlogsController.cs: access control simplified
* FrontOfficeController.cs: Pdf generation made public ni case of
formatting exception
* mdd_styles.css: Theme -> App_Themes
* style.css: yet another style impact
* AccountController.cs: Fixes the user name modification
* BlogsController.cs: * Fixes the removal process
* On a title and user name, we get collection of posts, not only one.
* Implements an Access on circle
* FrontOfficeController.cs: * implements a new Get method.
* ensure a membership existence before delivering an estimate.
* GoogleController.cs: Fixes the user name modification on a Google
account
* ErrorHtmlFormatter.cs: nice error message in html (using Markdown
helper)
* FormatterException.cs: formatter exception exposes error and
standard output of the process
* TexToPdfFormatter.cs: * generates temporary files in the folder
returned by Path.GetTempPath()
* throws FormatterException
* Global.asax.cs: new route map:
Blogs/{action}/{user}/{title}
Blog/{user}/{title}
B/{id}
{controller}/{action}/{id}
* App.master: * refactoring: Theme moved to App_Themes
* a link to the logged user's blog
*
* NoLogin.master: refactoring: Theme moved to App_Themes
* Circles.aspx: refactoring : circles now are given as select items
* Login.aspx: fixes the html presentation
* Register.aspx: Fixes a Typo
* Index.aspx: Implements a blog index, due to M&C changes with this
commit
* RemovePost.aspx: links to the new route to the "RemovePost" action,
giving it a post id
* RemoveTitle.aspx: fixes a not yet linked page to remove a post
collection under a given title
* EventPub.aspx: code refactoring
* Writting.ascx: cleans the code
* Web.config: fills the config with new names in the space
* Web.config: configures the new NpgsqlUserNameProvider
* Web.csproj: refactoring and others
* BlogEntryCollection.cs: implement the BlogEntryCollection
* BlogManager.cs: the manager helps to filter on access
* BlogProvider.cs: The title is not unique anymore, and one can modify
it, post a lot under it, drop all posts under it.
A Post is deleted by id.
* UUBlogEntryCollection.cs: implements a collection of post under a
given user name.
* UUTBlogEntryCollection.cs: implements a collection of post under a
given couple (user name, title).
* ListItem.cs: ListItem is declared obsolete in this model, helpers
can build MVC SelectListItem on data returned by the manager.
* LocalizedText.Designer.cs:
* LocalizedText.fr.Designer.cs: autogenerated from xml
* LocalizedText.resx:
* LocalizedText.fr.resx: new labels
* ChangeUserNameProvider.cs: xml doc
* Profile.cs: the UserName property is read only, and comes from
authentication, to change it, we set a Name and validate it agains
the "Profile" method
* UserManager.cs: simpler code a init time
* IContentProvider.cs: implements the new IDataProvider interface
* IDataProvider.cs: defines the new IDataProvider interface
* YavscModel.csproj: includes new classes
* UserPosts.aspx: adds a link to remove a post
* UserPost.aspx: now uses the new BlogEntryCollection object
9 years ago
|
|
|
|
|
|
|
|
|
throw new NotImplementedException ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// The allowed media types.
|
|
|
|
|
/// </summary>
|
|
|
|
|
protected string[] allowedMediaTypes = {
|
|
|
|
|
"text/plain",
|
|
|
|
|
"text/x-tex",
|
|
|
|
|
"text/html",
|
|
|
|
|
"image/png",
|
|
|
|
|
"image/gif",
|
|
|
|
|
"image/jpeg",
|
|
|
|
|
"image/x-xcf",
|
|
|
|
|
"application/pdf",
|
|
|
|
|
"application/vnd.openxmlformats-officedocument.wordprocessingml.document"
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Posts the file.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <returns>The file.</returns>
|
|
|
|
|
[Authorize, HttpPost]
|
|
|
|
|
public async Task<HttpResponseMessage> PostFile(long id) {
|
|
|
|
|
if (!(Request.Content.Headers.ContentType.MediaType=="multipart/form-data"))
|
|
|
|
|
throw new HttpRequestException ("not a multipart/form-data request");
|
|
|
|
|
BlogEntry be = BlogManager.GetPost (id);
|
|
|
|
|
if (be.Author != Membership.GetUser ().UserName)
|
|
|
|
|
throw new AuthorizationDenied ("b"+id);
|
|
|
|
|
string root = HttpContext.Current.Server.MapPath("~/bfiles/"+id);
|
|
|
|
|
DirectoryInfo di = new DirectoryInfo (root);
|
|
|
|
|
if (!di.Exists) di.Create ();
|
|
|
|
|
|
|
|
|
|
var provider = new MultipartFormDataStreamProvider(root);
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
// Read the form data.
|
|
|
|
|
await Request.Content.ReadAsMultipartAsync(provider) ;
|
|
|
|
|
var invalidChars = Path.GetInvalidFileNameChars();
|
|
|
|
|
foreach (string fkey in provider.BodyPartFileNames.Keys)
|
|
|
|
|
{
|
|
|
|
|
string filename = provider.BodyPartFileNames[fkey];
|
|
|
|
|
Trace.WriteLine(filename);
|
|
|
|
|
|
|
|
|
|
string nicename = HttpUtility.UrlDecode(fkey) ;
|
|
|
|
|
if (fkey.StartsWith("\"") && fkey.EndsWith("\"") && fkey.Length > 2)
|
|
|
|
|
nicename = fkey.Substring(1,fkey.Length-2);
|
|
|
|
|
nicename = new string (nicename.Where( x=> !invalidChars.Contains(x)).ToArray());
|
|
|
|
|
nicename = nicename.Replace(' ','_');
|
|
|
|
|
var dest = Path.Combine(root,nicename);
|
|
|
|
|
var fi = new FileInfo(dest);
|
|
|
|
|
if (fi.Exists) fi.Delete();
|
|
|
|
|
File.Move(filename, fi.FullName);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return Request.CreateResponse(HttpStatusCode.OK);
|
|
|
|
|
}
|
|
|
|
|
catch (System.Exception e)
|
|
|
|
|
{
|
|
|
|
|
return Request.CreateResponse(HttpStatusCode.InternalServerError, e);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Searchs the file.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <returns>The file.</returns>
|
|
|
|
|
/// <param name="id">Postid.</param>
|
|
|
|
|
/// <param name="terms">Terms.</param>
|
|
|
|
|
[HttpGet]
|
|
|
|
|
public async Task<HttpResponseMessage> SearchFile(long id, string terms) {
|
|
|
|
|
throw new NotImplementedException ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Sets the photo.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="id">Identifier.</param>
|
|
|
|
|
/// <param name="photo">Photo.</param>
|
|
|
|
|
[Authorize, HttpPost, ValidateAjaxAttribute]
|
|
|
|
|
public void SetPhoto(long id, [FromBody] string photo)
|
|
|
|
|
{
|
|
|
|
|
BlogManager.Provider.UpdatePostPhoto (id, photo);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Import the specified id.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="id">Identifier.</param>
|
|
|
|
|
[Authorize, HttpPost, ValidateAjaxAttribute]
|
|
|
|
|
public async Task<HttpResponseMessage> Import(long id) {
|
|
|
|
|
if (!(Request.Content.Headers.ContentType.MediaType=="multipart/form-data"))
|
|
|
|
|
throw new HttpRequestException ("not a multipart/form-data request");
|
|
|
|
|
BlogEntry be = BlogManager.GetPost (id);
|
|
|
|
|
if (be.Author != Membership.GetUser ().UserName)
|
|
|
|
|
throw new AuthorizationDenied ("post: "+id);
|
|
|
|
|
string root = HttpContext.Current.Server.MapPath("~/bfiles/"+id);
|
|
|
|
|
DirectoryInfo di = new DirectoryInfo (root);
|
|
|
|
|
if (!di.Exists) di.Create ();
|
|
|
|
|
var provider = new MultipartFormDataStreamProvider(root);
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
// Read the form data.
|
|
|
|
|
//IEnumerable<HttpContent> data =
|
|
|
|
|
await Request.Content.ReadAsMultipartAsync(provider) ;
|
|
|
|
|
|
|
|
|
|
var invalidChars = Path.GetInvalidFileNameChars();
|
|
|
|
|
List<string> bodies = new List<string>();
|
|
|
|
|
|
|
|
|
|
foreach (string fkey in provider.BodyPartFileNames.Keys)
|
|
|
|
|
{
|
|
|
|
|
string filename = provider.BodyPartFileNames[fkey];
|
|
|
|
|
|
|
|
|
|
string nicename=fkey;
|
|
|
|
|
var filtered = new string (nicename.Where( x=> !invalidChars.Contains(x)).ToArray());
|
|
|
|
|
|
|
|
|
|
FileInfo fi = new FileInfo(filtered);
|
|
|
|
|
FileInfo fo = new FileInfo(filtered+".md");
|
|
|
|
|
FileInfo fp = new FileInfo (Path.Combine(root,filename));
|
|
|
|
|
if (fi.Exists) fi.Delete();
|
|
|
|
|
fp.MoveTo(fi.FullName);
|
|
|
|
|
// TODO Get the mime type
|
|
|
|
|
using (Process p = new Process ()) {
|
|
|
|
|
p.StartInfo.WorkingDirectory = root;
|
|
|
|
|
p.StartInfo = new ProcessStartInfo ();
|
|
|
|
|
p.StartInfo.UseShellExecute = false;
|
|
|
|
|
p.StartInfo.FileName = "/usr/bin/pandoc";
|
|
|
|
|
p.StartInfo.Arguments =
|
|
|
|
|
string.Format (" -o '{0}' -t markdown '{1}'",
|
|
|
|
|
fo.FullName,
|
|
|
|
|
fi.FullName);
|
|
|
|
|
p.StartInfo.RedirectStandardError = true;
|
|
|
|
|
p.StartInfo.RedirectStandardOutput = true;
|
|
|
|
|
p.Start ();
|
|
|
|
|
p.WaitForExit ();
|
|
|
|
|
if (p.ExitCode != 0) {
|
|
|
|
|
return Request.CreateResponse (HttpStatusCode.InternalServerError,
|
|
|
|
|
"# Import failed with exit code: " + p.ExitCode + "---\n"
|
|
|
|
|
+ LocalizedText.ImportException + "---\n"
|
|
|
|
|
+ p.StandardError.ReadToEnd() + "---\n"
|
|
|
|
|
+ p.StandardOutput.ReadToEnd()
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
bodies.Add(fo.OpenText().ReadToEnd());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fi.Delete();
|
|
|
|
|
fo.Delete();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return Request.CreateResponse(HttpStatusCode.OK,string.Join("---\n",bodies),new SimpleFormatter("text/plain"));
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
catch (System.Exception e)
|
|
|
|
|
{
|
|
|
|
|
return Request.CreateResponse(HttpStatusCode.InternalServerError, e);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|