mirror of
https://github.com/ncblakely/GiantsTools
synced 2024-11-24 07:05:37 +01:00
Rename DiscordService to be a bit more future-proof. Fix flickering when showing community link.
This commit is contained in:
parent
bb376e1f63
commit
6d46fa2875
9
Giants.DataContract/Contracts/V1/CommunityStatus.cs
Normal file
9
Giants.DataContract/Contracts/V1/CommunityStatus.cs
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
namespace Giants.DataContract.V1
|
||||||
|
{
|
||||||
|
public class CommunityStatus
|
||||||
|
{
|
||||||
|
public string CommunityAppName { get; set; }
|
||||||
|
|
||||||
|
public string CommunityAppUri { get; set; }
|
||||||
|
}
|
||||||
|
}
|
@ -1,7 +0,0 @@
|
|||||||
namespace Giants.DataContract.V1
|
|
||||||
{
|
|
||||||
public class DiscordStatus
|
|
||||||
{
|
|
||||||
public string DiscordUri { get; set; }
|
|
||||||
}
|
|
||||||
}
|
|
32
Giants.Launcher/LauncherForm.Designer.cs
generated
32
Giants.Launcher/LauncherForm.Designer.cs
generated
@ -34,7 +34,7 @@
|
|||||||
this.btnPlay = new Giants.Launcher.ImageButton();
|
this.btnPlay = new Giants.Launcher.ImageButton();
|
||||||
this.updateProgressBar = new System.Windows.Forms.ProgressBar();
|
this.updateProgressBar = new System.Windows.Forms.ProgressBar();
|
||||||
this.txtProgress = new System.Windows.Forms.Label();
|
this.txtProgress = new System.Windows.Forms.Label();
|
||||||
this.DiscordLabel = new System.Windows.Forms.LinkLabel();
|
this.CommunityLabel = new System.Windows.Forms.LinkLabel();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.btnExit)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.btnExit)).BeginInit();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.btnOptions)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.btnOptions)).BeginInit();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.btnPlay)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.btnPlay)).BeginInit();
|
||||||
@ -108,19 +108,21 @@
|
|||||||
this.txtProgress.Text = "ProgressText";
|
this.txtProgress.Text = "ProgressText";
|
||||||
this.txtProgress.Visible = false;
|
this.txtProgress.Visible = false;
|
||||||
//
|
//
|
||||||
// DiscordLabel
|
// CommunityLabel
|
||||||
//
|
//
|
||||||
this.DiscordLabel.AutoSize = true;
|
this.CommunityLabel.ActiveLinkColor = System.Drawing.Color.DodgerBlue;
|
||||||
this.DiscordLabel.BackColor = System.Drawing.Color.Transparent;
|
this.CommunityLabel.AutoSize = true;
|
||||||
this.DiscordLabel.LinkColor = System.Drawing.Color.Aquamarine;
|
this.CommunityLabel.BackColor = System.Drawing.Color.Transparent;
|
||||||
this.DiscordLabel.Location = new System.Drawing.Point(12, 9);
|
this.CommunityLabel.Font = new System.Drawing.Font("Microsoft Sans Serif", 10F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
|
||||||
this.DiscordLabel.Name = "DiscordLabel";
|
this.CommunityLabel.LinkColor = System.Drawing.Color.DodgerBlue;
|
||||||
this.DiscordLabel.Size = new System.Drawing.Size(69, 13);
|
this.CommunityLabel.Location = new System.Drawing.Point(12, 9);
|
||||||
this.DiscordLabel.TabIndex = 12;
|
this.CommunityLabel.Name = "CommunityLabel";
|
||||||
this.DiscordLabel.TabStop = true;
|
this.CommunityLabel.Size = new System.Drawing.Size(112, 17);
|
||||||
this.DiscordLabel.Text = "DiscordLabel";
|
this.CommunityLabel.TabIndex = 12;
|
||||||
this.DiscordLabel.Visible = false;
|
this.CommunityLabel.TabStop = true;
|
||||||
this.DiscordLabel.LinkClicked += new System.Windows.Forms.LinkLabelLinkClickedEventHandler(this.DiscordLabel_LinkClicked);
|
this.CommunityLabel.Text = "CommunityLabel";
|
||||||
|
this.CommunityLabel.Visible = false;
|
||||||
|
this.CommunityLabel.LinkClicked += new System.Windows.Forms.LinkLabelLinkClickedEventHandler(this.DiscordLabel_LinkClicked);
|
||||||
//
|
//
|
||||||
// LauncherForm
|
// LauncherForm
|
||||||
//
|
//
|
||||||
@ -131,7 +133,7 @@
|
|||||||
this.CancelButton = this.btnExit;
|
this.CancelButton = this.btnExit;
|
||||||
this.ClientSize = new System.Drawing.Size(800, 500);
|
this.ClientSize = new System.Drawing.Size(800, 500);
|
||||||
this.ControlBox = false;
|
this.ControlBox = false;
|
||||||
this.Controls.Add(this.DiscordLabel);
|
this.Controls.Add(this.CommunityLabel);
|
||||||
this.Controls.Add(this.txtProgress);
|
this.Controls.Add(this.txtProgress);
|
||||||
this.Controls.Add(this.updateProgressBar);
|
this.Controls.Add(this.updateProgressBar);
|
||||||
this.Controls.Add(this.btnExit);
|
this.Controls.Add(this.btnExit);
|
||||||
@ -161,7 +163,7 @@
|
|||||||
private ImageButton btnExit;
|
private ImageButton btnExit;
|
||||||
private System.Windows.Forms.ProgressBar updateProgressBar;
|
private System.Windows.Forms.ProgressBar updateProgressBar;
|
||||||
private System.Windows.Forms.Label txtProgress;
|
private System.Windows.Forms.Label txtProgress;
|
||||||
private System.Windows.Forms.LinkLabel DiscordLabel;
|
private System.Windows.Forms.LinkLabel CommunityLabel;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,16 +24,18 @@ namespace Giants.Launcher
|
|||||||
|
|
||||||
private readonly HttpClient httpClient;
|
private readonly HttpClient httpClient;
|
||||||
private readonly VersionClient versionHttpClient;
|
private readonly VersionClient versionHttpClient;
|
||||||
private readonly DiscordClient discordHttpClient;
|
private readonly CommunityClient communityHttpClient;
|
||||||
|
|
||||||
private string commandLine = String.Empty;
|
private string commandLine = String.Empty;
|
||||||
private string gamePath = null;
|
private string gamePath = null;
|
||||||
private Updater updater;
|
private Updater updater;
|
||||||
private string discordUri;
|
private string communityAppUri;
|
||||||
|
|
||||||
public LauncherForm()
|
public LauncherForm()
|
||||||
{
|
{
|
||||||
this.InitializeComponent();
|
this.InitializeComponent();
|
||||||
|
this.SetStyle(ControlStyles.OptimizedDoubleBuffer, true);
|
||||||
|
this.SetStyle(ControlStyles.AllPaintingInWmPaint, true);
|
||||||
|
|
||||||
// Set window title
|
// Set window title
|
||||||
this.Text = GameName;
|
this.Text = GameName;
|
||||||
@ -42,8 +44,8 @@ namespace Giants.Launcher
|
|||||||
this.versionHttpClient = new VersionClient(this.httpClient);
|
this.versionHttpClient = new VersionClient(this.httpClient);
|
||||||
this.versionHttpClient.BaseUrl = BaseUrl;
|
this.versionHttpClient.BaseUrl = BaseUrl;
|
||||||
|
|
||||||
this.discordHttpClient = new DiscordClient(this.httpClient);
|
this.communityHttpClient = new CommunityClient(this.httpClient);
|
||||||
this.discordHttpClient.BaseUrl = BaseUrl;
|
this.communityHttpClient.BaseUrl = BaseUrl;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void btnExit_Click(object sender, EventArgs e)
|
private void btnExit_Click(object sender, EventArgs e)
|
||||||
@ -138,11 +140,11 @@ namespace Giants.Launcher
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var status = await this.discordHttpClient.GetDiscordStatusAsync();
|
var status = await this.communityHttpClient.GetDiscordStatusAsync();
|
||||||
|
|
||||||
this.discordUri = status.DiscordUri;
|
this.communityAppUri = status.CommunityAppUri;
|
||||||
this.DiscordLabel.Text = Resources.DiscordLabel;
|
this.CommunityLabel.Text = string.Format(Resources.CommunityLabel, status.CommunityAppName);
|
||||||
this.DiscordLabel.Visible = true;
|
this.CommunityLabel.Visible = true;
|
||||||
}
|
}
|
||||||
catch (Exception)
|
catch (Exception)
|
||||||
{
|
{
|
||||||
@ -273,19 +275,19 @@ namespace Giants.Launcher
|
|||||||
|
|
||||||
private void DiscordLabel_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
|
private void DiscordLabel_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
|
||||||
{
|
{
|
||||||
if (string.IsNullOrEmpty(this.discordUri))
|
if (string.IsNullOrEmpty(this.communityAppUri))
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var uri = new Uri(this.discordUri);
|
var uri = new Uri(this.communityAppUri);
|
||||||
if (uri.Scheme != "https")
|
if (uri.Scheme != "https")
|
||||||
{
|
{
|
||||||
// For security, reject any non-HTTPS or local file system URIs
|
// For security, reject any non-HTTPS or local file system URIs
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Process.Start(this.discordUri);
|
Process.Start(this.communityAppUri);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
6
Giants.Launcher/Properties/Resources.Designer.cs
generated
6
Giants.Launcher/Properties/Resources.Designer.cs
generated
@ -80,11 +80,11 @@ namespace Giants.Launcher {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized string similar to Join the community on Discord!.
|
/// Looks up a localized string similar to Join the community on {0}!.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
internal static string DiscordLabel {
|
internal static string CommunityLabel {
|
||||||
get {
|
get {
|
||||||
return ResourceManager.GetString("DiscordLabel", resourceCulture);
|
return ResourceManager.GetString("CommunityLabel", resourceCulture);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -199,7 +199,7 @@
|
|||||||
<data name="OptionSamples" xml:space="preserve">
|
<data name="OptionSamples" xml:space="preserve">
|
||||||
<value>{0} Samples</value>
|
<value>{0} Samples</value>
|
||||||
</data>
|
</data>
|
||||||
<data name="DiscordLabel" xml:space="preserve">
|
<data name="CommunityLabel" xml:space="preserve">
|
||||||
<value>Join the community on Discord!</value>
|
<value>Join the community on {0}!</value>
|
||||||
</data>
|
</data>
|
||||||
</root>
|
</root>
|
@ -17,7 +17,7 @@
|
|||||||
services.AddSingleton<IMemoryCache, MemoryCache>();
|
services.AddSingleton<IMemoryCache, MemoryCache>();
|
||||||
services.AddSingleton<IUpdaterStore, CosmosDbUpdaterStore>();
|
services.AddSingleton<IUpdaterStore, CosmosDbUpdaterStore>();
|
||||||
services.AddSingleton<IUpdaterService, UpdaterService>();
|
services.AddSingleton<IUpdaterService, UpdaterService>();
|
||||||
services.AddSingleton<IDiscordService, DiscordService>();
|
services.AddSingleton<ICommunityService, CommunityService>();
|
||||||
|
|
||||||
services.AddHostedService<InitializerService>();
|
services.AddHostedService<InitializerService>();
|
||||||
services.AddHostedService<ServerRegistryCleanupService>();
|
services.AddHostedService<ServerRegistryCleanupService>();
|
||||||
|
@ -2,11 +2,11 @@
|
|||||||
{
|
{
|
||||||
using Microsoft.Extensions.Configuration;
|
using Microsoft.Extensions.Configuration;
|
||||||
|
|
||||||
public class DiscordService : IDiscordService
|
public class CommunityService : ICommunityService
|
||||||
{
|
{
|
||||||
private readonly IConfiguration configuration;
|
private readonly IConfiguration configuration;
|
||||||
|
|
||||||
public DiscordService(IConfiguration configuration)
|
public CommunityService(IConfiguration configuration)
|
||||||
{
|
{
|
||||||
this.configuration = configuration;
|
this.configuration = configuration;
|
||||||
}
|
}
|
@ -1,6 +1,6 @@
|
|||||||
namespace Giants.Services
|
namespace Giants.Services
|
||||||
{
|
{
|
||||||
public interface IDiscordService
|
public interface ICommunityService
|
||||||
{
|
{
|
||||||
string GetDiscordUri();
|
string GetDiscordUri();
|
||||||
}
|
}
|
@ -342,13 +342,13 @@ namespace Giants.WebApi.Clients
|
|||||||
}
|
}
|
||||||
|
|
||||||
[System.CodeDom.Compiler.GeneratedCode("NSwag", "13.7.0.0 (NJsonSchema v10.1.24.0 (Newtonsoft.Json v11.0.0.0))")]
|
[System.CodeDom.Compiler.GeneratedCode("NSwag", "13.7.0.0 (NJsonSchema v10.1.24.0 (Newtonsoft.Json v11.0.0.0))")]
|
||||||
public partial class DiscordClient
|
public partial class CommunityClient
|
||||||
{
|
{
|
||||||
private string _baseUrl = "https://localhost:44304";
|
private string _baseUrl = "https://localhost:44304";
|
||||||
private System.Net.Http.HttpClient _httpClient;
|
private System.Net.Http.HttpClient _httpClient;
|
||||||
private System.Lazy<Newtonsoft.Json.JsonSerializerSettings> _settings;
|
private System.Lazy<Newtonsoft.Json.JsonSerializerSettings> _settings;
|
||||||
|
|
||||||
public DiscordClient(System.Net.Http.HttpClient httpClient)
|
public CommunityClient(System.Net.Http.HttpClient httpClient)
|
||||||
{
|
{
|
||||||
_httpClient = httpClient;
|
_httpClient = httpClient;
|
||||||
_settings = new System.Lazy<Newtonsoft.Json.JsonSerializerSettings>(CreateSerializerSettings);
|
_settings = new System.Lazy<Newtonsoft.Json.JsonSerializerSettings>(CreateSerializerSettings);
|
||||||
@ -375,17 +375,17 @@ namespace Giants.WebApi.Clients
|
|||||||
partial void ProcessResponse(System.Net.Http.HttpClient client, System.Net.Http.HttpResponseMessage response);
|
partial void ProcessResponse(System.Net.Http.HttpClient client, System.Net.Http.HttpResponseMessage response);
|
||||||
|
|
||||||
/// <exception cref="ApiException">A server side error occurred.</exception>
|
/// <exception cref="ApiException">A server side error occurred.</exception>
|
||||||
public System.Threading.Tasks.Task<DiscordStatus> GetDiscordStatusAsync()
|
public System.Threading.Tasks.Task<CommunityStatus> GetDiscordStatusAsync()
|
||||||
{
|
{
|
||||||
return GetDiscordStatusAsync(System.Threading.CancellationToken.None);
|
return GetDiscordStatusAsync(System.Threading.CancellationToken.None);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <param name="cancellationToken">A cancellation token that can be used by other objects or threads to receive notice of cancellation.</param>
|
/// <param name="cancellationToken">A cancellation token that can be used by other objects or threads to receive notice of cancellation.</param>
|
||||||
/// <exception cref="ApiException">A server side error occurred.</exception>
|
/// <exception cref="ApiException">A server side error occurred.</exception>
|
||||||
public async System.Threading.Tasks.Task<DiscordStatus> GetDiscordStatusAsync(System.Threading.CancellationToken cancellationToken)
|
public async System.Threading.Tasks.Task<CommunityStatus> GetDiscordStatusAsync(System.Threading.CancellationToken cancellationToken)
|
||||||
{
|
{
|
||||||
var urlBuilder_ = new System.Text.StringBuilder();
|
var urlBuilder_ = new System.Text.StringBuilder();
|
||||||
urlBuilder_.Append(BaseUrl != null ? BaseUrl.TrimEnd('/') : "").Append("/api/Discord");
|
urlBuilder_.Append(BaseUrl != null ? BaseUrl.TrimEnd('/') : "").Append("/api/Community");
|
||||||
|
|
||||||
var client_ = _httpClient;
|
var client_ = _httpClient;
|
||||||
try
|
try
|
||||||
@ -415,7 +415,7 @@ namespace Giants.WebApi.Clients
|
|||||||
var status_ = (int)response_.StatusCode;
|
var status_ = (int)response_.StatusCode;
|
||||||
if (status_ == 200)
|
if (status_ == 200)
|
||||||
{
|
{
|
||||||
var objectResponse_ = await ReadObjectResponseAsync<DiscordStatus>(response_, headers_).ConfigureAwait(false);
|
var objectResponse_ = await ReadObjectResponseAsync<CommunityStatus>(response_, headers_).ConfigureAwait(false);
|
||||||
if (objectResponse_.Object == null)
|
if (objectResponse_.Object == null)
|
||||||
{
|
{
|
||||||
throw new ApiException("Response was null which was not expected.", status_, objectResponse_.Text, headers_, null);
|
throw new ApiException("Response was null which was not expected.", status_, objectResponse_.Text, headers_, null);
|
||||||
@ -857,10 +857,13 @@ namespace Giants.WebApi.Clients
|
|||||||
}
|
}
|
||||||
|
|
||||||
[System.CodeDom.Compiler.GeneratedCode("NJsonSchema", "10.1.24.0 (Newtonsoft.Json v11.0.0.0)")]
|
[System.CodeDom.Compiler.GeneratedCode("NJsonSchema", "10.1.24.0 (Newtonsoft.Json v11.0.0.0)")]
|
||||||
public partial class DiscordStatus
|
public partial class CommunityStatus
|
||||||
{
|
{
|
||||||
[Newtonsoft.Json.JsonProperty("discordUri", Required = Newtonsoft.Json.Required.Default, NullValueHandling = Newtonsoft.Json.NullValueHandling.Ignore)]
|
[Newtonsoft.Json.JsonProperty("communityAppName", Required = Newtonsoft.Json.Required.Default, NullValueHandling = Newtonsoft.Json.NullValueHandling.Ignore)]
|
||||||
public string DiscordUri { get; set; }
|
public string CommunityAppName { get; set; }
|
||||||
|
|
||||||
|
[Newtonsoft.Json.JsonProperty("communityAppUri", Required = Newtonsoft.Json.Required.Default, NullValueHandling = Newtonsoft.Json.NullValueHandling.Ignore)]
|
||||||
|
public string CommunityAppUri { get; set; }
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -68,19 +68,19 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"/api/Discord": {
|
"/api/Community": {
|
||||||
"get": {
|
"get": {
|
||||||
"tags": [
|
"tags": [
|
||||||
"Discord"
|
"Community"
|
||||||
],
|
],
|
||||||
"operationId": "Discord_GetDiscordStatus",
|
"operationId": "Community_GetDiscordStatus",
|
||||||
"responses": {
|
"responses": {
|
||||||
"200": {
|
"200": {
|
||||||
"description": "",
|
"description": "",
|
||||||
"content": {
|
"content": {
|
||||||
"application/json": {
|
"application/json": {
|
||||||
"schema": {
|
"schema": {
|
||||||
"$ref": "#/components/schemas/DiscordStatus"
|
"$ref": "#/components/schemas/CommunityStatus"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -281,11 +281,15 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"DiscordStatus": {
|
"CommunityStatus": {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"additionalProperties": false,
|
"additionalProperties": false,
|
||||||
"properties": {
|
"properties": {
|
||||||
"discordUri": {
|
"communityAppName": {
|
||||||
|
"type": "string",
|
||||||
|
"nullable": true
|
||||||
|
},
|
||||||
|
"communityAppUri": {
|
||||||
"type": "string",
|
"type": "string",
|
||||||
"nullable": true
|
"nullable": true
|
||||||
}
|
}
|
||||||
|
@ -6,22 +6,23 @@
|
|||||||
|
|
||||||
[ApiController]
|
[ApiController]
|
||||||
[Route("api/[controller]")]
|
[Route("api/[controller]")]
|
||||||
public class DiscordController : ControllerBase
|
public class CommunityController : ControllerBase
|
||||||
{
|
{
|
||||||
private readonly IDiscordService discordService;
|
private readonly ICommunityService discordService;
|
||||||
|
|
||||||
public DiscordController(
|
public CommunityController(
|
||||||
IDiscordService discordService)
|
ICommunityService communityService)
|
||||||
{
|
{
|
||||||
this.discordService = discordService;
|
this.discordService = communityService;
|
||||||
}
|
}
|
||||||
|
|
||||||
[HttpGet]
|
[HttpGet]
|
||||||
public DiscordStatus GetDiscordStatus()
|
public CommunityStatus GetDiscordStatus()
|
||||||
{
|
{
|
||||||
return new DiscordStatus
|
return new CommunityStatus
|
||||||
{
|
{
|
||||||
DiscordUri = this.discordService.GetDiscordUri()
|
CommunityAppName = "Discord",
|
||||||
|
CommunityAppUri = this.discordService.GetDiscordUri()
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user