public IActionResult Delete(string id) { Vault.Models.Vault foundVault = _dbContext.Vaults.Where(v => v.Url == id).FirstOrDefault(); if (foundVault != null) { if (foundVault.User.Username == User.Identity.Name) { _dbContext.Vaults.Remove(foundVault); _dbContext.SaveChanges(); return(Json(new { result = new { url = Url.SubRouteUrl("vault", "Vault.CreateVault") } })); } 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" } })); }
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 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)); }