Browse Source

fix: remove the unique constraint for foreign keys

pull/532/head
cKey 4 years ago
parent
commit
68009f37ab
  1. 2
      aspnet-core/modules/webhooks/LINGYUN.Abp.WebHooks/LINGYUN.Abp.WebHooks.csproj
  2. 28
      aspnet-core/modules/webhooks/LINGYUN.Abp.WebHooks/LINGYUN/Abp/Webhooks/AbpWebhooksModule.cs
  3. 8
      aspnet-core/modules/webhooks/LINGYUN.Abp.WebHooks/LINGYUN/Abp/Webhooks/DefaultWebhookPublisher.cs
  4. 3
      aspnet-core/modules/webhooks/LINGYUN.Abp.WebHooks/LINGYUN/Abp/Webhooks/DefaultWebhookSender.cs
  5. 3
      aspnet-core/modules/webhooks/LINGYUN.Abp.WebHooks/LINGYUN/Abp/Webhooks/WebhookSubscriptionManager.cs
  6. 4
      aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.Domain.Shared/LINGYUN/Abp/WebhooksManagement/Localization/Resources/en.json
  7. 4
      aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.Domain.Shared/LINGYUN/Abp/WebhooksManagement/Localization/Resources/zh-Hans.json
  8. 36
      aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.Domain/LINGYUN/Abp/WebhooksManagement/DefaultWebhookManager.cs
  9. 25
      aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.Domain/LINGYUN/Abp/WebhooksManagement/WebhookSubscriptionsStore.cs
  10. 22
      aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.Domain/LINGYUN/Abp/WebhooksManagement/Webhooks/WebhooksDefinitionProvider.cs
  11. 6
      aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.Domain/LINGYUN/Abp/WebhooksManagement/Webhooks/WebhooksNames.cs
  12. 3
      aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.EntityFrameworkCore/LINGYUN/Abp/WebhooksManagement/EntityFrameworkCore/WebhooksManagementDbContextModelCreatingExtensions.cs
  13. 5
      aspnet-core/services/LY.MicroService.WebhooksManagement.HttpApi.Host/Migrations/20220326064231_Add-Module-WebHooks-Management.Designer.cs
  14. 3
      aspnet-core/services/LY.MicroService.WebhooksManagement.HttpApi.Host/Migrations/20220326064231_Add-Module-WebHooks-Management.cs
  15. 3
      aspnet-core/services/LY.MicroService.WebhooksManagement.HttpApi.Host/Migrations/WebhooksManagementMigrationsDbContextModelSnapshot.cs
  16. 7
      aspnet-core/services/LY.MicroService.WebhooksManagement.HttpApi.Host/WebhooksManagementHttpApiHostModule.Configure.cs
  17. 2
      aspnet-core/services/LY.MicroService.WebhooksManagement.HttpApi.Host/WebhooksManagementHttpApiHostModule.cs

2
aspnet-core/modules/webhooks/LINGYUN.Abp.WebHooks/LINGYUN.Abp.WebHooks.csproj

@ -9,7 +9,7 @@
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Volo.Abp.BackgroundJobs.Abstractions" Version="$(VoloAbpPackageVersion)" />
<PackageReference Include="Volo.Abp.BackgroundJobs" Version="$(VoloAbpPackageVersion)" />
<PackageReference Include="Volo.Abp.Features" Version="$(VoloAbpPackageVersion)" />
<PackageReference Include="Volo.Abp.Guids" Version="$(VoloAbpPackageVersion)" />
<PackageReference Include="Volo.Abp.Http.Client" Version="$(VoloAbpPackageVersion)" />

28
aspnet-core/modules/webhooks/LINGYUN.Abp.WebHooks/LINGYUN/Abp/Webhooks/AbpWebhooksModule.cs

@ -1,4 +1,7 @@
using Volo.Abp.BackgroundJobs;
using Microsoft.Extensions.DependencyInjection;
using System;
using System.Collections.Generic;
using Volo.Abp.BackgroundJobs;
using Volo.Abp.Features;
using Volo.Abp.Guids;
using Volo.Abp.Http.Client;
@ -6,7 +9,9 @@ using Volo.Abp.Modularity;
namespace LINGYUN.Abp.Webhooks;
[DependsOn(typeof(AbpBackgroundJobsAbstractionsModule))]
//[DependsOn(typeof(AbpBackgroundJobsAbstractionsModule))]
// 防止未引用实现无法发布到后台作业
[DependsOn(typeof(AbpBackgroundJobsModule))]
[DependsOn(typeof(AbpFeaturesModule))]
[DependsOn(typeof(AbpGuidsModule))]
[DependsOn(typeof(AbpHttpClientModule))]
@ -14,5 +19,24 @@ public class AbpWebhooksModule : AbpModule
{
public override void PreConfigureServices(ServiceConfigurationContext context)
{
AutoAddDefinitionProviders(context.Services);
}
private static void AutoAddDefinitionProviders(IServiceCollection services)
{
var definitionProviders = new List<Type>();
services.OnRegistred(context =>
{
if (typeof(WebhookDefinitionProvider).IsAssignableFrom(context.ImplementationType))
{
definitionProviders.Add(context.ImplementationType);
}
});
services.Configure<AbpWebhooksOptions>(options =>
{
options.DefinitionProviders.AddIfNotContains(definitionProviders);
});
}
}

8
aspnet-core/modules/webhooks/LINGYUN.Abp.WebHooks/LINGYUN/Abp/Webhooks/DefaultWebhookPublisher.cs

@ -6,10 +6,11 @@ using System.Threading.Tasks;
using Volo.Abp.BackgroundJobs;
using Volo.Abp.Guids;
using Volo.Abp.MultiTenancy;
using Volo.Abp.DependencyInjection;
namespace LINGYUN.Abp.Webhooks
{
public class DefaultWebhookPublisher : IWebhookPublisher
public class DefaultWebhookPublisher : IWebhookPublisher, ITransientDependency
{
public IWebhookEventStore WebhookEventStore { get; set; }
@ -128,13 +129,14 @@ namespace LINGYUN.Abp.Webhooks
{
var webhookInfo = new WebhookEvent
{
Id = _guidGenerator.Create(),
WebhookName = webhookName,
Data = JsonConvert.SerializeObject(data),
TenantId = tenantId
};
await WebhookEventStore.InsertAndGetIdAsync(webhookInfo);
var webhookId = await WebhookEventStore.InsertAndGetIdAsync(webhookInfo);
webhookInfo.Id = webhookId;
return webhookInfo;
}
}

3
aspnet-core/modules/webhooks/LINGYUN.Abp.WebHooks/LINGYUN/Abp/Webhooks/DefaultWebhookSender.cs

@ -5,10 +5,11 @@ using System;
using System.Net;
using System.Net.Http;
using System.Threading.Tasks;
using Volo.Abp.DependencyInjection;
namespace LINGYUN.Abp.Webhooks
{
public class DefaultWebhookSender : IWebhookSender
public class DefaultWebhookSender : IWebhookSender, ITransientDependency
{
public ILogger<DefaultWebhookSender> Logger { protected get; set; }

3
aspnet-core/modules/webhooks/LINGYUN.Abp.WebHooks/LINGYUN/Abp/Webhooks/WebhookSubscriptionManager.cs

@ -3,12 +3,13 @@ using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Volo.Abp.Authorization;
using Volo.Abp.DependencyInjection;
using Volo.Abp.Guids;
using Volo.Abp.Uow;
namespace LINGYUN.Abp.Webhooks
{
public class WebhookSubscriptionManager : IWebhookSubscriptionManager
public class WebhookSubscriptionManager : IWebhookSubscriptionManager, ITransientDependency
{
public IWebhookSubscriptionsStore WebhookSubscriptionsStore { get; set; }

4
aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.Domain.Shared/LINGYUN/Abp/WebhooksManagement/Localization/Resources/en.json

@ -3,6 +3,8 @@
"texts": {
"Features:WebhooksManagement": "Webhooks",
"Permission:WebhooksManagement": "Webhooks",
"Permission:ManageSettings": "Manage Settings"
"Permission:ManageSettings": "Manage Settings",
"DisplayName:CheckConnect": "Check Connect",
"Description:CheckConnect": "When a third-party service is connected, it is used to check whether the communication is normal."
}
}

4
aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.Domain.Shared/LINGYUN/Abp/WebhooksManagement/Localization/Resources/zh-Hans.json

@ -3,6 +3,8 @@
"texts": {
"Features:WebhooksManagement": "Webhooks",
"Permission:WebhooksManagement": "Webhooks",
"Permission:ManageSettings": "管理设置"
"Permission:ManageSettings": "管理设置",
"DisplayName:CheckConnect": "检查连接",
"Description:CheckConnect": "第三方服务接入时,用于检查是否通讯正常."
}
}

36
aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.Domain/LINGYUN/Abp/WebhooksManagement/DefaultWebhookManager.cs

@ -29,40 +29,32 @@ public class DefaultWebhookManager : WebhookManager, ITransientDependency
WebhookSendAttemptRepository = webhookSendAttemptRepository;
}
[UnitOfWork]
public async override Task<Guid> InsertAndGetIdWebhookSendAttemptAsync(WebhookSenderArgs webhookSenderArgs)
{
using (var uow = UnitOfWorkManager.Begin())
using (CurrentTenant.Change(webhookSenderArgs.TenantId))
{
using (CurrentTenant.Change(webhookSenderArgs.TenantId))
{
var record = new WebhookSendRecord(
GuidGenerator.Create(),
webhookSenderArgs.WebhookEventId,
webhookSenderArgs.WebhookSubscriptionId,
webhookSenderArgs.TenantId);
var record = new WebhookSendRecord(
GuidGenerator.Create(),
webhookSenderArgs.WebhookEventId,
webhookSenderArgs.WebhookSubscriptionId,
webhookSenderArgs.TenantId);
await WebhookSendAttemptRepository.InsertAsync(record);
await WebhookSendAttemptRepository.InsertAsync(record);
await uow.SaveChangesAsync();
return record.Id;
}
return record.Id;
}
}
[UnitOfWork]
public async override Task StoreResponseOnWebhookSendAttemptAsync(Guid webhookSendAttemptId, Guid? tenantId, HttpStatusCode? statusCode, string content)
{
using (var uow = UnitOfWorkManager.Begin())
using (CurrentTenant.Change(tenantId))
{
using (CurrentTenant.Change(tenantId))
{
var record = await WebhookSendAttemptRepository.GetAsync(webhookSendAttemptId);
record.SetResponse(content, statusCode);
await WebhookSendAttemptRepository.UpdateAsync(record);
var record = await WebhookSendAttemptRepository.GetAsync(webhookSendAttemptId);
record.SetResponse(content, statusCode);
await uow.SaveChangesAsync();
}
await WebhookSendAttemptRepository.UpdateAsync(record);
}
}
}

25
aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.Domain/LINGYUN/Abp/WebhooksManagement/WebhookSubscriptionsStore.cs

@ -36,7 +36,9 @@ public class WebhookSubscriptionsStore : DomainService, IWebhookSubscriptionsSto
{
var queryable = await SubscriptionRepository.GetQueryableAsync();
var subscriptions = await AsyncExecuter.ToListAsync(queryable.Where(x => x.TenantId == tenantId));
queryable = queryable.Where(x => x.TenantId == tenantId);
var subscriptions = await AsyncExecuter.ToListAsync(queryable);
return subscriptions.Select(subscription => subscription.ToWebhookSubscriptionInfo()).ToList();
}
@ -49,11 +51,12 @@ public class WebhookSubscriptionsStore : DomainService, IWebhookSubscriptionsSto
{
var queryable = await SubscriptionRepository.GetQueryableAsync();
var subscriptions = await AsyncExecuter.ToListAsync(
queryable.Where(x =>
queryable = queryable.Where(x =>
x.TenantId == tenantId &&
x.IsActive &&
x.Webhooks.Contains("\"" + webhookName + "\"")));
x.Webhooks.Contains("\"" + webhookName + "\""));
var subscriptions = await AsyncExecuter.ToListAsync(queryable);
return subscriptions.Select(subscription => subscription.ToWebhookSubscriptionInfo()).ToList();
}
@ -79,11 +82,12 @@ public class WebhookSubscriptionsStore : DomainService, IWebhookSubscriptionsSto
{
var queryable = await SubscriptionRepository.GetQueryableAsync();
var subscriptions = await AsyncExecuter.ToListAsync(
queryable.Where(x =>
queryable = queryable.Where(x =>
x.IsActive &&
tenantIds.Contains(x.TenantId) &&
x.Webhooks.Contains("\"" + webhookName + "\"")));
x.Webhooks.Contains("\"" + webhookName + "\""));
var subscriptions = await AsyncExecuter.ToListAsync(queryable);
return subscriptions.Select(subscription => subscription.ToWebhookSubscriptionInfo()).ToList();
}
@ -124,11 +128,12 @@ public class WebhookSubscriptionsStore : DomainService, IWebhookSubscriptionsSto
{
var queryable = await SubscriptionRepository.GetQueryableAsync();
return await AsyncExecuter.AnyAsync(
queryable.Where(x =>
queryable = queryable.Where(x =>
x.TenantId == tenantId &&
x.IsActive &&
x.Webhooks.Contains("\"" + webhookName + "\"")));
x.Webhooks.Contains("\"" + webhookName + "\""));
return await AsyncExecuter.AnyAsync(queryable);
}
}

22
aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.Domain/LINGYUN/Abp/WebhooksManagement/Webhooks/WebhooksDefinitionProvider.cs

@ -0,0 +1,22 @@
using LINGYUN.Abp.Webhooks;
using LINGYUN.Abp.WebhooksManagement.Localization;
using Volo.Abp.Localization;
namespace LINGYUN.Abp.WebhooksManagement.Webhooks;
public class WebhooksDefinitionProvider : WebhookDefinitionProvider
{
public override void Define(IWebhookDefinitionContext context)
{
context.Add(
new WebhookDefinition(
WebhooksNames.CheckConnect,
L("DisplayName:CheckConnect"),
L("Description:CheckConnect")));
}
private static ILocalizableString L(string name)
{
return LocalizableString.Create<WebhooksManagementResource>(name);
}
}

6
aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.Domain/LINGYUN/Abp/WebhooksManagement/Webhooks/WebhooksNames.cs

@ -0,0 +1,6 @@
namespace LINGYUN.Abp.WebhooksManagement.Webhooks;
public static class WebhooksNames
{
public const string CheckConnect = "Abp.Webhooks.CheckConnect";
}

3
aspnet-core/modules/webhooks/LINGYUN.Abp.WebhooksManagement.EntityFrameworkCore/LINGYUN/Abp/WebhooksManagement/EntityFrameworkCore/WebhooksManagementDbContextModelCreatingExtensions.cs

@ -48,6 +48,9 @@ public static class WebhooksManagementDbContextModelCreatingExtensions
.WithOne()
.HasForeignKey<WebhookSendRecord>(fk => fk.WebhookEventId)
.HasPrincipalKey<WebhookEventRecord>(pk => pk.Id );
b.HasIndex(p => p.WebhookEventId)
.IsUnique(false);
});
builder.Entity<WebhookSubscription>(b =>

5
aspnet-core/services/LY.MicroService.WebhooksManagement.HttpApi.Host/Migrations/20220326052244_Add-Module-WebHooks-Management.Designer.cs → aspnet-core/services/LY.MicroService.WebhooksManagement.HttpApi.Host/Migrations/20220326064231_Add-Module-WebHooks-Management.Designer.cs

@ -12,7 +12,7 @@ using Volo.Abp.EntityFrameworkCore;
namespace LY.MicroService.WebhooksManagement.Migrations
{
[DbContext(typeof(WebhooksManagementMigrationsDbContext))]
[Migration("20220326052244_Add-Module-WebHooks-Management")]
[Migration("20220326064231_Add-Module-WebHooks-Management")]
partial class AddModuleWebHooksManagement
{
protected override void BuildTargetModel(ModelBuilder modelBuilder)
@ -97,8 +97,7 @@ namespace LY.MicroService.WebhooksManagement.Migrations
b.HasKey("Id");
b.HasIndex("WebhookEventId")
.IsUnique();
b.HasIndex("WebhookEventId");
b.ToTable("AbpWebhooksSendAttempts", (string)null);
});

3
aspnet-core/services/LY.MicroService.WebhooksManagement.HttpApi.Host/Migrations/20220326052244_Add-Module-WebHooks-Management.cs → aspnet-core/services/LY.MicroService.WebhooksManagement.HttpApi.Host/Migrations/20220326064231_Add-Module-WebHooks-Management.cs

@ -85,8 +85,7 @@ namespace LY.MicroService.WebhooksManagement.Migrations
migrationBuilder.CreateIndex(
name: "IX_AbpWebhooksSendAttempts_WebhookEventId",
table: "AbpWebhooksSendAttempts",
column: "WebhookEventId",
unique: true);
column: "WebhookEventId");
}
protected override void Down(MigrationBuilder migrationBuilder)

3
aspnet-core/services/LY.MicroService.WebhooksManagement.HttpApi.Host/Migrations/WebhooksManagementMigrationsDbContextModelSnapshot.cs

@ -95,8 +95,7 @@ namespace LY.MicroService.WebhooksManagement.Migrations
b.HasKey("Id");
b.HasIndex("WebhookEventId")
.IsUnique();
b.HasIndex("WebhookEventId");
b.ToTable("AbpWebhooksSendAttempts", (string)null);
});

7
aspnet-core/services/LY.MicroService.WebhooksManagement.HttpApi.Host/WebhooksManagementHttpApiHostModule.Configure.cs

@ -81,7 +81,12 @@ public partial class WebhooksManagementHttpApiHostModule
// 配置Ef
Configure<AbpDbContextOptions>(options =>
{
options.UseMySQL();
//options.UseMySQL();
options.Configure(cfg =>
{
cfg.UseMySQL();
cfg.DbContextOptions.EnableSensitiveDataLogging();
});
});
}

2
aspnet-core/services/LY.MicroService.WebhooksManagement.HttpApi.Host/WebhooksManagementHttpApiHostModule.cs

@ -86,7 +86,7 @@ public partial class WebhooksManagementHttpApiHostModule : AbpModule
ConfigureSeedWorker(context.Services, hostingEnvironment.IsDevelopment());
ConfigureSecurity(context.Services, configuration, hostingEnvironment.IsDevelopment());
// context.Services.AddAlwaysAllowAuthorization();
context.Services.AddAlwaysAllowAuthorization();
}
public override void OnApplicationInitialization(ApplicationInitializationContext context)

Loading…
Cancel
Save