file detail edit api
This commit is contained in:
@@ -1,39 +1,24 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<configuration>
|
||||
<appSettings>
|
||||
<add key="url" value="http://localhost/API" />
|
||||
<!--<add key="url" value="http://test.benjamin-ifland.de"/>-->
|
||||
<!--<add key="url" value="http://localhost/API" />-->
|
||||
<add key="url" value="http://test.benjamin-ifland.de"/>
|
||||
</appSettings>
|
||||
|
||||
<runtime>
|
||||
|
||||
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
|
||||
|
||||
<dependentAssembly>
|
||||
|
||||
<assemblyIdentity name="Microsoft.OData.Core" publicKeyToken="31bf3856ad364e35" culture="neutral" />
|
||||
|
||||
<bindingRedirect oldVersion="0.0.0.0-7.5.4.30215" newVersion="7.5.4.30215" />
|
||||
|
||||
</dependentAssembly>
|
||||
|
||||
<dependentAssembly>
|
||||
|
||||
<assemblyIdentity name="Microsoft.OData.Edm" publicKeyToken="31bf3856ad364e35" culture="neutral" />
|
||||
|
||||
<bindingRedirect oldVersion="0.0.0.0-7.5.4.30215" newVersion="7.5.4.30215" />
|
||||
|
||||
</dependentAssembly>
|
||||
|
||||
<dependentAssembly>
|
||||
|
||||
<assemblyIdentity name="Microsoft.Spatial" publicKeyToken="31bf3856ad364e35" culture="neutral" />
|
||||
|
||||
<bindingRedirect oldVersion="0.0.0.0-7.5.4.30215" newVersion="7.5.4.30215" />
|
||||
|
||||
</dependentAssembly>
|
||||
|
||||
</assemblyBinding>
|
||||
|
||||
</runtime>
|
||||
</configuration>
|
||||
@@ -1,10 +1,11 @@
|
||||
using System;
|
||||
using API.Models;
|
||||
using Microsoft.VisualStudio.TestTools.UnitTesting;
|
||||
using Simple.OData.Client;
|
||||
using System;
|
||||
using System.Linq;
|
||||
using System.Net;
|
||||
using System.Threading.Tasks;
|
||||
using API.Models;
|
||||
using Microsoft.VisualStudio.TestTools.UnitTesting;
|
||||
using Simple.OData.Client;
|
||||
using File = System.IO.File;
|
||||
|
||||
namespace API.Client.Test {
|
||||
[TestClass]
|
||||
@@ -39,7 +40,7 @@ namespace API.Client.Test {
|
||||
var client = new Client();
|
||||
var data = await client.Get();
|
||||
|
||||
Assert.IsTrue(data.Any(_=>_.ID == testSong.ID));
|
||||
Assert.IsTrue(data.Any(_ => _.ID == testSong.ID));
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -64,6 +65,29 @@ namespace API.Client.Test {
|
||||
Assert.AreEqual(newSong.Name, insertedSong.Name);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public async Task PatchItem() {
|
||||
var client = new Client();
|
||||
var newSong = new Song {
|
||||
Name = Guid.NewGuid().ToString(),
|
||||
Text = TEST_CASE_IDENTIFIER,
|
||||
Comments = "Item to Patch"
|
||||
};
|
||||
|
||||
var response = await client.Post(newSong);
|
||||
try {
|
||||
var patchedSong = await client.Patch(response.ID, new { Comments = "patched" });
|
||||
} catch (WebRequestException ex) {
|
||||
File.WriteAllText("error.html", ex.Response);
|
||||
throw;
|
||||
}
|
||||
var insertedSong = await client.Get(response.ID);
|
||||
|
||||
Assert.AreEqual("patched", insertedSong.Comments);
|
||||
Assert.AreEqual(newSong.Name, insertedSong.Name);
|
||||
Assert.AreEqual(TEST_CASE_IDENTIFIER, insertedSong.Text);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public async Task DeleteItem() {
|
||||
var client = new Client();
|
||||
@@ -75,9 +99,14 @@ namespace API.Client.Test {
|
||||
var response = await client.Post(newSong);
|
||||
var insertedSong = await client.Get(response.ID);
|
||||
Assert.AreEqual(newSong.Name, insertedSong.Name);
|
||||
try {
|
||||
|
||||
var count = await client.Delete(response.ID);
|
||||
Assert.AreEqual(1, count);
|
||||
} catch (WebRequestException ex) {
|
||||
File.WriteAllText("error.html", ex.Response);
|
||||
throw;
|
||||
}
|
||||
|
||||
try {
|
||||
await client.Get(response.ID);
|
||||
|
||||
@@ -35,6 +35,12 @@ namespace API.Client {
|
||||
return insertedSong;
|
||||
}
|
||||
|
||||
public async Task<Song> Patch(long id, object value) {
|
||||
var client = new ODataClient(url).For<Song>().Key(id);
|
||||
var insertedSong = await client.Set(value).UpdateEntryAsync();
|
||||
return insertedSong;
|
||||
}
|
||||
|
||||
public async Task<int> Delete(long id) {
|
||||
var client = new ODataClient(url).For<Song>();
|
||||
var count = await client.Key(id).DeleteEntriesAsync();
|
||||
|
||||
@@ -179,7 +179,6 @@
|
||||
</ProjectReference>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Content Include="App_Data\environment.json" />
|
||||
<None Include="packages.config" />
|
||||
<None Include="Properties\PublishProfiles\deploy to test.pubxml" />
|
||||
</ItemGroup>
|
||||
@@ -194,7 +193,9 @@
|
||||
<DependentUpon>201903172028249_Log.cs</DependentUpon>
|
||||
</EmbeddedResource>
|
||||
</ItemGroup>
|
||||
<ItemGroup />
|
||||
<ItemGroup>
|
||||
<Folder Include="App_Data\" />
|
||||
</ItemGroup>
|
||||
<PropertyGroup>
|
||||
<VisualStudioVersion Condition="'$(VisualStudioVersion)' == ''">10.0</VisualStudioVersion>
|
||||
<VSToolsPath Condition="'$(VSToolsPath)' == ''">$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)</VSToolsPath>
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
using API.Database;
|
||||
using API.Models;
|
||||
using API.Services;
|
||||
using System.Net;
|
||||
using System.Net.Http;
|
||||
@@ -27,22 +28,18 @@ namespace API.Controllers {
|
||||
}
|
||||
|
||||
// GET: api/Files/5
|
||||
[Route("api/songs/{songId}/files/{fileId}")]
|
||||
public HttpResponseMessage Get(long songId, long fileId) {
|
||||
[Route("api/songs/{songId}/files/{fileId}", Order = 1)]
|
||||
public async Task<HttpResponseMessage> Get(long songId, long fileId) {
|
||||
var response = new HttpResponseMessage(HttpStatusCode.OK);
|
||||
fileGarbageCollectionService.Collect(dataPath);
|
||||
|
||||
var file = dataContext.Files.Find(fileId);
|
||||
var file = await dataContext.Files.FindAsync(fileId);
|
||||
if (file == null || file.Song.ID != songId) return new HttpResponseMessage(HttpStatusCode.NotFound);
|
||||
var reference = file.ReferenceFile;
|
||||
var filename = file.Name;
|
||||
|
||||
var stream = fileService.Load(dataPath, reference.ToString());
|
||||
response.Content = new StreamContent(stream);
|
||||
response.Content.Headers.ContentType = new MediaTypeHeaderValue("application/octet-stream");
|
||||
response.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment") {
|
||||
FileName = filename
|
||||
};
|
||||
return response;
|
||||
}
|
||||
|
||||
@@ -65,7 +62,7 @@ namespace API.Controllers {
|
||||
var filename = await fileService.Save(stream, dataPath, c);
|
||||
|
||||
// attach file reference to song
|
||||
song.Files.Add(new Models.File {
|
||||
song.Files.Add(new File {
|
||||
Name = file.FileName,
|
||||
ReferenceFile = filename
|
||||
});
|
||||
@@ -74,9 +71,29 @@ namespace API.Controllers {
|
||||
return new HttpResponseMessage(HttpStatusCode.OK);
|
||||
}
|
||||
|
||||
[Route("api/songs/{songId}/files/{fileId}/edit"), HttpGet]
|
||||
public async Task<HttpResponseMessage> Edit(long songId, long fileId, string Name, FileType FileType, CancellationToken c) {
|
||||
var file = await dataContext.Files.FindAsync(fileId);
|
||||
if (file == null || file.Song.ID != songId) return new HttpResponseMessage(HttpStatusCode.NotFound);
|
||||
|
||||
file.Name = Name;
|
||||
file.FileType = FileType;
|
||||
await dataContext.SaveChangesAsync();
|
||||
|
||||
return new HttpResponseMessage(HttpStatusCode.OK);
|
||||
}
|
||||
|
||||
[Route("api/songs/{songId}/files/{fileId}/delete"), HttpGet]
|
||||
public async Task<HttpResponseMessage> Delete(long songId, long fileId, CancellationToken c) {
|
||||
var file = await dataContext.Files.FindAsync(fileId);
|
||||
if (file == null || file.Song.ID != songId) return new HttpResponseMessage(HttpStatusCode.NotFound);
|
||||
|
||||
dataContext.Files.Remove(file);
|
||||
await dataContext.SaveChangesAsync();
|
||||
fileGarbageCollectionService.Collect(dataPath);
|
||||
|
||||
return new HttpResponseMessage(HttpStatusCode.OK);
|
||||
}
|
||||
|
||||
|
||||
//// PUT: api/Files/5
|
||||
|
||||
@@ -30,8 +30,15 @@
|
||||
<remove name="OPTIONSVerbHandler"/>
|
||||
<remove name="TRACEVerbHandler"/>
|
||||
<remove name="WebDAV"/>
|
||||
<add name="ExtensionlessUrlHandler-Integrated-4.0" path="*." verb="*" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0"/>
|
||||
<add name="ExtensionlessUrlHandler-Integrated-4.0" path="*." verb="GET,HEAD,POST,DEBUG,PUT,DELETE,PATCH,OPTIONS" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0"/>
|
||||
</handlers>
|
||||
<security>
|
||||
<requestFiltering>
|
||||
<verbs>
|
||||
<add verb="PATCH" allowed="true" />
|
||||
</verbs>
|
||||
</requestFiltering>
|
||||
</security>
|
||||
</system.webServer>
|
||||
<runtime>
|
||||
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
|
||||
|
||||
@@ -6,34 +6,19 @@
|
||||
</appSettings>
|
||||
|
||||
<runtime>
|
||||
|
||||
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
|
||||
|
||||
<dependentAssembly>
|
||||
|
||||
<assemblyIdentity name="Microsoft.OData.Core" publicKeyToken="31bf3856ad364e35" culture="neutral" />
|
||||
|
||||
<bindingRedirect oldVersion="0.0.0.0-7.5.4.30215" newVersion="7.5.4.30215" />
|
||||
|
||||
</dependentAssembly>
|
||||
|
||||
<dependentAssembly>
|
||||
|
||||
<assemblyIdentity name="Microsoft.OData.Edm" publicKeyToken="31bf3856ad364e35" culture="neutral" />
|
||||
|
||||
<bindingRedirect oldVersion="0.0.0.0-7.5.4.30215" newVersion="7.5.4.30215" />
|
||||
|
||||
</dependentAssembly>
|
||||
|
||||
<dependentAssembly>
|
||||
|
||||
<assemblyIdentity name="Microsoft.Spatial" publicKeyToken="31bf3856ad364e35" culture="neutral" />
|
||||
|
||||
<bindingRedirect oldVersion="0.0.0.0-7.5.4.30215" newVersion="7.5.4.30215" />
|
||||
|
||||
</dependentAssembly>
|
||||
|
||||
</assemblyBinding>
|
||||
|
||||
</runtime>
|
||||
</configuration>
|
||||
Reference in New Issue
Block a user