public ActionResult CrearProyectoArchivo(ProyectoArchivoViewModel newModel, HttpPostedFileBase topologiaCVS) { if (ModelState.IsValid) { int idProyecto = newModel.InsertProyecto(); List<Tabla> tablaDatos = new List<Tabla>(); StreamReader csvreader = new StreamReader(topologiaCVS.InputStream); // Use the InputStream to get the actual stream sent. //Primera linea var line = csvreader.ReadLine(); var values = line.Split(';'); while (!csvreader.EndOfStream) { Tabla row = new Tabla(); line = csvreader.ReadLine(); values = line.Split(';'); row.Hostname = values[0]; row.OSPFRouterID = values[1]; row.OSPFNeighborRouterID = values[2]; row.OSPFNeighborIP = values[3]; tablaDatos.Add(row); } Proyecto newProyecto = new Proyecto(idProyecto); newProyecto.GenerarTopologia(tablaDatos); string url = Url.Action("Editar", "Topologia", new { idProyecto = idProyecto }); return Json(new { success = true, url = url }); //return Json(new { success = true }); } else { return PartialView(newModel); } }
public ActionResult CrearProyectoRP(ProyectoRaspberryViewModel newModel) { if (ModelState.IsValid) { int idProyecto = newModel.InsertProyecto(); string answer = ConexionSSH.EjecutarOSPFDiscovery(newModel.cRaspberryIP, newModel.nPuerto, newModel.cRouterIP, newModel.cCommunityString); //string answer = ""; //ConexionSSH.EjecutarOSPFDiscovery(newModel.cRaspberryIP, newModel.nPuerto, newModel.cRouterIP, newModel.cCommunityString); List<Tabla> tablaDatos = new List<Tabla>(); #region response /* answer = @"Hostname; OSPFRouterID; OSPFNeighborRouterID; OSPFNeighborIP\n\n" + @"R6; 6.6.6.6; 5.5.5.5, 4.4.4.4; 10.0.4.5, 10.0.4.14\n\n" + @"R5; 5.5.5.5; 1.1.1.1, 6.6.6.6, 4.4.4.4; 10.0.4.1, 10.0.4.6, 10.0.4.10\n\n" + @"R4; 4.4.4.4; 3.3.3.3, 5.5.5.5, 6.6.6.6; 10.0.3.1, 10.0.4.9, 10.0.4.13\n\n" + @"R4; 4.4.4.4; 3.3.3.3, 5.5.5.5, 6.6.6.6; 10.0.3.1, 10.0.4.9, 10.0.4.13\n\n" + @"R1; 1.1.1.1; 2.2.2.2, 5.5.5.5; 10.0.1.2, 10.0.4.2\n\n" + @"R3; 3.3.3.3; 2.2.2.2, 4.4.4.4; 10.0.2.1, 10.0.3.2\n\n" + @"R3; 3.3.3.3; 2.2.2.2, 4.4.4.4; 10.0.2.1, 10.0.3.2\n\n" + @"R3; 3.3.3.3; 2.2.2.2, 4.4.4.4; 10.0.2.1, 10.0.3.2\n\n" + @"R3; 3.3.3.3; 2.2.2.2, 4.4.4.4; 10.0.2.1, 10.0.3.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"R2; 2.2.2.2; 1.1.1.1, 3.3.3.3; 10.0.1.1, 10.0.2.2\n\n" + @"end of file\n";*/ #endregion if (answer != "") { string[] lines = answer.Split(new string[] { "\n\n" }, StringSplitOptions.None); // TODO: Parsear el archivo CSV List<string> templist = new List<string>(); templist = lines.ToList(); templist.RemoveAt(0); templist.RemoveAt(templist.Count - 1); foreach (var line in templist) { Tabla row = new Tabla(); var values = line.Split(';'); row.Hostname = values[0].Trim(); row.OSPFRouterID = values[1].Trim(); row.OSPFNeighborRouterID = values[2].Trim(); row.OSPFNeighborIP = values[3].Trim(); tablaDatos.Add(row); } Proyecto newModelP = new Proyecto(idProyecto); newModelP.GenerarTopologia(tablaDatos); } //return RedirectToAction("Index"); //return RedirectToAction("Editar", new { idProyecto = idProyecto }); string url = Url.Action("Editar", "Topologia", new { idProyecto = idProyecto }); return Json(new { success = true, url = url }); } else { return PartialView(newModel); } }
public async Task<IHttpActionResult> PostFile() { if (!Request.Content.IsMimeMultipartContent()) { throw new HttpResponseException(HttpStatusCode.UnsupportedMediaType); } var provider = await Request.Content.ReadAsMultipartAsync<InMemoryMultipartFormDataStreamProvider>(new InMemoryMultipartFormDataStreamProvider()); //Debug.Write(provider.Contents.ToString()); //access form data NameValueCollection formData = provider.FormData; //access files IList<HttpContent> files = provider.Files; string userName = formData.GetValues("cUserName")[0]; string projectName = formData.GetValues("cFileName")[0]; byte[] byteArray = await provider.Files[0].ReadAsByteArrayAsync(); MemoryStream myStream = new MemoryStream(byteArray); //Proceso de parsing del archivo CSV List<Tabla> tablaDatos = new List<Tabla>(); StreamReader csvreader = new StreamReader(myStream); //Debug.Write(csvreader.ReadToEnd()); //Primera linea var line = csvreader.ReadLine(); var values = line.Split(';'); while (!csvreader.EndOfStream) { Tabla row = new Tabla(); line = csvreader.ReadLine(); if (line != "") { values = line.Split(';'); row.Hostname = values[0]; row.OSPFRouterID = values[1]; row.OSPFNeighborRouterID = values[2]; row.OSPFNeighborIP = values[3]; tablaDatos.Add(row); } } //Llama al SP para crear el nuevo proyecto en la DB Data.dsTopologiaTableAdapters.ProyectosTableAdapter Adapter = new Data.dsTopologiaTableAdapters.ProyectosTableAdapter(); int idProyecto = (int)Adapter.CrearProyectoLocal(userName, projectName); //Creación del nuevo objeto de proyecto Proyecto newProyecto = new Proyecto(idProyecto); newProyecto.GenerarTopologia(tablaDatos); return Ok(); }