diff --git a/CHANGELOG.md b/CHANGELOG.md
index e0f4c5c3e..9438ea587 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -7,6 +7,7 @@
- Use numeric input instead of dropdown for top bedrock quality fields.
- Proxy requests to legacy api through .NET API with authentication.
- Disable spatial reference inputs when editing mode is not active or borehole status does not allow editing.
+- Remove obsolete database view `completness`.
## v2.0.476 - 2023-12-08
diff --git a/src/api-legacy/v1/action.py b/src/api-legacy/v1/action.py
index b7d1aed31..3ca7168fa 100644
--- a/src/api-legacy/v1/action.py
+++ b/src/api-legacy/v1/action.py
@@ -90,9 +90,6 @@ def getordering(self, orderby, direction):
elif orderby == 'status':
_orderby = 'status_id_cli'
- elif orderby == 'completness':
- _orderby = 'percentage'
-
elif orderby == 'creator':
_orderby = 'created_by_bho'
diff --git a/src/api-legacy/v1/borehole/editinglist.py b/src/api-legacy/v1/borehole/editinglist.py
index 6f6b129e7..092eede9a 100644
--- a/src/api-legacy/v1/borehole/editinglist.py
+++ b/src/api-legacy/v1/borehole/editinglist.py
@@ -116,7 +116,6 @@ async def execute(
) t
) as extended,
stratigraphy as stratigraphy,
- completness.percentage,
array_to_json(status) as workflows,
status[array_length(status, 1)] ->> 'role' as "role"
@@ -177,11 +176,6 @@ async def execute(
ON
v.id_bho_fk = borehole.id_bho
- INNER JOIN
- bdms.completness
- ON
- completness.id_bho = borehole.id_bho
-
LEFT JOIN
bdms.users as locker
ON
@@ -284,11 +278,6 @@ async def execute(
ON
ids.id_bho_fk = id_bho
- INNER JOIN
- bdms.completness
- ON
- completness.id_bho = borehole.id_bho
-
INNER JOIN
bdms.users as creator
ON
diff --git a/src/api-legacy/v1/borehole/get.py b/src/api-legacy/v1/borehole/get.py
index 20f916d12..f05cd5bbf 100644
--- a/src/api-legacy/v1/borehole/get.py
+++ b/src/api-legacy/v1/borehole/get.py
@@ -113,7 +113,6 @@ def get_sql(sql_lock='', file_permission=''):
) t
) as custom,
stratigraphy as stratigraphy,
- completness.percentage,
(
SELECT row_to_json(t)
FROM (
@@ -246,9 +245,6 @@ def get_sql(sql_lock='', file_permission=''):
ON
p.id_bho_fk = id_bho
- INNER JOIN bdms.completness
- ON completness.id_bho = borehole.id_bho
-
INNER JOIN bdms.users as updater
ON updated_by_bho = updater.id_usr
diff --git a/src/api-legacy/v1/borehole/ids.py b/src/api-legacy/v1/borehole/ids.py
index d4dc53018..77d12e952 100644
--- a/src/api-legacy/v1/borehole/ids.py
+++ b/src/api-legacy/v1/borehole/ids.py
@@ -63,11 +63,6 @@ async def execute(self, filter={}, user=None):
bdms.users as creator
ON
created_by_bho = creator.id_usr
-
- INNER JOIN
- bdms.completness
- ON
- completness.id_bho = borehole.id_bho
"""
if len(where) > 0:
diff --git a/src/api-legacy/v1/borehole/patch.py b/src/api-legacy/v1/borehole/patch.py
index c340057e3..2bbb08b2c 100644
--- a/src/api-legacy/v1/borehole/patch.py
+++ b/src/api-legacy/v1/borehole/patch.py
@@ -386,8 +386,6 @@ async def execute(self, id, field, value, user):
bdms.borehole
INNER JOIN bdms.users as locker
ON locked_by_bho = locker.id_usr
- INNER JOIN bdms.completness
- ON completness.id_bho = borehole.id_bho
INNER JOIN bdms.users as updater
ON updated_by_bho = updater.id_usr
WHERE
diff --git a/src/api/Migrations/20231211124901_RemoveCompletnessView.Designer.cs b/src/api/Migrations/20231211124901_RemoveCompletnessView.Designer.cs
new file mode 100644
index 000000000..4753476f1
--- /dev/null
+++ b/src/api/Migrations/20231211124901_RemoveCompletnessView.Designer.cs
@@ -0,0 +1,2472 @@
+//
+using System;
+using BDMS;
+using Microsoft.EntityFrameworkCore;
+using Microsoft.EntityFrameworkCore.Infrastructure;
+using Microsoft.EntityFrameworkCore.Migrations;
+using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
+using NetTopologySuite.Geometries;
+using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata;
+
+#nullable disable
+
+namespace BDMS.Migrations
+{
+ [DbContext(typeof(BdmsContext))]
+ [Migration("20231211124901_RemoveCompletnessView")]
+ partial class RemoveCompletnessView
+ {
+ ///
+ protected override void BuildTargetModel(ModelBuilder modelBuilder)
+ {
+#pragma warning disable 612, 618
+ modelBuilder
+ .HasDefaultSchema("bdms")
+ .HasAnnotation("ProductVersion", "8.0.0")
+ .HasAnnotation("Relational:MaxIdentifierLength", 63);
+
+ NpgsqlModelBuilderExtensions.HasPostgresExtension(modelBuilder, "ltree");
+ NpgsqlModelBuilderExtensions.HasPostgresExtension(modelBuilder, "postgis");
+ NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder);
+
+ modelBuilder.Entity("BDMS.Models.Borehole", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id_bho");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("AlternateName")
+ .HasColumnType("text")
+ .HasColumnName("alternate_name_bho");
+
+ b.Property("Canton")
+ .HasColumnType("text")
+ .HasColumnName("canton_bho");
+
+ b.Property("ChronostratigraphyId")
+ .HasColumnType("integer")
+ .HasColumnName("chronostrat_id_cli");
+
+ b.Property("Country")
+ .HasColumnType("text")
+ .HasColumnName("country_bho");
+
+ b.Property("Created")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("created_bho");
+
+ b.Property("CreatedById")
+ .HasColumnType("integer")
+ .HasColumnName("created_by_bho");
+
+ b.Property("CuttingsId")
+ .HasColumnType("integer")
+ .HasColumnName("cuttings_id_cli");
+
+ b.Property("DrillingDate")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("drilling_date_bho");
+
+ b.Property("DrillingDiameter")
+ .HasColumnType("double precision")
+ .HasColumnName("drilling_diameter_bho");
+
+ b.Property("DrillingMethodId")
+ .HasColumnType("integer")
+ .HasColumnName("drilling_method_id_cli");
+
+ b.Property("ElevationZ")
+ .HasColumnType("double precision")
+ .HasColumnName("elevation_z_bho");
+
+ b.Property("Geometry")
+ .HasColumnType("geometry")
+ .HasColumnName("geom_bho");
+
+ b.Property("HasGroundwater")
+ .HasColumnType("boolean")
+ .HasColumnName("groundwater_bho");
+
+ b.Property("HrsId")
+ .HasColumnType("integer")
+ .HasColumnName("hrs_id_cli");
+
+ b.Property("Inclination")
+ .HasColumnType("double precision")
+ .HasColumnName("inclination_bho");
+
+ b.Property("InclinationDirection")
+ .HasColumnType("double precision")
+ .HasColumnName("inclination_direction_bho");
+
+ b.Property("IsPublic")
+ .HasColumnType("boolean")
+ .HasColumnName("public_bho");
+
+ b.Property("KindId")
+ .HasColumnType("integer")
+ .HasColumnName("kind_id_cli");
+
+ b.Property("LithologyTopBedrockId")
+ .HasColumnType("integer")
+ .HasColumnName("lithology_top_bedrock_id_cli");
+
+ b.Property("LithostratigraphyId")
+ .HasColumnType("integer")
+ .HasColumnName("lithostrat_id_cli");
+
+ b.Property("LocationX")
+ .HasColumnType("double precision")
+ .HasColumnName("location_x_bho");
+
+ b.Property("LocationXLV03")
+ .HasColumnType("double precision")
+ .HasColumnName("location_x_lv03_bho");
+
+ b.Property("LocationY")
+ .HasColumnType("double precision")
+ .HasColumnName("location_y_bho");
+
+ b.Property("LocationYLV03")
+ .HasColumnType("double precision")
+ .HasColumnName("location_y_lv03_bho");
+
+ b.Property("Locked")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("locked_bho");
+
+ b.Property("LockedById")
+ .HasColumnType("integer")
+ .HasColumnName("locked_by_bho");
+
+ b.Property("Municipality")
+ .HasColumnType("text")
+ .HasColumnName("municipality_bho");
+
+ b.Property("NationalInterest")
+ .HasColumnType("boolean")
+ .HasColumnName("national_interest");
+
+ b.Property("OriginalName")
+ .HasColumnType("text")
+ .HasColumnName("original_name_bho");
+
+ b.Property("OriginalReferenceSystem")
+ .HasColumnType("integer")
+ .HasColumnName("srs_id_cli");
+
+ b.Property("ProjectName")
+ .HasColumnType("text")
+ .HasColumnName("project_name_bho");
+
+ b.Property("PurposeId")
+ .HasColumnType("integer")
+ .HasColumnName("purpose_id_cli");
+
+ b.Property("QtDepthId")
+ .HasColumnType("integer")
+ .HasColumnName("qt_depth_id_cli");
+
+ b.Property("QtElevationId")
+ .HasColumnType("integer")
+ .HasColumnName("qt_elevation_id_cli");
+
+ b.Property("QtInclinationDirectionId")
+ .HasColumnType("integer")
+ .HasColumnName("qt_inclination_direction_id_cli");
+
+ b.Property("QtLocationId")
+ .HasColumnType("integer")
+ .HasColumnName("qt_location_id_cli");
+
+ b.Property("QtReferenceElevationId")
+ .HasColumnType("integer")
+ .HasColumnName("qt_reference_elevation_id_cli");
+
+ b.Property("QtTopBedrock")
+ .HasColumnType("double precision")
+ .HasColumnName("qt_top_bedrock");
+
+ b.Property("QtTopBedrockTvd")
+ .HasColumnType("double precision")
+ .HasColumnName("qt_top_bedrock_tvd");
+
+ b.Property("QtTotalDepthTvdId")
+ .HasColumnType("integer")
+ .HasColumnName("qt_total_depth_tvd_id_cli");
+
+ b.Property("ReferenceElevation")
+ .HasColumnType("double precision")
+ .HasColumnName("reference_elevation_bho");
+
+ b.Property("ReferenceElevationTypeId")
+ .HasColumnType("integer")
+ .HasColumnName("reference_elevation_type_id_cli");
+
+ b.Property("Remarks")
+ .HasColumnType("text")
+ .HasColumnName("remarks_bho");
+
+ b.Property("RestrictionId")
+ .HasColumnType("integer")
+ .HasColumnName("restriction_id_cli");
+
+ b.Property("RestrictionUntil")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("restriction_until_bho");
+
+ b.Property("SpudDate")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("spud_date_bho");
+
+ b.Property("StatusId")
+ .HasColumnType("integer")
+ .HasColumnName("status_id_cli");
+
+ b.Property("TopBedrock")
+ .HasColumnType("double precision")
+ .HasColumnName("top_bedrock_bho");
+
+ b.Property("TopBedrockTvd")
+ .HasColumnType("double precision")
+ .HasColumnName("top_bedrock_tvd_bho");
+
+ b.Property("TotalDepth")
+ .HasColumnType("double precision")
+ .HasColumnName("total_depth_bho");
+
+ b.Property("TotalDepthTvd")
+ .HasColumnType("double precision")
+ .HasColumnName("total_depth_tvd_bho");
+
+ b.Property("Updated")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("updated_bho");
+
+ b.Property("UpdatedById")
+ .HasColumnType("integer")
+ .HasColumnName("updated_by_bho");
+
+ b.Property("WorkgroupId")
+ .HasColumnType("integer")
+ .HasColumnName("id_wgp_fk");
+
+ b.HasKey("Id");
+
+ b.HasIndex("ChronostratigraphyId");
+
+ b.HasIndex("CreatedById");
+
+ b.HasIndex("CuttingsId");
+
+ b.HasIndex("DrillingMethodId");
+
+ b.HasIndex("HrsId");
+
+ b.HasIndex("KindId");
+
+ b.HasIndex("LithologyTopBedrockId");
+
+ b.HasIndex("LithostratigraphyId");
+
+ b.HasIndex("LockedById");
+
+ b.HasIndex("PurposeId");
+
+ b.HasIndex("QtDepthId");
+
+ b.HasIndex("QtElevationId");
+
+ b.HasIndex("QtInclinationDirectionId");
+
+ b.HasIndex("QtLocationId");
+
+ b.HasIndex("QtReferenceElevationId");
+
+ b.HasIndex("QtTotalDepthTvdId");
+
+ b.HasIndex("ReferenceElevationTypeId");
+
+ b.HasIndex("RestrictionId");
+
+ b.HasIndex("StatusId");
+
+ b.HasIndex("UpdatedById");
+
+ b.HasIndex("WorkgroupId");
+
+ b.ToTable("borehole", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.BoreholeCodelist", b =>
+ {
+ b.Property("BoreholeId")
+ .HasColumnType("integer")
+ .HasColumnName("id_bho_fk");
+
+ b.Property("CodelistId")
+ .HasColumnType("integer")
+ .HasColumnName("id_cli_fk");
+
+ b.Property("SchemaName")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("code_cli");
+
+ b.Property("Value")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("value_bco");
+
+ b.HasKey("BoreholeId", "CodelistId");
+
+ b.HasIndex("CodelistId");
+
+ b.ToTable("borehole_codelist", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.BoreholeFile", b =>
+ {
+ b.Property("BoreholeId")
+ .HasColumnType("integer")
+ .HasColumnName("id_bho_fk");
+
+ b.Property("FileId")
+ .HasColumnType("integer")
+ .HasColumnName("id_fil_fk");
+
+ b.Property("Attached")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("attached_bfi");
+
+ b.Property("Created")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("created_bfi");
+
+ b.Property("CreatedById")
+ .HasColumnType("integer")
+ .HasColumnName("created_by_bfi");
+
+ b.Property("Description")
+ .HasColumnType("text")
+ .HasColumnName("description_bfi");
+
+ b.Property("Public")
+ .HasColumnType("boolean")
+ .HasColumnName("public_bfi");
+
+ b.Property("Updated")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("update_bfi");
+
+ b.Property("UpdatedById")
+ .HasColumnType("integer")
+ .HasColumnName("updater_bfi");
+
+ b.Property("UserId")
+ .HasColumnType("integer")
+ .HasColumnName("id_usr_fk");
+
+ b.HasKey("BoreholeId", "FileId");
+
+ b.HasIndex("CreatedById");
+
+ b.HasIndex("FileId");
+
+ b.HasIndex("UpdatedById");
+
+ b.HasIndex("UserId");
+
+ b.ToTable("borehole_files", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.ChronostratigraphyLayer", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id_chr");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("ChronostratigraphyId")
+ .HasColumnType("integer")
+ .HasColumnName("chronostratigraphy_id");
+
+ b.Property("Created")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("creation");
+
+ b.Property("CreatedById")
+ .HasColumnType("integer")
+ .HasColumnName("creator");
+
+ b.Property("FromDepth")
+ .HasColumnType("double precision")
+ .HasColumnName("depth_from");
+
+ b.Property("IsLast")
+ .HasColumnType("boolean")
+ .HasColumnName("is_last");
+
+ b.Property("StratigraphyId")
+ .HasColumnType("integer")
+ .HasColumnName("id_sty_fk");
+
+ b.Property("ToDepth")
+ .HasColumnType("double precision")
+ .HasColumnName("depth_to");
+
+ b.Property("Updated")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("update");
+
+ b.Property("UpdatedById")
+ .HasColumnType("integer")
+ .HasColumnName("updater");
+
+ b.HasKey("Id");
+
+ b.HasIndex("ChronostratigraphyId");
+
+ b.HasIndex("CreatedById");
+
+ b.HasIndex("StratigraphyId");
+
+ b.HasIndex("UpdatedById");
+
+ b.ToTable("chronostratigraphy", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.Codelist", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id_cli");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("Code")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("code_cli");
+
+ b.Property("Conf")
+ .HasColumnType("text")
+ .HasColumnName("conf_cli");
+
+ b.Property("De")
+ .HasColumnType("text")
+ .HasColumnName("text_cli_de");
+
+ b.Property("DescriptionDe")
+ .HasColumnType("text")
+ .HasColumnName("description_cli_de");
+
+ b.Property("DescriptionEn")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("description_cli_en");
+
+ b.Property("DescriptionFr")
+ .HasColumnType("text")
+ .HasColumnName("description_cli_fr");
+
+ b.Property("DescriptionIt")
+ .HasColumnType("text")
+ .HasColumnName("description_cli_it");
+
+ b.Property("DescriptionRo")
+ .HasColumnType("text")
+ .HasColumnName("description_cli_ro");
+
+ b.Property("En")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("text_cli_en");
+
+ b.Property("Fr")
+ .HasColumnType("text")
+ .HasColumnName("text_cli_fr");
+
+ b.Property("Geolcode")
+ .HasColumnType("integer")
+ .HasColumnName("geolcode");
+
+ b.Property("IsDefault")
+ .HasColumnType("boolean")
+ .HasColumnName("default_cli");
+
+ b.Property("It")
+ .HasColumnType("text")
+ .HasColumnName("text_cli_it");
+
+ b.Property("Order")
+ .HasColumnType("integer")
+ .HasColumnName("order_cli");
+
+ b.Property("Path")
+ .HasColumnType("ltree")
+ .HasColumnName("path_cli");
+
+ b.Property("Ro")
+ .HasColumnType("text")
+ .HasColumnName("text_cli_ro");
+
+ b.Property("Schema")
+ .HasColumnType("text")
+ .HasColumnName("schema_cli");
+
+ b.HasKey("Id");
+
+ b.ToTable("codelist", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.Config", b =>
+ {
+ b.Property("Name")
+ .HasColumnType("text")
+ .HasColumnName("name_cfg");
+
+ b.Property("Value")
+ .HasColumnType("text")
+ .HasColumnName("value_cfg");
+
+ b.HasKey("Name");
+
+ b.ToTable("config", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.Content", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id_cnt");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("Creation")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("creation_cnt");
+
+ b.Property("Expired")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("expired_cnt");
+
+ b.Property("IsDraft")
+ .HasColumnType("boolean")
+ .HasColumnName("draft_cnt");
+
+ b.Property("Name")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("name_cnt");
+
+ b.Property("TextDe")
+ .HasColumnType("text")
+ .HasColumnName("text_cnt_de");
+
+ b.Property("TextEn")
+ .HasColumnType("text")
+ .HasColumnName("text_cnt_en");
+
+ b.Property("TextFr")
+ .HasColumnType("text")
+ .HasColumnName("text_cnt_fr");
+
+ b.Property("TextIt")
+ .HasColumnType("text")
+ .HasColumnName("text_cnt_it");
+
+ b.Property("TextRo")
+ .HasColumnType("text")
+ .HasColumnName("text_cnt_ro");
+
+ b.Property("TitelRo")
+ .HasColumnType("text")
+ .HasColumnName("title_cnt_ro");
+
+ b.Property("TitleDe")
+ .HasColumnType("text")
+ .HasColumnName("title_cnt_de");
+
+ b.Property("TitleEn")
+ .HasColumnType("text")
+ .HasColumnName("title_cnt_en");
+
+ b.Property("TitleFr")
+ .HasColumnType("text")
+ .HasColumnName("title_cnt_fr");
+
+ b.Property("TitleIt")
+ .HasColumnType("text")
+ .HasColumnName("title_cnt_it");
+
+ b.HasKey("Id");
+
+ b.ToTable("contents", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.FaciesDescription", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id_fac");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("Created")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("creation");
+
+ b.Property("CreatedById")
+ .HasColumnType("integer")
+ .HasColumnName("creator");
+
+ b.Property("Description")
+ .HasColumnType("text")
+ .HasColumnName("description");
+
+ b.Property("FromDepth")
+ .HasColumnType("double precision")
+ .HasColumnName("depth_from");
+
+ b.Property("IsLast")
+ .HasColumnType("boolean")
+ .HasColumnName("is_last");
+
+ b.Property("QtDescriptionId")
+ .HasColumnType("integer")
+ .HasColumnName("qt_description_id");
+
+ b.Property("StratigraphyId")
+ .HasColumnType("integer")
+ .HasColumnName("id_sty_fk");
+
+ b.Property("ToDepth")
+ .HasColumnType("double precision")
+ .HasColumnName("depth_to");
+
+ b.Property("Updated")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("update");
+
+ b.Property("UpdatedById")
+ .HasColumnType("integer")
+ .HasColumnName("updater");
+
+ b.HasKey("Id");
+
+ b.HasIndex("CreatedById");
+
+ b.HasIndex("QtDescriptionId");
+
+ b.HasIndex("StratigraphyId");
+
+ b.HasIndex("UpdatedById");
+
+ b.ToTable("facies_description", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.Feedback", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id_feb");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("Created")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("created_feb");
+
+ b.Property("IsFrw")
+ .HasColumnType("boolean")
+ .HasColumnName("frw_feb");
+
+ b.Property("Message")
+ .HasColumnType("text")
+ .HasColumnName("message_feb");
+
+ b.Property("Tag")
+ .HasColumnType("text")
+ .HasColumnName("tag_feb");
+
+ b.Property("User")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("user_feb");
+
+ b.HasKey("Id");
+
+ b.ToTable("feedbacks", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.File", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id_fil");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("Created")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("uploaded_fil");
+
+ b.Property("CreatedById")
+ .HasColumnType("integer")
+ .HasColumnName("id_usr_fk");
+
+ b.Property("Hash")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("hash_fil");
+
+ b.Property("Name")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("name_fil");
+
+ b.Property("NameUuid")
+ .HasColumnType("text")
+ .HasColumnName("name_uuid_fil");
+
+ b.Property("Type")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("type_fil");
+
+ b.Property("Updated")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("updated_fil");
+
+ b.Property("UpdatedById")
+ .HasColumnType("integer")
+ .HasColumnName("updated_by_fil");
+
+ b.HasKey("Id");
+
+ b.HasIndex("CreatedById");
+
+ b.HasIndex("UpdatedById");
+
+ b.ToTable("files", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.HydrotestCodelist", b =>
+ {
+ b.Property("HydrotestId")
+ .HasColumnType("integer")
+ .HasColumnName("id_ht_fk");
+
+ b.Property("CodelistId")
+ .HasColumnType("integer")
+ .HasColumnName("id_cli_fk");
+
+ b.HasKey("HydrotestId", "CodelistId");
+
+ b.HasIndex("CodelistId");
+
+ b.ToTable("hydrotest_codelist", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.HydrotestResult", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("Created")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("creation");
+
+ b.Property("CreatedById")
+ .HasColumnType("integer")
+ .HasColumnName("creator");
+
+ b.Property("HydrotestId")
+ .HasColumnType("integer")
+ .HasColumnName("hydrotest_id");
+
+ b.Property("MaxValue")
+ .HasColumnType("double precision")
+ .HasColumnName("max_value");
+
+ b.Property("MinValue")
+ .HasColumnType("double precision")
+ .HasColumnName("min_value");
+
+ b.Property("ParameterId")
+ .HasColumnType("integer")
+ .HasColumnName("parameter");
+
+ b.Property("Updated")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("update");
+
+ b.Property("UpdatedById")
+ .HasColumnType("integer")
+ .HasColumnName("updater");
+
+ b.Property("Value")
+ .HasColumnType("double precision")
+ .HasColumnName("value");
+
+ b.HasKey("Id");
+
+ b.HasIndex("CreatedById");
+
+ b.HasIndex("HydrotestId");
+
+ b.HasIndex("ParameterId");
+
+ b.HasIndex("UpdatedById");
+
+ b.ToTable("hydrotest_result", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.Layer", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id_lay");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("AlterationId")
+ .HasColumnType("integer")
+ .HasColumnName("alteration_id_cli");
+
+ b.Property("Casing")
+ .HasColumnType("text")
+ .HasColumnName("casng_id");
+
+ b.Property("CasingDateFinish")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("casng_date_finish_lay");
+
+ b.Property("CasingDateSpud")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("casng_date_spud_lay");
+
+ b.Property("CasingInnerDiameter")
+ .HasColumnType("double precision")
+ .HasColumnName("casng_inner_diameter_lay");
+
+ b.Property("CasingKindId")
+ .HasColumnType("integer")
+ .HasColumnName("casng_kind_id_cli");
+
+ b.Property("CasingMaterialId")
+ .HasColumnType("integer")
+ .HasColumnName("casng_material_id_cli");
+
+ b.Property("CasingOuterDiameter")
+ .HasColumnType("double precision")
+ .HasColumnName("casng_outer_diameter_lay");
+
+ b.Property("CohesionId")
+ .HasColumnType("integer")
+ .HasColumnName("cohesion_id_cli");
+
+ b.Property("CompactnessId")
+ .HasColumnType("integer")
+ .HasColumnName("compactness_id_cli");
+
+ b.Property("ConsistanceId")
+ .HasColumnType("integer")
+ .HasColumnName("consistance_id_cli");
+
+ b.Property("Created")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("creation_lay");
+
+ b.Property("CreatedById")
+ .HasColumnType("integer")
+ .HasColumnName("creator_lay");
+
+ b.Property("FillKindId")
+ .HasColumnType("integer")
+ .HasColumnName("fill_kind_id_cli");
+
+ b.Property("FillMaterialId")
+ .HasColumnType("integer")
+ .HasColumnName("fill_material_id_cli");
+
+ b.Property("FromDepth")
+ .HasColumnType("double precision")
+ .HasColumnName("depth_from_lay");
+
+ b.Property("GradationId")
+ .HasColumnType("integer")
+ .HasColumnName("gradation_id_cli");
+
+ b.Property("GrainSize1Id")
+ .HasColumnType("integer")
+ .HasColumnName("grain_size_1_id_cli");
+
+ b.Property("GrainSize2Id")
+ .HasColumnType("integer")
+ .HasColumnName("grain_size_2_id_cli");
+
+ b.Property("HumidityId")
+ .HasColumnType("integer")
+ .HasColumnName("humidity_id_cli");
+
+ b.Property("Instrument")
+ .HasColumnType("text")
+ .HasColumnName("instr_id");
+
+ b.Property("InstrumentCasingId")
+ .HasColumnType("integer")
+ .HasColumnName("instr_id_sty_fk");
+
+ b.Property("InstrumentCasingLayerId")
+ .HasColumnType("integer")
+ .HasColumnName("instr_id_lay_fk");
+
+ b.Property("InstrumentKindId")
+ .HasColumnType("integer")
+ .HasColumnName("instr_kind_id_cli");
+
+ b.Property("InstrumentStatusId")
+ .HasColumnType("integer")
+ .HasColumnName("instr_status_id_cli");
+
+ b.Property("IsLast")
+ .HasColumnType("boolean")
+ .HasColumnName("last_lay");
+
+ b.Property("IsStriae")
+ .HasColumnType("boolean")
+ .HasColumnName("striae_lay");
+
+ b.Property("IsUndefined")
+ .HasColumnType("boolean")
+ .HasColumnName("undefined_lay");
+
+ b.Property("LithologyId")
+ .HasColumnType("integer")
+ .HasColumnName("lithology_id_cli");
+
+ b.Property("LithologyTopBedrockId")
+ .HasColumnType("integer")
+ .HasColumnName("lithology_top_bedrock_id_cli");
+
+ b.Property("LithostratigraphyId")
+ .HasColumnType("integer")
+ .HasColumnName("lithostratigraphy_id_cli");
+
+ b.Property("Notes")
+ .HasColumnType("text")
+ .HasColumnName("notes_lay");
+
+ b.Property("OriginalLithology")
+ .HasColumnType("text")
+ .HasColumnName("original_lithology");
+
+ b.Property("OriginalUscs")
+ .HasColumnType("text")
+ .HasColumnName("uscs_original_lay");
+
+ b.Property("PlasticityId")
+ .HasColumnType("integer")
+ .HasColumnName("plasticity_id_cli");
+
+ b.Property("QtDescriptionId")
+ .HasColumnType("integer")
+ .HasColumnName("qt_description_id_cli");
+
+ b.Property("StratigraphyId")
+ .HasColumnType("integer")
+ .HasColumnName("id_sty_fk");
+
+ b.Property("ToDepth")
+ .HasColumnType("double precision")
+ .HasColumnName("depth_to_lay");
+
+ b.Property("Updated")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("update_lay");
+
+ b.Property("UpdatedById")
+ .HasColumnType("integer")
+ .HasColumnName("updater_lay");
+
+ b.Property("Uscs1Id")
+ .HasColumnType("integer")
+ .HasColumnName("uscs_1_id_cli");
+
+ b.Property("Uscs2Id")
+ .HasColumnType("integer")
+ .HasColumnName("uscs_2_id_cli");
+
+ b.Property("UscsDeterminationId")
+ .HasColumnType("integer")
+ .HasColumnName("uscs_determination_id_cli");
+
+ b.HasKey("Id");
+
+ b.HasIndex("AlterationId");
+
+ b.HasIndex("CasingKindId");
+
+ b.HasIndex("CasingMaterialId");
+
+ b.HasIndex("CohesionId");
+
+ b.HasIndex("CompactnessId");
+
+ b.HasIndex("ConsistanceId");
+
+ b.HasIndex("CreatedById");
+
+ b.HasIndex("FillKindId");
+
+ b.HasIndex("FillMaterialId");
+
+ b.HasIndex("GradationId");
+
+ b.HasIndex("GrainSize1Id");
+
+ b.HasIndex("GrainSize2Id");
+
+ b.HasIndex("HumidityId");
+
+ b.HasIndex("InstrumentCasingId");
+
+ b.HasIndex("InstrumentKindId");
+
+ b.HasIndex("InstrumentStatusId");
+
+ b.HasIndex("LithologyId");
+
+ b.HasIndex("LithologyTopBedrockId");
+
+ b.HasIndex("LithostratigraphyId");
+
+ b.HasIndex("PlasticityId");
+
+ b.HasIndex("QtDescriptionId");
+
+ b.HasIndex("StratigraphyId");
+
+ b.HasIndex("UpdatedById");
+
+ b.HasIndex("Uscs1Id");
+
+ b.HasIndex("Uscs2Id");
+
+ b.HasIndex("UscsDeterminationId");
+
+ b.ToTable("layer", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.LayerCodelist", b =>
+ {
+ b.Property("LayerId")
+ .HasColumnType("integer")
+ .HasColumnName("id_lay_fk");
+
+ b.Property("CodelistId")
+ .HasColumnType("integer")
+ .HasColumnName("id_cli_fk");
+
+ b.Property("SchemaName")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("code_cli");
+
+ b.HasKey("LayerId", "CodelistId");
+
+ b.HasIndex("CodelistId");
+
+ b.ToTable("layer_codelist", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.LithologicalDescription", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id_ldp");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("Created")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("creation");
+
+ b.Property("CreatedById")
+ .HasColumnType("integer")
+ .HasColumnName("creator");
+
+ b.Property("Description")
+ .HasColumnType("text")
+ .HasColumnName("description");
+
+ b.Property("FromDepth")
+ .HasColumnType("double precision")
+ .HasColumnName("depth_from");
+
+ b.Property("IsLast")
+ .HasColumnType("boolean")
+ .HasColumnName("is_last");
+
+ b.Property("QtDescriptionId")
+ .HasColumnType("integer")
+ .HasColumnName("qt_description_id");
+
+ b.Property("StratigraphyId")
+ .HasColumnType("integer")
+ .HasColumnName("id_sty_fk");
+
+ b.Property("ToDepth")
+ .HasColumnType("double precision")
+ .HasColumnName("depth_to");
+
+ b.Property("Updated")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("update");
+
+ b.Property("UpdatedById")
+ .HasColumnType("integer")
+ .HasColumnName("updater");
+
+ b.HasKey("Id");
+
+ b.HasIndex("CreatedById");
+
+ b.HasIndex("QtDescriptionId");
+
+ b.HasIndex("StratigraphyId");
+
+ b.HasIndex("UpdatedById");
+
+ b.ToTable("lithological_description", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.LithostratigraphyLayer", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("Created")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("creation");
+
+ b.Property("CreatedById")
+ .HasColumnType("integer")
+ .HasColumnName("creator");
+
+ b.Property("FromDepth")
+ .HasColumnType("double precision")
+ .HasColumnName("depth_from");
+
+ b.Property("IsLast")
+ .HasColumnType("boolean")
+ .HasColumnName("is_last");
+
+ b.Property("LithostratigraphyId")
+ .HasColumnType("integer")
+ .HasColumnName("lithostratigraphy_id");
+
+ b.Property("StratigraphyId")
+ .HasColumnType("integer")
+ .HasColumnName("stratigraphy_id");
+
+ b.Property("ToDepth")
+ .HasColumnType("double precision")
+ .HasColumnName("depth_to");
+
+ b.Property("Updated")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("update");
+
+ b.Property("UpdatedById")
+ .HasColumnType("integer")
+ .HasColumnName("updater");
+
+ b.HasKey("Id");
+
+ b.HasIndex("CreatedById");
+
+ b.HasIndex("LithostratigraphyId");
+
+ b.HasIndex("StratigraphyId");
+
+ b.HasIndex("UpdatedById");
+
+ b.ToTable("lithostratigraphy", "bdms");
+ });
+
+ modelBuilder.Entity("BDMS.Models.Observation", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("BoreholeId")
+ .HasColumnType("integer")
+ .HasColumnName("borehole_id");
+
+ b.Property("CasingId")
+ .HasColumnType("integer")
+ .HasColumnName("casing");
+
+ b.Property("Comment")
+ .HasColumnType("text")
+ .HasColumnName("comment");
+
+ b.Property("CompletionFinished")
+ .HasColumnType("boolean")
+ .HasColumnName("completion_finished");
+
+ b.Property("Created")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("creation");
+
+ b.Property("CreatedById")
+ .HasColumnType("integer")
+ .HasColumnName("creator");
+
+ b.Property("Duration")
+ .HasColumnType("double precision")
+ .HasColumnName("duration");
+
+ b.Property("EndTime")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("end_time");
+
+ b.Property("FromDepthM")
+ .HasColumnType("double precision")
+ .HasColumnName("from_depth_m");
+
+ b.Property("FromDepthMasl")
+ .HasColumnType("double precision")
+ .HasColumnName("from_depth_masl");
+
+ b.Property("ReliabilityId")
+ .HasColumnType("integer")
+ .HasColumnName("reliability");
+
+ b.Property("StartTime")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("start_time");
+
+ b.Property("ToDepthM")
+ .HasColumnType("double precision")
+ .HasColumnName("to_depth_m");
+
+ b.Property("ToDepthMasl")
+ .HasColumnType("double precision")
+ .HasColumnName("to_depth_masl");
+
+ b.Property("Type")
+ .HasColumnType("integer")
+ .HasColumnName("observation_type");
+
+ b.Property("Updated")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("update");
+
+ b.Property("UpdatedById")
+ .HasColumnType("integer")
+ .HasColumnName("updater");
+
+ b.HasKey("Id");
+
+ b.HasIndex("BoreholeId");
+
+ b.HasIndex("CasingId");
+
+ b.HasIndex("CreatedById");
+
+ b.HasIndex("ReliabilityId");
+
+ b.HasIndex("UpdatedById");
+
+ b.ToTable("observation", "bdms");
+
+ b.UseTptMappingStrategy();
+ });
+
+ modelBuilder.Entity("BDMS.Models.Stratigraphy", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .HasColumnName("id_sty");
+
+ NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
+
+ b.Property("BoreholeId")
+ .HasColumnType("integer")
+ .HasColumnName("id_bho_fk");
+
+ b.Property("Casing")
+ .HasColumnType("text")
+ .HasColumnName("casng_id");
+
+ b.Property