Auftraggeberservice und Projektservice hinzugefügt

This commit is contained in:
2023-04-12 18:22:14 +02:00
parent 1c3e3c876b
commit b100eca490
37 changed files with 400 additions and 43 deletions

View File

@@ -0,0 +1,89 @@
using Npgsql;
using SewerStammGen.Shared.Contracts;
using SewerStammGen.Shared.Domain;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace SewerStammGen.DAL.Services
{
public class AuftraggeberDataService : IAuftraggeberDataService
{
string connString = "Host = localhost; Database = SewerGen; Username = SewerGen; Password = SewerGen";
NpgsqlDataSource dataSource;
NpgsqlConnection? conn = null;
public AuftraggeberDataService()
{
var dataSourceBuilder = new NpgsqlDataSourceBuilder(connString);
dataSource = dataSourceBuilder.Build();
//OpenConnection();
conn = dataSource.OpenConnection();
}
public Task<Auftraggeber> Create(Auftraggeber entity)
{
throw new NotImplementedException();
}
public Auftraggeber CreateNonAsync(Auftraggeber entity)
{
throw new NotImplementedException();
}
public Task<bool> Delete(int id)
{
throw new NotImplementedException();
}
public async Task<Auftraggeber> Get(int id)
{
Auftraggeber result = new Auftraggeber();
using (var cmd = new NpgsqlCommand($"SELECT * FROM public.\"Auftraggebers\" WHERE \"Id\" = @1", conn))
{
cmd.Parameters.AddWithValue("1", id);
using var reader = await cmd.ExecuteReaderAsync();
reader.Read();
result = parseAuftraggeber(reader);
}
return result;
}
private Auftraggeber parseAuftraggeber(NpgsqlDataReader reader)
{
return new Auftraggeber()
{
Id = reader.GetInt32(0),
Name = reader.IsDBNull(1) ? "" : reader.GetString(1),
Strasse = reader.IsDBNull(2) ? "" : reader.GetString(2),
Ort = reader.IsDBNull(3) ? "" : reader.GetString(3),
Postleitzahl = reader.IsDBNull(4) ? "" : reader.GetString(4),
Ansprechpartner = reader.IsDBNull(5) ? "" : reader.GetString(5),
Telefonnummer = reader.IsDBNull(6) ? "" : reader.GetString(6)
};
}
public async Task<IEnumerable<Auftraggeber>> GetAll()
{
List<Auftraggeber> result = new List<Auftraggeber>();
using (var cmd = new NpgsqlCommand($"SELECT * FROM public.\"Auftraggebers\"", conn))
using (var reader = await cmd.ExecuteReaderAsync())
{
while (reader.Read())
{
result.Add(parseAuftraggeber(reader));
}
}
return result;
}
public Task<Auftraggeber> Update(int id, Auftraggeber entity)
{
throw new NotImplementedException();
}
}
}

View File

@@ -0,0 +1,119 @@
using SewerStammGen.Shared.Contracts;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Npgsql;
using SewerStammGen.Shared.Domain;
using SewerStammGen.Shared.Enum;
namespace SewerStammGen.DAL.Services
{
public class ProjektDataService : IProjektDataService
{
string connString = "Host = localhost; Database = SewerGen; Username = SewerGen; Password = SewerGen";
NpgsqlDataSource dataSource;
NpgsqlConnection? conn = null;
public ProjektDataService()
{
var dataSourceBuilder = new NpgsqlDataSourceBuilder(connString);
dataSource = dataSourceBuilder.Build();
//OpenConnection();
conn = dataSource.OpenConnection();
}
private async void OpenConnection()
{
conn = await dataSource.OpenConnectionAsync();
}
public async Task<Projekt> Create(Projekt entity)
{
string command = "INSERT INTO public.\"Projekte\" (\"Projektname\", \"Erstelldatum\", \"Strasse\", \"Ort\", \"ExportType\", \"Kodierungssystem\",\"AuftraggeberId\") " +
"VALUES(@1,@2,@3,@4,@5,@6,@7) RETURNING \"Id\"";
await using(var cmd = new NpgsqlCommand(command, conn))
{
cmd.Parameters.AddWithValue("1", entity.Projektname);
cmd.Parameters.AddWithValue("2", entity.Erstelldatum);
cmd.Parameters.AddWithValue("3", entity.Strasse);
cmd.Parameters.AddWithValue("4", entity.Ort);
cmd.Parameters.AddWithValue("5", (int)entity.ExportType);
cmd.Parameters.AddWithValue("6", (int)entity.Kodierungssystem);
cmd.Parameters.AddWithValue("7", entity.Auftraggeber.Id);
using var reader = await cmd.ExecuteReaderAsync();
reader.Read();
entity.Id = reader.GetInt32(0);
}
return entity;
}
public Projekt CreateNonAsync(Projekt entity)
{
throw new NotImplementedException();
}
public Task<bool> Delete(int id)
{
throw new NotImplementedException();
}
public async Task<Projekt> Get(int id)
{
Projekt result = new Projekt();
IAuftraggeberDataService auftraggeberDataService = new AuftraggeberDataService();
using (var cmd = new NpgsqlCommand($"SELECT * FROM public.\"Projekte\" WHERE \"Id\" = @1", conn))
{
cmd.Parameters.AddWithValue("1", id);
using var reader = await cmd.ExecuteReaderAsync();
reader.Read();
result = parseProjekt(reader);
result.Auftraggeber = await auftraggeberDataService.Get(reader.GetInt32(7));
}
return result;
}
private Projekt? parseProjekt(NpgsqlDataReader reader)
{
return new Projekt()
{
Id = reader.GetInt32(0),
Projektname = reader.GetString(1),
Erstelldatum = reader.GetString(2),
Strasse = reader.GetString(3),
Ort = reader.GetString(4),
ExportType = (EExportType)reader.GetInt32(5),
Kodierungssystem = (EKodierungssystem)reader.GetInt32(6)
};
}
public async Task<IEnumerable<Projekt>> GetAll()
{
IAuftraggeberDataService auftraggeberDataService = new AuftraggeberDataService();
IEnumerable<Auftraggeber> auftraggebers = await auftraggeberDataService.GetAll();
List<Projekt> result = new List<Projekt>();
using (var cmd = new NpgsqlCommand($"SELECT * FROM public.\"Projekte\"", conn))
using (var reader = await cmd.ExecuteReaderAsync())
{
while (reader.Read())
{
Projekt projekt = parseProjekt(reader);
projekt.Auftraggeber = auftraggebers.Where(x => x.Id == reader.GetInt32(7)).ToList().Last();
result.Add(projekt);
}
}
return result;
}
public Task<Projekt> Update(int id, Projekt entity)
{
throw new NotImplementedException();
}
}
}