2020-05-09 22:16:16 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Dapper;
|
2021-09-27 12:42:46 +00:00
|
|
|
|
using Wabbajack.Hashing.xxHash64;
|
2020-05-09 22:16:16 +00:00
|
|
|
|
|
|
|
|
|
namespace Wabbajack.Server.DataLayer
|
|
|
|
|
{
|
|
|
|
|
public partial class SqlService
|
|
|
|
|
{
|
|
|
|
|
public async Task<string> LoginByApiKey(string key)
|
|
|
|
|
{
|
|
|
|
|
await using var conn = await Open();
|
|
|
|
|
var result = await conn.QueryAsync<string>(@"SELECT Owner as Id FROM dbo.ApiKeys WHERE ApiKey = @ApiKey",
|
|
|
|
|
new {ApiKey = key});
|
|
|
|
|
return result.FirstOrDefault();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<string> AddLogin(string name)
|
|
|
|
|
{
|
|
|
|
|
var key = NewAPIKey();
|
|
|
|
|
await using var conn = await Open();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
await conn.ExecuteAsync("INSERT INTO dbo.ApiKeys (Owner, ApiKey) VALUES (@Owner, @ApiKey)",
|
|
|
|
|
new {Owner = name, ApiKey = key});
|
|
|
|
|
return key;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static string NewAPIKey()
|
|
|
|
|
{
|
|
|
|
|
var arr = new byte[128];
|
|
|
|
|
new Random().NextBytes(arr);
|
|
|
|
|
return arr.ToHex();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<IEnumerable<(string Owner, string Key)>> GetAllUserKeys()
|
|
|
|
|
{
|
|
|
|
|
await using var conn = await Open();
|
|
|
|
|
var result = await conn.QueryAsync<(string Owner, string Key)>("SELECT Owner, ApiKey FROM dbo.ApiKeys");
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2020-06-14 13:13:29 +00:00
|
|
|
|
public async Task<bool> IsTarKey(string metricsKey)
|
|
|
|
|
{
|
|
|
|
|
await using var conn = await Open();
|
|
|
|
|
var result = await conn.QueryFirstOrDefaultAsync<string>(
|
|
|
|
|
"SELECT MetricsKey FROM TarKey WHERE MetricsKey = @MetricsKey", new {MetricsKey = metricsKey});
|
|
|
|
|
return result == metricsKey;
|
|
|
|
|
}
|
2020-05-09 22:16:16 +00:00
|
|
|
|
}
|
|
|
|
|
}
|