Save
This commit is contained in:
@ -1,6 +1,54 @@
|
||||
namespace decePubClient.Services;
|
||||
using Microsoft.JSInterop;
|
||||
|
||||
namespace decePubClient.Services;
|
||||
|
||||
public class AppStatusService
|
||||
{
|
||||
|
||||
readonly IJSRuntime JsRuntime;
|
||||
readonly IJSInProcessRuntime JsSyncRuntime;
|
||||
|
||||
public AppStatusService(IJSRuntime JSRuntime)
|
||||
{
|
||||
JsRuntime = JSRuntime;
|
||||
JsSyncRuntime = (IJSInProcessRuntime)JSRuntime;
|
||||
}
|
||||
|
||||
public async ValueTask<bool> IsOnline() => await JsSyncRuntime.InvokeAsync<bool>("isOnline");
|
||||
|
||||
public bool InputCaptureSupported() => JsSyncRuntime.Invoke<bool>("inputCaptureSupported");
|
||||
|
||||
public bool IsServiceWorkerAvailable() => JsSyncRuntime.Invoke<bool>("isServiceWorkerAvailable");
|
||||
|
||||
public string Language() => JsSyncRuntime.Invoke<string>("getLanguage");
|
||||
|
||||
public void Language(string language) => JsSyncRuntime.InvokeVoid("setLanguage", language);
|
||||
|
||||
public long GetHeight(string classId) => JsSyncRuntime.Invoke<long>("getHeight", classId);
|
||||
|
||||
public void SetAppBadge(int counter) => JsSyncRuntime.InvokeVoid("setAppBadge", counter);
|
||||
|
||||
public void ClearAppBadge() => JsSyncRuntime.InvokeVoid("clearAppBadge");
|
||||
|
||||
public async ValueTask ClearCache()
|
||||
{
|
||||
await JsRuntime.InvokeVoidAsync("clearCache");
|
||||
}
|
||||
|
||||
public async ValueTask ClearLocalStorage()
|
||||
{
|
||||
await JsRuntime.InvokeVoidAsync("clearLocalStorage");
|
||||
}
|
||||
|
||||
public void ReloadPage()
|
||||
{
|
||||
JsSyncRuntime.InvokeVoid("reloadPage");
|
||||
}
|
||||
|
||||
public bool IsMobileMedia() => JsSyncRuntime.Invoke<bool>("isMobileMedia");
|
||||
|
||||
public bool CanShare() => JsSyncRuntime.Invoke<bool>("canShareStuff");
|
||||
|
||||
public async ValueTask ShareTextUrl(string title, string text, Uri uri) => await JsRuntime.InvokeVoidAsync("shareTextUrl", title, text, uri.ToString());
|
||||
|
||||
public async ValueTask ShareText(string title, string text) => await JsRuntime.InvokeVoidAsync("shareText", title, text);
|
||||
}
|
@ -8,15 +8,15 @@ namespace decePubClient.Services
|
||||
{
|
||||
public interface IHttpService
|
||||
{
|
||||
Task<HttpResponseMessage> Get(string uri, object payload = default, string?[] queryParams = default);
|
||||
Task<HttpResponseMessage> Get(string uri, object payload = default, string[] queryParams = default);
|
||||
|
||||
Task<HttpResponseMessage> GetAnon(string uri, object payload = default, string?[] queryParams = default);
|
||||
Task<HttpResponseMessage> GetAnon(string uri, object payload = default, string[] queryParams = default);
|
||||
|
||||
Task<HttpResponseMessage> Post(string uri, object payload = default);
|
||||
|
||||
Task<HttpResponseMessage> PostAnon(string uri, object payload = default);
|
||||
|
||||
Task<HttpResponseMessage> Delete(string uri, string?[] queryParams = default, object payload = default);
|
||||
Task<HttpResponseMessage> Delete(string uri, string[] queryParams = default, object payload = default);
|
||||
}
|
||||
|
||||
public class HttpService : IHttpService
|
||||
@ -41,7 +41,7 @@ namespace decePubClient.Services
|
||||
DbStorage = dbStorage;
|
||||
}
|
||||
|
||||
public async Task<HttpResponseMessage> Get(string uri, object payload = default, string?[] queryParams = default)
|
||||
public async Task<HttpResponseMessage> Get(string uri, object payload = default, string[] queryParams = default)
|
||||
{
|
||||
try
|
||||
{
|
||||
@ -82,7 +82,7 @@ namespace decePubClient.Services
|
||||
}
|
||||
}
|
||||
|
||||
public async Task<HttpResponseMessage> GetAnon(string uri, object payload = default, string?[] queryParams = default)
|
||||
public async Task<HttpResponseMessage> GetAnon(string uri, object payload = default, string[] queryParams = default)
|
||||
{
|
||||
try
|
||||
{
|
||||
@ -123,7 +123,7 @@ namespace decePubClient.Services
|
||||
}
|
||||
}
|
||||
|
||||
public async Task<HttpResponseMessage> Delete(string uri, string?[] queryParams = default, object payload = default)
|
||||
public async Task<HttpResponseMessage> Delete(string uri, string[] queryParams = default, object payload = default)
|
||||
{
|
||||
try
|
||||
{
|
||||
|
322
Services/IStorage.cs
Normal file
322
Services/IStorage.cs
Normal file
@ -0,0 +1,322 @@
|
||||
using decePubClient.Helpers;
|
||||
using decePubClient.Models;
|
||||
using decePubClient.Models.Types;
|
||||
using Markdig;
|
||||
|
||||
namespace decePubClient.Services
|
||||
{
|
||||
public interface IStorage
|
||||
{
|
||||
ValueTask<List<Message>> GetMessages();
|
||||
ValueTask<Message> GetMessage(string messageId);
|
||||
ValueTask<string> AddMessages(List<Message> messages);
|
||||
ValueTask<string> UpdateMessages(List<Message> messages);
|
||||
ValueTask<string> RemoveMessage(string messageId);
|
||||
|
||||
ValueTask<ICollection<ClientLogs>> GetClientLogs();
|
||||
ValueTask AddLog(Exception exception, string where);
|
||||
ValueTask AddLog(string message, string where);
|
||||
|
||||
ValueTask<bool> RemoveAll(bool includeClientLogs = false);
|
||||
}
|
||||
|
||||
public class Storage : IStorage
|
||||
{
|
||||
readonly IndexedDb _db;
|
||||
readonly ILogger<Storage> _logger;
|
||||
|
||||
public Storage(IndexedDb indexedDb, ILogger<Storage> logger)
|
||||
{
|
||||
_db = indexedDb;
|
||||
_logger = logger;
|
||||
}
|
||||
|
||||
#region Messagges
|
||||
|
||||
public async ValueTask<Message> GetMessage(string messageId)
|
||||
{
|
||||
await _db.OpenIndexedDb();
|
||||
var message = await _db.GetByKey<string, Message>(nameof(Message), messageId);
|
||||
|
||||
if (message is null)
|
||||
{
|
||||
var messages = await GetMessages();
|
||||
return messages.FirstOrDefault(m => m.MessageId == messageId);
|
||||
}
|
||||
|
||||
return message;
|
||||
}
|
||||
|
||||
public async ValueTask<List<Message>> GetMessages()
|
||||
{
|
||||
await _db.OpenIndexedDb();
|
||||
var messages = await _db.GetAll<Message>(nameof(Message)) ?? new();
|
||||
|
||||
|
||||
if (messages.Count == 0)
|
||||
{
|
||||
messages.Add(new()
|
||||
{
|
||||
RootMessageId = default,
|
||||
MessageId = "992167EE-8947-4823-B1E2-B4E1019B6974",
|
||||
User = Faker.GetRandomUser(),
|
||||
MessageType = (MessageType)Random.Shared.Next(0, 4),
|
||||
Title = default,
|
||||
Content = "test di messaggio normale senza titolo",
|
||||
Medias = new(),
|
||||
CreatedAt = DateTime.UtcNow.AddMinutes(Random.Shared.Next(-5000, 0)),
|
||||
IsFavourite = Random.Shared.Next() % 2 == 0,
|
||||
IsBoosted = Random.Shared.Next() % 2 == 0,
|
||||
});
|
||||
messages.Add(new()
|
||||
{
|
||||
RootMessageId = default,
|
||||
MessageId = "C5307644-4EA8-4B5F-A240-7CFE4DE34741",
|
||||
User = Faker.GetRandomUser(),
|
||||
MessageType = (MessageType)Random.Shared.Next(0, 4),
|
||||
Title = "sopra la panca la capra canta",
|
||||
Content = Markdown.ToHtml("test di messaggio con titolo"),
|
||||
Medias = new(),
|
||||
CreatedAt = DateTime.UtcNow.AddMinutes(Random.Shared.Next(-5000, 0)),
|
||||
IsFavourite = Random.Shared.Next() % 2 == 0,
|
||||
IsBoosted = Random.Shared.Next() % 2 == 0,
|
||||
});
|
||||
messages.Add(new()
|
||||
{
|
||||
RootMessageId = default,
|
||||
MessageId = "E473D562-D210-4453-93DA-157D4B90B0D8",
|
||||
User = Faker.GetRandomUser(),
|
||||
MessageType = (MessageType)Random.Shared.Next(0, 4),
|
||||
Title = default,
|
||||
Content = "dddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddd test di messaggio con overflow del testo",
|
||||
Medias = new(),
|
||||
CreatedAt = DateTime.UtcNow.AddMinutes(Random.Shared.Next(-5000, 0)),
|
||||
IsFavourite = Random.Shared.Next() % 2 == 0,
|
||||
IsBoosted = Random.Shared.Next() % 2 == 0,
|
||||
});
|
||||
messages.Add(new()
|
||||
{
|
||||
RootMessageId = default,
|
||||
MessageId = "adf89dc6-0484-430e-a7c9-fcb1179b0c28",
|
||||
User = Faker.GetRandomUser(),
|
||||
MessageType = (MessageType)Random.Shared.Next(0, 4),
|
||||
Title = default,
|
||||
Content = "test video",
|
||||
Medias = new()
|
||||
{
|
||||
new()
|
||||
{
|
||||
FileName = "8252d175e714db88beb8ee0349dbac90405d3d5148e96e0cfd7de3b0876dbb1b.mp4",
|
||||
Url = "https://ihatebeinga.live/media/8252d175e714db88beb8ee0349dbac90405d3d5148e96e0cfd7de3b0876dbb1b.mp4",
|
||||
AltText = "https://ihatebeinga.live/media/8252d175e714db88beb8ee0349dbac90405d3d5148e96e0cfd7de3b0876dbb1b.mp4",
|
||||
ContentType = "video/mp4"
|
||||
}
|
||||
},
|
||||
CreatedAt = DateTime.UtcNow.AddMinutes(Random.Shared.Next(-5000, 0)),
|
||||
IsFavourite = Random.Shared.Next() % 2 == 0,
|
||||
IsBoosted = Random.Shared.Next() % 2 == 0,
|
||||
});
|
||||
messages.Add(new()
|
||||
{
|
||||
RootMessageId = default,
|
||||
MessageId = "96025b43-5235-44e9-a3fa-98df31edfbfb",
|
||||
User = Faker.GetRandomUser(),
|
||||
MessageType = (MessageType)Random.Shared.Next(0, 4),
|
||||
Title = default,
|
||||
Content = "test immagine",
|
||||
Medias = new()
|
||||
{
|
||||
new()
|
||||
{
|
||||
FileName = "51a7cf620f1dd096ac5867d5b78f8c71d57a23972b31c64ec124a8c41e77a618.jpg",
|
||||
Url = "https://ihatebeinga.live/media/51a7cf620f1dd096ac5867d5b78f8c71d57a23972b31c64ec124a8c41e77a618.jpg",
|
||||
AltText = "51a7cf620f1dd096ac5867d5b78f8c71d57a23972b31c64ec124a8c41e77a618.jpg",
|
||||
ContentType = "image/jpg"
|
||||
}
|
||||
},
|
||||
CreatedAt = DateTime.UtcNow.AddMinutes(Random.Shared.Next(-5000, 0)),
|
||||
IsFavourite = Random.Shared.Next() % 2 == 0,
|
||||
IsBoosted = Random.Shared.Next() % 2 == 0,
|
||||
});
|
||||
messages.Add(new()
|
||||
{
|
||||
RootMessageId = default,
|
||||
MessageId = "96025b43-5235-44e9-a3fa-98df31edfbfb",
|
||||
User = Faker.GetRandomUser(),
|
||||
MessageType = (MessageType)Random.Shared.Next(0, 4),
|
||||
Title = default,
|
||||
Content = "test immagini",
|
||||
Medias = new()
|
||||
{
|
||||
new()
|
||||
{
|
||||
FileName = "51a7cf620f1dd096ac5867d5b78f8c71d57a23972b31c64ec124a8c41e77a618.jpg",
|
||||
Url = "https://ihatebeinga.live/media/51a7cf620f1dd096ac5867d5b78f8c71d57a23972b31c64ec124a8c41e77a618.jpg",
|
||||
AltText = "51a7cf620f1dd096ac5867d5b78f8c71d57a23972b31c64ec124a8c41e77a618.jpg",
|
||||
ContentType = "image/jpg"
|
||||
},
|
||||
new()
|
||||
{
|
||||
FileName = "51a7cf620f1dd096ac5867d5b78f8c71d57a23972b31c64ec124a8c41e77a618.jpg",
|
||||
Url = "https://ihatebeinga.live/media/51a7cf620f1dd096ac5867d5b78f8c71d57a23972b31c64ec124a8c41e77a618.jpg",
|
||||
AltText = "51a7cf620f1dd096ac5867d5b78f8c71d57a23972b31c64ec124a8c41e77a618.jpg",
|
||||
ContentType = "image/jpg"
|
||||
},
|
||||
new()
|
||||
{
|
||||
FileName = "51a7cf620f1dd096ac5867d5b78f8c71d57a23972b31c64ec124a8c41e77a618.jpg",
|
||||
Url = "https://ihatebeinga.live/media/51a7cf620f1dd096ac5867d5b78f8c71d57a23972b31c64ec124a8c41e77a618.jpg",
|
||||
AltText = "51a7cf620f1dd096ac5867d5b78f8c71d57a23972b31c64ec124a8c41e77a618.jpg",
|
||||
ContentType = "image/jpg"
|
||||
}
|
||||
},
|
||||
CreatedAt = DateTime.UtcNow.AddMinutes(Random.Shared.Next(-5000, 0)),
|
||||
IsFavourite = Random.Shared.Next() % 2 == 0,
|
||||
IsBoosted = Random.Shared.Next() % 2 == 0,
|
||||
});
|
||||
}
|
||||
|
||||
messages = messages.OrderByDescending(m => m.CreatedAt).ToList();
|
||||
|
||||
return messages;
|
||||
}
|
||||
|
||||
public async ValueTask<string> AddMessages(List<Message> messages)
|
||||
{
|
||||
await _db.OpenIndexedDb();
|
||||
var result = await _db.AddItems(nameof(Message), messages);
|
||||
_logger.LogInformation(result);
|
||||
return result;
|
||||
}
|
||||
|
||||
public async ValueTask<string> UpdateMessages(List<Message> messages)
|
||||
{
|
||||
await _db.OpenIndexedDb();
|
||||
var result = await _db.UpdateItems(nameof(Message), messages);
|
||||
_logger.LogInformation(result);
|
||||
return result;
|
||||
|
||||
}
|
||||
|
||||
public async ValueTask<string> RemoveMessage(string messageId)
|
||||
{
|
||||
await _db.OpenIndexedDb();
|
||||
var result = await _db.DeleteByKey(nameof(Message), messageId);
|
||||
_logger.LogInformation(result);
|
||||
return result;
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Logs
|
||||
|
||||
public async ValueTask<ICollection<ClientLogs>> GetClientLogs()
|
||||
{
|
||||
try
|
||||
{
|
||||
_logger.LogInformation($"opening on {nameof(GetClientLogs)}");
|
||||
await _db.OpenIndexedDb();
|
||||
return (await _db.GetAll<ClientLogs>(nameof(ClientLogs))).OrderByDescending(cl => cl.TimeStamp).ToArray();
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
_logger.LogError(ex, ex.Message);
|
||||
return new List<ClientLogs>();
|
||||
}
|
||||
}
|
||||
|
||||
public async ValueTask AddLog(Exception exception, string where)
|
||||
{
|
||||
try
|
||||
{
|
||||
await _db.OpenIndexedDb();
|
||||
|
||||
var maxKey = await _db.GetMaxKey<long>(nameof(ClientLogs));
|
||||
var minKey = await _db.GetMinKey<long>(nameof(ClientLogs));
|
||||
|
||||
if (minKey - maxKey <= -100)
|
||||
for (var i = minKey; i < minKey + 50; i++)
|
||||
_ = await _db.DeleteByKey(nameof(ClientLogs), i);
|
||||
|
||||
maxKey += 1;
|
||||
var result = await _db.AddItems<ClientLogs>(nameof(ClientLogs), new()
|
||||
{
|
||||
new()
|
||||
{
|
||||
Id = maxKey,
|
||||
Where = where,
|
||||
Exception = new()
|
||||
{
|
||||
Type = exception.GetType().ToString(),
|
||||
HelpLink = exception.HelpLink,
|
||||
HResult = exception.HResult.ToString(),
|
||||
InnerExceptionMessage = exception.InnerException?.Message,
|
||||
Message = exception.Message,
|
||||
Source = exception.Source,
|
||||
StackTrace = exception.StackTrace,
|
||||
TargetSiteName = exception.TargetSite?.Name
|
||||
}
|
||||
}
|
||||
});
|
||||
_logger.LogDebug($"{nameof(AddLog)}() add logs result = {result}");
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
_logger.LogError(ex, ex.Message);
|
||||
}
|
||||
}
|
||||
|
||||
public async ValueTask AddLog(string message, string where)
|
||||
{
|
||||
try
|
||||
{
|
||||
await _db.OpenIndexedDb();
|
||||
|
||||
var maxKey = await _db.GetMaxKey<long>(nameof(ClientLogs));
|
||||
var minKey = await _db.GetMinKey<long>(nameof(ClientLogs));
|
||||
|
||||
if (minKey - maxKey <= -100)
|
||||
for (var i = minKey; i < minKey + 50; i++)
|
||||
_ = await _db.DeleteByKey(nameof(ClientLogs), i);
|
||||
|
||||
maxKey += 1;
|
||||
var result = await _db.AddItems<ClientLogs>(nameof(ClientLogs), new()
|
||||
{
|
||||
new()
|
||||
{
|
||||
Id = maxKey,
|
||||
Where = where,
|
||||
Exception = null,
|
||||
WarningMessage = message
|
||||
}
|
||||
});
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
_logger.LogError(ex, ex.Message);
|
||||
}
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
public async ValueTask<bool> RemoveAll(bool includeClientLogs = false)
|
||||
{
|
||||
try
|
||||
{
|
||||
_logger.LogInformation($"opening on {nameof(RemoveAll)}");
|
||||
await _db.OpenIndexedDb();
|
||||
_ = await _db.DeleteAll(nameof(Message));
|
||||
if (includeClientLogs)
|
||||
_ = await _db.DeleteAll(nameof(ClientLogs));
|
||||
|
||||
return true;
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
_logger.LogError(ex, ex.Message);
|
||||
return default;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
14
Services/IndexedDb.cs
Normal file
14
Services/IndexedDb.cs
Normal file
@ -0,0 +1,14 @@
|
||||
using DnetIndexedDb;
|
||||
|
||||
using Microsoft.JSInterop;
|
||||
|
||||
namespace decePubClient.Services
|
||||
{
|
||||
public class IndexedDb : IndexedDbInterop
|
||||
{
|
||||
public IndexedDb(IJSRuntime jsRuntime, IndexedDbOptions<IndexedDb> options)
|
||||
: base(jsRuntime, options)
|
||||
{
|
||||
}
|
||||
}
|
||||
}
|
@ -1,10 +1,77 @@
|
||||
namespace decePubClient.Services
|
||||
using Blazored.Modal.Services;
|
||||
using decePubClient.Models;
|
||||
using decePubClient.Models.Types;
|
||||
|
||||
namespace decePubClient.Services
|
||||
{
|
||||
public class MessagesService
|
||||
{
|
||||
public MessagesService()
|
||||
{
|
||||
readonly IModalService modalService;
|
||||
readonly IStorage storage;
|
||||
readonly HttpClient http;
|
||||
|
||||
public MessagesService(IHttpClientFactory clientFactory, IModalService modalService, IStorage storage)
|
||||
{
|
||||
this.modalService = modalService;
|
||||
this.storage = storage;
|
||||
http = clientFactory.CreateClient("default");
|
||||
}
|
||||
|
||||
//Covers also direct message
|
||||
public async Task<Message> SubmitMessage(MessageForm messageForm)
|
||||
{
|
||||
//TODO
|
||||
|
||||
await Task.Run(() => {});
|
||||
return new();
|
||||
}
|
||||
|
||||
//Covers also direct message
|
||||
public async Task<Message> ReplyMessage(Message messageToReply, MessageType messageType = MessageType.Public)
|
||||
{
|
||||
//TODO
|
||||
|
||||
await Task.Run(() => {});
|
||||
return messageToReply;
|
||||
}
|
||||
|
||||
public async Task<Message> BoostUnboostMessage(Message messageToReply)
|
||||
{
|
||||
//TODO
|
||||
|
||||
await Task.Run(() => {});
|
||||
return messageToReply;
|
||||
}
|
||||
|
||||
public async Task<Message> FavouriteUnfavouriteMessage(Message messageToReply)
|
||||
{
|
||||
//TODO
|
||||
|
||||
await Task.Run(() => {});
|
||||
return messageToReply;
|
||||
}
|
||||
|
||||
public async Task<Message> DeleteMessage(Message messageToReply)
|
||||
{
|
||||
//TODO
|
||||
|
||||
await Task.Run(() => {});
|
||||
return messageToReply;
|
||||
}
|
||||
|
||||
public async Task<MessageUser> BlockUserFromMessage(MessageUser messageUser)
|
||||
{
|
||||
//TODO
|
||||
await Task.Run(() => {});
|
||||
return messageUser;
|
||||
}
|
||||
|
||||
public async Task<MessageUser> SilenceUserFromMessage(MessageUser messageUser)
|
||||
{
|
||||
//TODO
|
||||
|
||||
await Task.Run(() => {});
|
||||
return messageUser;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user