Moved software type version from Interop to Metadata.

This commit is contained in:
2017-12-29 01:32:12 +00:00
parent cfee0226dd
commit efc48f3e6a
8 changed files with 81 additions and 42 deletions

View File

@@ -679,6 +679,7 @@
</e> </e>
<e p="Resume.cs" t="Include" /> <e p="Resume.cs" t="Include" />
<e p="Statistics.cs" t="Include" /> <e p="Statistics.cs" t="Include" />
<e p="Version.cs" t="Include" />
<e p="bin" t="ExcludeRecursive" /> <e p="bin" t="ExcludeRecursive" />
<e p="obj" t="ExcludeRecursive" /> <e p="obj" t="ExcludeRecursive" />
</e> </e>

View File

@@ -117,7 +117,7 @@ namespace DiscImageChef.Core.Devices.Dumping
currentTry = new DumpHardwareType currentTry = new DumpHardwareType
{ {
Software = Version.GetSoftwareType(platform), Software = Metadata.Version.GetSoftwareType(platform),
Manufacturer = manufacturer, Manufacturer = manufacturer,
Model = model, Model = model,
Serial = serial Serial = serial
@@ -136,7 +136,7 @@ namespace DiscImageChef.Core.Devices.Dumping
}; };
currentTry = new DumpHardwareType currentTry = new DumpHardwareType
{ {
Software = Version.GetSoftwareType(platform), Software = Metadata.Version.GetSoftwareType(platform),
Manufacturer = manufacturer, Manufacturer = manufacturer,
Model = model, Model = model,
Serial = serial Serial = serial

View File

@@ -43,7 +43,7 @@ using DiscImageChef.Devices;
using DiscImageChef.Metadata; using DiscImageChef.Metadata;
using Schemas; using Schemas;
using MediaType = DiscImageChef.CommonTypes.MediaType; using MediaType = DiscImageChef.CommonTypes.MediaType;
using Version = DiscImageChef.Interop.Version; using Version = DiscImageChef.Metadata.Version;
namespace DiscImageChef.Core.Devices.Dumping namespace DiscImageChef.Core.Devices.Dumping
{ {

View File

@@ -36,6 +36,7 @@ using System.Net;
using System.Threading; using System.Threading;
using System.Xml.Serialization; using System.Xml.Serialization;
using DiscImageChef.Metadata; using DiscImageChef.Metadata;
using Version = DiscImageChef.Interop.Version;
namespace DiscImageChef.Core namespace DiscImageChef.Core
{ {
@@ -64,7 +65,8 @@ namespace DiscImageChef.Core
XmlSerializer xmlSer = new XmlSerializer(typeof(DeviceReport)); XmlSerializer xmlSer = new XmlSerializer(typeof(DeviceReport));
xmlSer.Serialize(xmlStream, report); xmlSer.Serialize(xmlStream, report);
xmlStream.Seek(0, SeekOrigin.Begin); xmlStream.Seek(0, SeekOrigin.Begin);
WebRequest request = WebRequest.Create("http://discimagechef.claunia.com/api/uploadreport"); WebRequest request =
WebRequest.Create("http://discimagechef.claunia.com/api/uploadreport");
((HttpWebRequest)request).UserAgent = $"DiscImageChef {typeof(Version).Assembly.GetName().Version}"; ((HttpWebRequest)request).UserAgent = $"DiscImageChef {typeof(Version).Assembly.GetName().Version}";
request.Method = "POST"; request.Method = "POST";
request.ContentLength = xmlStream.Length; request.ContentLength = xmlStream.Length;

View File

@@ -44,12 +44,6 @@
<Link>LICENSE.MIT</Link> <Link>LICENSE.MIT</Link>
</EmbeddedResource> </EmbeddedResource>
</ItemGroup> </ItemGroup>
<ItemGroup>
<ProjectReference Include="..\DiscImageChef.Metadata\DiscImageChef.Metadata.csproj">
<Project>{9F213318-5CB8-4066-A757-074489C9F818}</Project>
<Name>DiscImageChef.Metadata</Name>
</ProjectReference>
</ItemGroup>
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" /> <Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
<ProjectExtensions> <ProjectExtensions>
<MonoDevelop> <MonoDevelop>

View File

@@ -36,29 +36,10 @@
// Copyright © 2011-2018 Natalia Portillo // Copyright © 2011-2018 Natalia Portillo
// ****************************************************************************/ // ****************************************************************************/
using DiscImageChef.Interop;
using Schemas;
namespace DiscImageChef.Interop namespace DiscImageChef.Interop
{ {
public static class Version public static class Version
{ {
/// <summary>
/// Gets XML software type for the running version
/// </summary>
/// <param name="platform">Platform we are running in</param>
/// <returns>XML software type</returns>
public static SoftwareType GetSoftwareType(PlatformID platform)
{
// TODO: Platform should be get automatically
return new SoftwareType
{
Name = "DiscImageChef",
OperatingSystem = platform.ToString(),
Version = typeof(Version).Assembly.GetName().Version.ToString()
};
}
/// <summary> /// <summary>
/// Gets version string /// Gets version string
/// </summary> /// </summary>

View File

@@ -1,4 +1,4 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> <Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup> <PropertyGroup>
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration> <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
@@ -45,6 +45,7 @@
<Compile Include="Statistics.cs" /> <Compile Include="Statistics.cs" />
<Compile Include="Resume.cs" /> <Compile Include="Resume.cs" />
<Compile Include="ExtentsConverter.cs" /> <Compile Include="ExtentsConverter.cs" />
<Compile Include="Version.cs" />
</ItemGroup> </ItemGroup>
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" /> <Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
<ItemGroup> <ItemGroup>
@@ -60,6 +61,10 @@
<Project>{F8BDF57B-1571-4CD0-84B3-B422088D359A}</Project> <Project>{F8BDF57B-1571-4CD0-84B3-B422088D359A}</Project>
<Name>DiscImageChef.Helpers</Name> <Name>DiscImageChef.Helpers</Name>
</ProjectReference> </ProjectReference>
<ProjectReference Include="..\DiscImageChef.Interop\DiscImageChef.Interop.csproj">
<Project>{9183f2e0-a879-4f23-9ee3-c6908f1332b2}</Project>
<Name>DiscImageChef.Interop</Name>
</ProjectReference>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<EmbeddedResource Include="..\LICENSE.LGPL"> <EmbeddedResource Include="..\LICENSE.LGPL">

View File

@@ -0,0 +1,56 @@
// /***************************************************************************
// The Disc Image Chef
// ----------------------------------------------------------------------------
//
// Filename : Statistics.cs
// Author(s) : Natalia Portillo <claunia@claunia.com>
//
// Component : XML metadata.
//
// --[ Description ] ----------------------------------------------------------
//
// Returns DiscImageChef version in XML software type format.
//
// --[ License ] --------------------------------------------------------------
//
// This library is free software; you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as
// published by the Free Software Foundation; either version 2.1 of the
// License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful, but
// WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, see <http://www.gnu.org/licenses/>.
//
// ----------------------------------------------------------------------------
// Copyright © 2011-2018 Natalia Portillo
// ****************************************************************************/
using DiscImageChef.Interop;
using Schemas;
namespace DiscImageChef.Metadata
{
public static class Version
{
/// <summary>
/// Gets XML software type for the running version
/// </summary>
/// <param name="platform">Platform we are running in</param>
/// <returns>XML software type</returns>
public static SoftwareType GetSoftwareType(PlatformID platform)
{
// TODO: Platform should be get automatically
return new SoftwareType
{
Name = "DiscImageChef",
OperatingSystem = platform.ToString(),
Version = typeof(Version).Assembly.GetName().Version.ToString()
};
}
}
}