/*
* Licensed under the Apache License, Version 2.0 (http://www.apache.org/licenses/LICENSE-2.0)
* See https://github.com/openiddict/openiddict-core for more information concerning
* the license and the contributors participating to this project.
*/
using System;
using System.ComponentModel;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Metadata.Builders;
using OpenIddict.EntityFrameworkCore.Models;
namespace OpenIddict.EntityFrameworkCore
{
///
/// Defines a relational mapping for the Application entity.
///
/// The type of the Application entity.
/// The type of the Authorization entity.
/// The type of the Token entity.
/// The type of the Key entity.
[EditorBrowsable(EditorBrowsableState.Never)]
public class OpenIddictApplicationConfiguration : IEntityTypeConfiguration
where TApplication : OpenIddictApplication
where TAuthorization : OpenIddictAuthorization
where TToken : OpenIddictToken
where TKey : IEquatable
{
public void Configure(EntityTypeBuilder builder)
{
if (builder == null)
{
throw new ArgumentNullException(nameof(builder));
}
// Warning: optional foreign keys MUST NOT be added as CLR properties because
// Entity Framework would throw an exception due to the TKey generic parameter
// being non-nullable when using value types like short, int, long or Guid.
builder.HasKey(application => application.Id);
builder.HasIndex(application => application.ClientId)
.IsUnique();
builder.Property(application => application.ClientId)
.IsRequired();
builder.Property(application => application.ConcurrencyToken)
.IsConcurrencyToken();
builder.Property(application => application.Type)
.IsRequired();
builder.HasMany(application => application.Authorizations)
.WithOne(authorization => authorization.Application)
.HasForeignKey("ApplicationId")
.IsRequired(required: false);
builder.HasMany(application => application.Tokens)
.WithOne(token => token.Application)
.HasForeignKey("ApplicationId")
.IsRequired(required: false);
builder.ToTable("OpenIddictApplications");
}
}
}