Merge pull request #1861 from sbwalker/dev
added support for url mapping and viitors
This commit is contained in:
@ -0,0 +1,51 @@
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
using Microsoft.EntityFrameworkCore.Migrations.Operations;
|
||||
using Microsoft.EntityFrameworkCore.Migrations.Operations.Builders;
|
||||
using Oqtane.Databases.Interfaces;
|
||||
|
||||
// ReSharper disable MemberCanBePrivate.Global
|
||||
// ReSharper disable UnusedAutoPropertyAccessor.Global
|
||||
|
||||
namespace Oqtane.Migrations.EntityBuilders
|
||||
{
|
||||
public class UrlMappingEntityBuilder : BaseEntityBuilder<UrlMappingEntityBuilder>
|
||||
{
|
||||
private const string _entityTableName = "UrlMapping";
|
||||
private readonly PrimaryKey<UrlMappingEntityBuilder> _primaryKey = new("PK_UrlMapping", x => x.UrlMappingId);
|
||||
private readonly ForeignKey<UrlMappingEntityBuilder> _urlMappingForeignKey = new("FK_UrlMapping_Site", x => x.SiteId, "Site", "SiteId", ReferentialAction.Cascade);
|
||||
|
||||
public UrlMappingEntityBuilder(MigrationBuilder migrationBuilder, IDatabase database) : base(migrationBuilder, database)
|
||||
{
|
||||
EntityTableName = _entityTableName;
|
||||
PrimaryKey = _primaryKey;
|
||||
ForeignKeys.Add(_urlMappingForeignKey);
|
||||
}
|
||||
|
||||
protected override UrlMappingEntityBuilder BuildTable(ColumnsBuilder table)
|
||||
{
|
||||
UrlMappingId = AddAutoIncrementColumn(table, "UrlMappingId");
|
||||
SiteId = AddIntegerColumn(table, "SiteId");
|
||||
Url = AddStringColumn(table, "Url", 500);
|
||||
MappedUrl = AddStringColumn(table, "MappedUrl", 500);
|
||||
Requests = AddIntegerColumn(table, "Requests");
|
||||
CreatedOn = AddDateTimeColumn(table, "CreatedOn");
|
||||
RequestedOn = AddDateTimeColumn(table, "RequestedOn");
|
||||
|
||||
return this;
|
||||
}
|
||||
|
||||
public OperationBuilder<AddColumnOperation> UrlMappingId { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> SiteId { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> Url { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> MappedUrl { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> Requests { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> CreatedOn { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> RequestedOn { get; private set; }
|
||||
}
|
||||
}
|
@ -0,0 +1,57 @@
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
using Microsoft.EntityFrameworkCore.Migrations.Operations;
|
||||
using Microsoft.EntityFrameworkCore.Migrations.Operations.Builders;
|
||||
using Oqtane.Databases.Interfaces;
|
||||
|
||||
// ReSharper disable MemberCanBePrivate.Global
|
||||
// ReSharper disable UnusedAutoPropertyAccessor.Global
|
||||
|
||||
namespace Oqtane.Migrations.EntityBuilders
|
||||
{
|
||||
public class VisitorEntityBuilder : BaseEntityBuilder<VisitorEntityBuilder>
|
||||
{
|
||||
private const string _entityTableName = "Visitor";
|
||||
private readonly PrimaryKey<VisitorEntityBuilder> _primaryKey = new("PK_Visitor", x => x.VisitorId);
|
||||
private readonly ForeignKey<VisitorEntityBuilder> _visitorForeignKey = new("FK_Visitor_Site", x => x.SiteId, "Site", "SiteId", ReferentialAction.Cascade);
|
||||
|
||||
public VisitorEntityBuilder(MigrationBuilder migrationBuilder, IDatabase database) : base(migrationBuilder, database)
|
||||
{
|
||||
EntityTableName = _entityTableName;
|
||||
PrimaryKey = _primaryKey;
|
||||
ForeignKeys.Add(_visitorForeignKey);
|
||||
}
|
||||
|
||||
protected override VisitorEntityBuilder BuildTable(ColumnsBuilder table)
|
||||
{
|
||||
VisitorId = AddAutoIncrementColumn(table, "VisitorId");
|
||||
SiteId = AddIntegerColumn(table, "SiteId");
|
||||
UserId = AddIntegerColumn(table, "UserId", true);
|
||||
Visits = AddIntegerColumn(table, "Visits");
|
||||
IPAddress = AddStringColumn(table,"IPAddress", 50);
|
||||
UserAgent = AddStringColumn(table, "UserAgent", 256);
|
||||
Language = AddStringColumn(table, "Language", 50);
|
||||
CreatedOn = AddDateTimeColumn(table, "CreatedOn");
|
||||
VisitedOn = AddDateTimeColumn(table, "VisitedOn");
|
||||
|
||||
return this;
|
||||
}
|
||||
|
||||
public OperationBuilder<AddColumnOperation> VisitorId { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> SiteId { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> UserId { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> Visits { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> IPAddress { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> UserAgent { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> Language { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> CreatedOn { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> VisitedOn { get; private set; }
|
||||
}
|
||||
}
|
29
Oqtane.Server/Migrations/Tenant/03000102_AddVisitorTable.cs
Normal file
29
Oqtane.Server/Migrations/Tenant/03000102_AddVisitorTable.cs
Normal file
@ -0,0 +1,29 @@
|
||||
using Microsoft.EntityFrameworkCore.Infrastructure;
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
using Oqtane.Databases.Interfaces;
|
||||
using Oqtane.Migrations.EntityBuilders;
|
||||
using Oqtane.Repository;
|
||||
|
||||
namespace Oqtane.Migrations.Tenant
|
||||
{
|
||||
[DbContext(typeof(TenantDBContext))]
|
||||
[Migration("Tenant.03.00.01.02")]
|
||||
public class AddVisitorTable : MultiDatabaseMigration
|
||||
{
|
||||
public AddVisitorTable(IDatabase database) : base(database)
|
||||
{
|
||||
}
|
||||
|
||||
protected override void Up(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
var visitorEntityBuilder = new VisitorEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
visitorEntityBuilder.Create();
|
||||
}
|
||||
|
||||
protected override void Down(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
var visitorEntityBuilder = new VisitorEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
visitorEntityBuilder.Drop();
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,30 @@
|
||||
using Microsoft.EntityFrameworkCore.Infrastructure;
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
using Oqtane.Databases.Interfaces;
|
||||
using Oqtane.Migrations.EntityBuilders;
|
||||
using Oqtane.Repository;
|
||||
|
||||
namespace Oqtane.Migrations.Tenant
|
||||
{
|
||||
[DbContext(typeof(TenantDBContext))]
|
||||
[Migration("Tenant.03.00.01.03")]
|
||||
public class AddUrlMappingTable : MultiDatabaseMigration
|
||||
{
|
||||
public AddUrlMappingTable(IDatabase database) : base(database)
|
||||
{
|
||||
}
|
||||
|
||||
protected override void Up(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
var urlMappingEntityBuilder = new UrlMappingEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
urlMappingEntityBuilder.Create();
|
||||
urlMappingEntityBuilder.AddIndex("IX_UrlMapping", new[] { "SiteId", "Url" }, true);
|
||||
}
|
||||
|
||||
protected override void Down(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
var urlMappingEntityBuilder = new UrlMappingEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
urlMappingEntityBuilder.Drop();
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,35 @@
|
||||
using Microsoft.EntityFrameworkCore.Infrastructure;
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
using Oqtane.Databases.Interfaces;
|
||||
using Oqtane.Migrations.EntityBuilders;
|
||||
using Oqtane.Repository;
|
||||
|
||||
namespace Oqtane.Migrations.Tenant
|
||||
{
|
||||
[DbContext(typeof(TenantDBContext))]
|
||||
[Migration("Tenant.03.00.01.04")]
|
||||
public class AddSiteVisitorTracking : MultiDatabaseMigration
|
||||
{
|
||||
public AddSiteVisitorTracking(IDatabase database) : base(database)
|
||||
{
|
||||
}
|
||||
|
||||
protected override void Up(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
var siteEntityBuilder = new SiteEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
|
||||
siteEntityBuilder.AddBooleanColumn("VisitorTracking", true);
|
||||
siteEntityBuilder.UpdateColumn("VisitorTracking", "1", "bool", "");
|
||||
siteEntityBuilder.AddBooleanColumn("CaptureBrokenUrls", true);
|
||||
siteEntityBuilder.UpdateColumn("CaptureBrokenUrls", "1", "bool", "");
|
||||
}
|
||||
|
||||
protected override void Down(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
var siteEntityBuilder = new SiteEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
|
||||
siteEntityBuilder.DropColumn("VisitorTracking");
|
||||
siteEntityBuilder.DropColumn("CaptureBrokenUrls");
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user