public IActionResult NewVault() { ViewBag.Title = "Create Vault"; ModifyVaultViewModel model = new ModifyVaultViewModel(); model.CurrentSub = Subdomain; return(View("~/Areas/Vault/Views/Vault/ModifyVault.cshtml", model)); }
public IActionResult NewVaultFromService(string type, string items) { ViewBag.Title = "Create Vault"; ModifyVaultViewModel model = new ModifyVaultViewModel(); model.CurrentSub = Subdomain; string decodedItems = HttpUtility.UrlDecode(items); string[] allURLs = decodedItems.Split(','); int index = 0; foreach (string url in allURLs) { string[] urlInfo = url.Split(':'); string uploadId = urlInfo[0]; string title = string.Empty; if (urlInfo.GetUpperBound(0) >= 1) { // They also passed in the original filename, so let's use it as our title title = urlInfo[1]; } if (IsValidItem(type, uploadId)) { ModifyVaultItemViewModel item = new ModifyVaultItemViewModel(); item.isTemplate = false; item.index = index; item.title = title; item.url = uploadId; item.type = type; model.items.Add(item); index++; } } return(View("~/Areas/Vault/Views/Vault/ModifyVault.cshtml", model)); }
public IActionResult EditVault(ModifyVaultViewModel model) { if (model != null) { Vault.Models.Vault foundVault = _dbContext.Vaults.Where(v => v.VaultId == model.vaultId).FirstOrDefault(); if (foundVault != null) { if (foundVault.User.Username == User.Identity.Name) { foundVault.DateEdited = DateTime.Now; foundVault.Title = model.title; foundVault.Description = model.description; // Clear previous items List <VaultItem> vaultItems = _dbContext.VaultItems.Where(v => v.VaultId == foundVault.VaultId).ToList(); if (vaultItems != null) { foreach (VaultItem item in vaultItems) { _dbContext.VaultItems.Remove(item); } } foundVault.VaultItems.Clear(); // Add/Verify items if (model.items.Any()) { int index = 0; foreach (ModifyVaultItemViewModel item in model.items) { if (IsValidItem(item.type, item.url)) { switch (item.type.ToLower()) { case "upload": UploadVaultItem newUpload = new UploadVaultItem(); newUpload.Index = index; newUpload.DateAdded = DateTime.Now; newUpload.Title = item.title; newUpload.Description = item.description; newUpload.UploadId = _dbContext.Uploads.Where(u => u.Url == item.url).FirstOrDefault().UploadId; foundVault.VaultItems.Add(newUpload); index++; break; case "paste": PasteVaultItem newPaste = new PasteVaultItem(); newPaste.Index = index; newPaste.DateAdded = DateTime.Now; newPaste.Title = item.title; newPaste.Description = item.description; newPaste.PasteId = _dbContext.Pastes.Where(p => p.Url == item.url).FirstOrDefault().PasteId; foundVault.VaultItems.Add(newPaste); index++; break; default: return(Json(new { error = new { message = "You have an invalid item type: " + item.type } })); } } else { return(Json(new { error = new { message = "You have an invalid item URL: " + item.url } })); } } } _dbContext.Entry(foundVault).State = EntityState.Modified; _dbContext.SaveChanges(); return(Json(new { result = new { url = Url.SubRouteUrl("v", "Vault.ViewVault", new { id = foundVault.Url }) } })); } return(Json(new { error = new { message = "You do not have permission to edit this Vault" } })); } return(Json(new { error = new { message = "That Vault does not exist" } })); } return(Json(new { error = new { message = "Invalid Parameters" } })); }
public IActionResult CreateVault(ModifyVaultViewModel model) { if (model != null) { if (!string.IsNullOrEmpty(model.title)) { Models.Vault newVault = new Models.Vault(); // Create a new ID string url = StringHelper.RandomString(_config.VaultConfig.UrlLength); while (_dbContext.Vaults.Where(v => v.Url == url).FirstOrDefault() != null) { url = StringHelper.RandomString(_config.VaultConfig.UrlLength); } newVault.Url = url; newVault.DateCreated = DateTime.Now; newVault.Title = model.title; newVault.Description = model.description; if (User.Identity.IsAuthenticated) { User user = UserHelper.GetUser(_dbContext, User.Identity.Name); if (user != null) { newVault.UserId = user.UserId; } } // Add/Verify items if (model.items.Any()) { int index = 0; foreach (ModifyVaultItemViewModel item in model.items) { if (IsValidItem(item.type, item.url)) { switch (item.type.ToLower()) { case "upload": UploadVaultItem newUpload = new UploadVaultItem(); newUpload.Index = index; newUpload.DateAdded = DateTime.Now; newUpload.Title = item.title; newUpload.Description = item.description; newUpload.UploadId = _dbContext.Uploads.Where(u => u.Url == item.url).FirstOrDefault().UploadId; newVault.VaultItems.Add(newUpload); index++; break; case "paste": PasteVaultItem newPaste = new PasteVaultItem(); newPaste.Index = index; newPaste.DateAdded = DateTime.Now; newPaste.Title = item.title; newPaste.Description = item.description; newPaste.PasteId = _dbContext.Pastes.Where(p => p.Url == item.url).FirstOrDefault().PasteId; newVault.VaultItems.Add(newPaste); index++; break; default: return(Json(new { error = new { message = "You have an invalid item type: " + item.type } })); } } else { return(Json(new { error = new { message = "You have an invalid item URL: " + item.url } })); } } } // Add and save the new vault _dbContext.Vaults.Add(newVault); _dbContext.SaveChanges(); return(Json(new { result = new { url = Url.SubRouteUrl("v", "Vault.ViewVault", new { id = url }) } })); } return(Json(new { error = new { message = "You must supply a Title" } })); } return(Json(new { error = new { message = "Invalid Parameters" } })); }
public IActionResult EditVault(string url, string type, string items) { ViewBag.Title = "Edit Vault"; Vault.Models.Vault foundVault = _dbContext.Vaults.Where(v => v.Url == url).FirstOrDefault(); if (foundVault != null) { if (foundVault.User.Username == User.Identity.Name) { ViewBag.Title = "Edit Vault | " + foundVault.Title; ModifyVaultViewModel model = new ModifyVaultViewModel(); model.CurrentSub = Subdomain; model.isEdit = true; model.vaultId = foundVault.VaultId; model.title = foundVault.Title; model.description = foundVault.Description; int index = 0; // Add all their existing items for the vault foreach (VaultItem item in foundVault.VaultItems.OrderBy(v => v.Index)) { ModifyVaultItemViewModel itemModel = new ModifyVaultItemViewModel(); itemModel.index = index; itemModel.isTemplate = false; if (item.GetType().BaseType == typeof(UploadVaultItem)) { UploadVaultItem upload = (UploadVaultItem)item; itemModel.title = upload.Title; itemModel.description = upload.Description; itemModel.type = "Upload"; itemModel.url = upload.Upload.Url; model.items.Add(itemModel); index++; } else if (item.GetType().BaseType == typeof(PasteVaultItem)) { PasteVaultItem paste = (PasteVaultItem)item; itemModel.title = paste.Title; itemModel.description = paste.Description; itemModel.type = "Paste"; itemModel.url = paste.Paste.Url; model.items.Add(itemModel); index++; } } // If they passed any new items in via the parameters, let's add them if (!string.IsNullOrEmpty(type) && !string.IsNullOrEmpty(items)) { string decodedItems = HttpUtility.UrlDecode(items); string[] allItems = decodedItems.Split(','); foreach (string newItem in allItems) { string[] urlInfo = newItem.Split(':'); string itemId = urlInfo[0]; string title = string.Empty; if (urlInfo.GetUpperBound(0) >= 1) { // They also passed in the original filename, so let's use it as our title title = urlInfo[1]; } if (IsValidItem(type, itemId)) { ModifyVaultItemViewModel item = new ModifyVaultItemViewModel(); item.isTemplate = false; item.index = index; item.title = title; item.url = itemId; item.type = type; model.items.Add(item); index++; } } } return(View("~/Areas/Vault/Views/Vault/ModifyVault.cshtml", model)); } return(new StatusCodeResult(StatusCodes.Status403Forbidden)); } return(new StatusCodeResult(StatusCodes.Status404NotFound)); }