diff options
Diffstat (limited to 'docker/crupest-api/CrupestApi/CrupestApi.Secrets')
| -rw-r--r-- | docker/crupest-api/CrupestApi/CrupestApi.Secrets/SecretInfo.cs | 6 | ||||
| -rw-r--r-- | docker/crupest-api/CrupestApi/CrupestApi.Secrets/SecretsService.cs | 55 | 
2 files changed, 19 insertions, 42 deletions
| diff --git a/docker/crupest-api/CrupestApi/CrupestApi.Secrets/SecretInfo.cs b/docker/crupest-api/CrupestApi/CrupestApi.Secrets/SecretInfo.cs index d4c1b66..009bde9 100644 --- a/docker/crupest-api/CrupestApi/CrupestApi.Secrets/SecretInfo.cs +++ b/docker/crupest-api/CrupestApi/CrupestApi.Secrets/SecretInfo.cs @@ -6,12 +6,14 @@ public class SecretInfo  {      [Column(NotNull = true)]      public string Key { get; set; } = default!; -    [Column(NotNull = true)] +    [Column(NotNull = true, ClientGenerate = true)]      public string Secret { get; set; } = default!;      [Column(DefaultEmptyForString = true)]      public string Description { get; set; } = default!;      [Column(NotNull = false)] -    public DateTime ExpireTime { get; set; } +    public DateTime? ExpireTime { get; set; } +    [Column(NotNull = true)]      public bool Revoked { get; set; } +    [Column(NotNull = true)]      public DateTime CreateTime { get; set; }  } diff --git a/docker/crupest-api/CrupestApi/CrupestApi.Secrets/SecretsService.cs b/docker/crupest-api/CrupestApi/CrupestApi.Secrets/SecretsService.cs index 23a0e82..5a49121 100644 --- a/docker/crupest-api/CrupestApi/CrupestApi.Secrets/SecretsService.cs +++ b/docker/crupest-api/CrupestApi/CrupestApi.Secrets/SecretsService.cs @@ -1,66 +1,31 @@ -using System.Data;  using System.Diagnostics; -using System.Security.Cryptography; -using System.Text;  using CrupestApi.Commons;  using CrupestApi.Commons.Crud;  using Dapper; -using Microsoft.Data.Sqlite; -using Microsoft.Extensions.Options;  namespace CrupestApi.Secrets;  public class SecretsService : CrudService<SecretInfo>, ISecretsService  { -    private readonly IOptionsSnapshot<CrupestApiConfig> _crupestApiConfig;      private readonly ILogger<SecretsService> _logger; -    public SecretsService(IOptionsSnapshot<CrupestApiConfig> crupestApiConfig, ILogger<SecretsService> logger, ServiceProvider services) -    : base(services) +    public SecretsService(ITableInfoFactory tableInfoFactory, IDbConnectionFactory dbConnectionFactory, ILoggerFactory loggerFactory) +    : base("secrets", tableInfoFactory, dbConnectionFactory, loggerFactory)      { -        _crupestApiConfig = crupestApiConfig; -        _logger = logger; -    } - -    private string GetDatabasePath() -    { -        return Path.Combine(_crupestApiConfig.Value.DataDir, "secrets.db"); -    } - -    public override string GetDbConnectionString() -    { -        var fileName = GetDatabasePath(); - -        return new SqliteConnectionStringBuilder() -        { -            DataSource = fileName, -            Mode = SqliteOpenMode.ReadWriteCreate -        }.ToString(); -    } - -    private string GenerateRandomKey(int length) -    { -        const string alphanum = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"; -        using var randomNumberGenerator = RandomNumberGenerator.Create(); -        var result = new StringBuilder(length); -        for (int i = 0; i < length; i++) -        { -            result.Append(alphanum[i]); -        } -        return result.ToString(); +        _logger = loggerFactory.CreateLogger<SecretsService>();      }      public async Task<SecretInfo> CreateSecretAsync(SecretInfo secretInfo)      {          if (secretInfo.Secret is not null)          { -            throw new ArgumentException("Secret is auto generated. Don't specify it explicit.") +            throw new ArgumentException("Secret is auto generated. Don't specify it explicit.");          }          secretInfo.Secret = GenerateRandomKey(16);          secretInfo.CreateTime = DateTime.Now; -        await InsertAsync(_table.GenerateInsertClauseFromObject(secretInfo)); +        await InsertAsync(_table.GenerateInsertClauseFromEntity(secretInfo));          return secretInfo;      } @@ -233,4 +198,14 @@ SELECT Id, Key, Secret, Description, ExpireTime, Revoked, CreateTime FROM secret          await VerifySecretAsync(key, secret);      } + +    public Task<SecretInfo?> GetSecretAsync(string secret) +    { +        throw new NotImplementedException(); +    } + +    public Task<SecretInfo> CreateSecretAsync(string key, string description, DateTime? expireTime = null) +    { +        throw new NotImplementedException(); +    }  } | 
