From d059f6d6f4de2678555f23a357d69686e595ad29 Mon Sep 17 00:00:00 2001 From: Roy Ben-Shabat Date: Wed, 27 Feb 2019 18:56:38 +0200 Subject: Added machine service downloads site. --- .../Controllers/DownloadsController.cs | 67 ++++++++++++++++++---- 1 file changed, 57 insertions(+), 10 deletions(-) (limited to 'Software/Visual_Studio/Web/Tango.MachineService/Controllers') diff --git a/Software/Visual_Studio/Web/Tango.MachineService/Controllers/DownloadsController.cs b/Software/Visual_Studio/Web/Tango.MachineService/Controllers/DownloadsController.cs index ecdbf662c..a46cab3c2 100644 --- a/Software/Visual_Studio/Web/Tango.MachineService/Controllers/DownloadsController.cs +++ b/Software/Visual_Studio/Web/Tango.MachineService/Controllers/DownloadsController.cs @@ -3,9 +3,19 @@ using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc; +using Tango.BL; using Tango.MachineService.Filters; using Tango.MachineService.Models; using Tango.MachineService.Views.Downloads; +using Tango.Web.Helpers; +using System.Data.Entity; +using Tango.Web.Storage; +using System.IO; +using Microsoft.WindowsAzure.Storage.Blob; +using System.Net.Http; +using System.Net; +using System.Net.Http.Headers; +using System.Net.Mime; namespace Tango.MachineService.Controllers { @@ -15,18 +25,40 @@ namespace Tango.MachineService.Controllers public ActionResult Index() { List downloads = new List(); - for (int i = 0; i < 10; i++) + + using (ObservablesContext db = ObservablesContextHelper.CreateContext()) { - downloads.Add(new DownloadModel() + foreach (var item in db.MachineStudioVersions.Where(x => x.InstallerBlobName != null).Include(x => x.User).Include(x => x.User.Contact).ToList()) + { + DownloadModel download = new DownloadModel(); + download.App = DownloadModel.DownloadApp.MachineStudio; + download.ID = item.InstallerBlobName; + download.Name = $"Machine Studio v{item.Version}.exe"; + download.Version = item.Version; + download.User = item.User.Contact.FullName; + download.Date = item.LastUpdated; + download.Comments = item.Comments; + + downloads.Add(download); + } + + foreach (var item in db.TangoVersions.Where(x => x.InstallerBlobName != null).Include(x => x.User).Include(x => x.User.Contact).ToList()) { - Name = "Downloads " + i, - Comments = "Some comments...\nWith a new line", - Date = DateTime.Now.ToString(), - User = "Roy", - ID = i.ToString(), - }); + DownloadModel download = new DownloadModel(); + download.App = DownloadModel.DownloadApp.PPC; + download.ID = item.InstallerBlobName; + download.Name = $"PPC v{item.Version}.exe"; + download.Version = item.Version; + download.User = item.User.Contact.FullName; + download.Date = item.LastUpdated; + download.Comments = item.Comments; + + downloads.Add(download); + } } + downloads = downloads.OrderByDescending(x => x.Date).ToList(); + IndexViewModel model = new IndexViewModel(); model.Downloads = downloads; @@ -34,9 +66,24 @@ namespace Tango.MachineService.Controllers } [Authorize] - public ActionResult Download(String id) + public ActionResult Download(String blobName, DownloadModel.DownloadApp downloadApp) { - return File(new byte[] { 25, 255, 255 }, System.Net.Mime.MediaTypeNames.Application.Octet,"Machine Studio v1.0.exe"); + CloudBlobContainer container = null; + + var manager = new BlobStorageManager(); + + if (downloadApp == DownloadModel.DownloadApp.MachineStudio) + { + container = manager.GetContainer(MachineServiceConfig.MACHINE_STUDIO_VERSIONS_CONTAINER); + } + else + { + container = manager.GetContainer(MachineServiceConfig.TANGO_VERSIONS_CONTAINER); + } + + var blob = container.GetBlockBlobReference(blobName); + var signature = blob.GenerateReadSignature(TimeSpan.FromMinutes(10)); + return Redirect(signature); } } } \ No newline at end of file -- cgit v1.3.1