Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/master' into pm-mypackages-update
Browse files Browse the repository at this point in the history
  • Loading branch information
dnenov committed Dec 1, 2023
2 parents c57133c + b9ebaca commit b8f8b05
Show file tree
Hide file tree
Showing 17 changed files with 826 additions and 609 deletions.
17 changes: 15 additions & 2 deletions src/DynamoCore/Core/IDSDKManager.cs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ namespace Dynamo.Core
/// <summary>
/// The class to provide auth APIs for IDSDK related methods.
/// </summary>
public class IDSDKManager : IOAuth2AuthProvider, IOAuth2AccessTokenProvider
public class IDSDKManager : IOAuth2AuthProvider, IOAuth2AccessTokenProvider, IDisposable
{
/// <summary>
/// Used by the auth provider to request authentication.
Expand Down Expand Up @@ -228,8 +228,10 @@ private bool Initialize()
}

bool ret = GetClientIDAndServer(out idsdk_server server, out string client_id);
if (ret)
if (ret)
{
Client.LogoutCompleteEvent += AuthCompleteEventHandler;
Client.LoginCompleteEvent += AuthCompleteEventHandler;
ret = SetProductConfigs("Dynamo", server, client_id);
Client.SetServer(server);
return ret;
Expand All @@ -253,6 +255,11 @@ private bool Deinitialize()
}
return false;
}
public void Dispose()
{
Client.LoginCompleteEvent -= AuthCompleteEventHandler;
Client.LogoutCompleteEvent -= AuthCompleteEventHandler;
}
private bool GetClientIDAndServer(out idsdk_server server, out string client_id)
{
server = idsdk_server.IDSDK_PRODUCTION_SERVER;
Expand All @@ -273,6 +280,12 @@ private bool GetClientIDAndServer(out idsdk_server server, out string client_id)
}
return !string.IsNullOrEmpty(client_id);
}

// Event handler for LogoutCompleteEvent and LoginCompleteEvent that is thrown whenever the user's auth state changes.
private void AuthCompleteEventHandler(object sender, Client.TypedEventArgs e)
{
OnLoginStateChanged(LoginState);
}
#endregion
}
}
5 changes: 5 additions & 0 deletions src/DynamoCore/Models/DynamoModel.cs
Original file line number Diff line number Diff line change
Expand Up @@ -1456,6 +1456,11 @@ public void Dispose()
{
SearchModel.ItemProduced -= SearchModel_ItemProduced;
}
//handle the disposal of IDSDK manager instance for sandbox
if (AuthenticationManager?.AuthProvider is IDSDKManager idsdkProvider)
{
idsdkProvider?.Dispose();
}
}

private void InitializeCustomNodeManager()
Expand Down
24 changes: 19 additions & 5 deletions src/DynamoCoreWpf/Controls/ShortcutToolbar.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -11,13 +11,14 @@
using System.Linq;
using System.Windows;
using System.Collections.Generic;
using System;

namespace Dynamo.UI.Controls
{
/// <summary>
/// An object which provides the data for the shortcut toolbar.
/// </summary>
public partial class ShortcutToolbar : UserControl
public partial class ShortcutToolbar : UserControl, IDisposable
{
private readonly ObservableCollection<ShortcutBarItem> shortcutBarItems;
private readonly ObservableCollection<ShortcutBarItem> shortcutBarRightSideItems;
Expand Down Expand Up @@ -57,7 +58,7 @@ public ShortcutToolbar(DynamoViewModel dynamoViewModel)
authManager = dynamoViewModel.Model.AuthenticationManager;
if (authManager.IsLoggedInInitial())
{
authManager.LoginStateChanged += SignOutHandler;
authManager.LoginStateChanged += AuthChangeHandler;
}
else {
logoutOption.Visibility = Visibility.Collapsed;
Expand All @@ -73,14 +74,28 @@ private void ShortcutToolbar_Loaded(object sender, RoutedEventArgs e)
DynamoViewModel.OnRequestShorcutToolbarLoaded(RightMenu.ActualWidth);
}

private void SignOutHandler(LoginState status)
public void Dispose()
{
if(authManager != null)
{
authManager.LoginStateChanged -= AuthChangeHandler;
}
this.Loaded -= ShortcutToolbar_Loaded;
}

private void AuthChangeHandler(LoginState status)
{
if (status == LoginState.LoggedOut)
{
LoginButton.ToolTip = Wpf.Properties.Resources.SignInButtonContentToolTip;
txtSignIn.Text = Wpf.Properties.Resources.SignInButtonText;
logoutOption.Visibility = Visibility.Collapsed;
authManager.LoginStateChanged -= SignOutHandler;
}
else if (status == LoginState.LoggedIn)
{
txtSignIn.Text = authManager.Username;
logoutOption.Visibility = Visibility.Visible;
LoginButton.ToolTip = null;
}
}

Expand Down Expand Up @@ -115,7 +130,6 @@ private void LoginButton_OnClick(object sender, RoutedEventArgs e)
tb.Text = authManager.Username;
logoutOption.Visibility = Visibility.Visible;
LoginButton.ToolTip = null;
authManager.LoginStateChanged += SignOutHandler;
}
}
}
Expand Down
1 change: 1 addition & 0 deletions src/DynamoCoreWpf/Views/Core/DynamoView.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -2968,6 +2968,7 @@ public void Dispose()

// Removing the tab items list handler
dynamoViewModel.SideBarTabItems.CollectionChanged -= this.OnCollectionChanged;
shortcutBar?.Dispose();

if (fileTrustWarningPopup != null)
{
Expand Down
47 changes: 44 additions & 3 deletions src/DynamoCoreWpf/Views/SplashScreen/SplashScreen.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
using Dynamo.Utilities;
using Dynamo.ViewModels;
using DynamoUtilities;
using Greg.AuthProviders;
using Microsoft.Web.WebView2.Core;
using Microsoft.Web.WebView2.Wpf;

Expand Down Expand Up @@ -129,9 +130,15 @@ public void OnRequestStaticSplashScreen()
}

/// <summary>
/// Constructor
/// Stores the value that indicates if the SignIn Button will be enabled(default) or not
/// </summary>
public SplashScreen()
bool enableSignInButton;

/// <summary>
/// Splash Screen Constructor.
/// <paramref name="enableSignInButton"/> Indicates if the SignIn Button will be enabled(default) or not.
/// </summary>
public SplashScreen(bool enableSignInButton = true)
{
InitializeComponent();

Expand All @@ -149,6 +156,7 @@ public SplashScreen()
RequestImportSettings = ImportSettings;
RequestSignIn = SignIn;
RequestSignOut = SignOut;
this.enableSignInButton = enableSignInButton;
}

private void DynamoModel_LanguageDetected()
Expand Down Expand Up @@ -230,12 +238,16 @@ private void LaunchDynamo(bool isCheckboxChecked)
{
viewModel.PreferenceSettings.EnableStaticSplashScreen = !isCheckboxChecked;
}
StaticSplashScreenReady -= OnStaticScreenReady;
Close();
dynamoView?.Show();
dynamoView?.Activate();
}

private void OnLoginStateChanged(LoginState state)
{
HandleSignInStatusChange(authManager.IsLoggedIn());
}

/// <summary>
/// Once main window is initialized, Dynamic Splash screen should finish loading
/// </summary>
Expand All @@ -250,6 +262,7 @@ private void OnStaticScreenReady()
// If user is launching Dynamo for the first time or chose to always show splash screen, display it. Otherwise, display Dynamo view directly.
if (viewModel.PreferenceSettings.IsFirstRun || viewModel.PreferenceSettings.EnableStaticSplashScreen)
{
authManager.LoginStateChanged += OnLoginStateChanged;
SetSignInStatus(authManager.IsLoggedInInitial());
SetLoadingDone();
}
Expand Down Expand Up @@ -346,6 +359,7 @@ internal async void SetLoadingDone()
{
await webView.CoreWebView2.ExecuteScriptAsync($"window.setLoadingDone()");
await webView.CoreWebView2.ExecuteScriptAsync($"window.setTotalLoadingTime(\"{Wpf.Properties.Resources.SplashScreenTotalLoadingTimeLabel} {totalLoadingTime}ms\")");
SetSignInEnable(enableSignInButton);
}
}

Expand Down Expand Up @@ -393,6 +407,28 @@ await webView.CoreWebView2.ExecuteScriptAsync("window.setSignInStatus({" +
}
}

/// <summary>
/// Handle the login status changes on splash screen.
/// </summary>
internal async void HandleSignInStatusChange(bool status)
{
if (webView?.CoreWebView2 != null)
{
await webView.CoreWebView2.ExecuteScriptAsync(@$"window.handleSignInStateChange({{""status"": ""{status}""}})");
}
}

/// <summary>
/// Enable or disable the SignIn button on splash screen.
/// </summary>
/// <param name="enabled"></param>
internal async void SetSignInEnable(bool enabled)
{
if (webView?.CoreWebView2 != null)
{
await webView.CoreWebView2.ExecuteScriptAsync(@$"window.setEnableSignInButton({{""enable"": ""{enabled}""}})");
}
}
/// <summary>
/// Setup the values for all labels on splash screen using resources
/// </summary>
Expand Down Expand Up @@ -509,6 +545,11 @@ protected override void OnClosed(EventArgs e)

DynamoModel.RequestUpdateLoadBarStatus -= DynamoModel_RequestUpdateLoadBarStatus;
DynamoModel.LanguageDetected -= DynamoModel_LanguageDetected;
StaticSplashScreenReady -= OnStaticScreenReady;
if (authManager is not null)
{
authManager.LoginStateChanged -= OnLoginStateChanged;
}
webView.Dispose();
webView = null;

Expand Down
17 changes: 14 additions & 3 deletions src/DynamoUtilities/CLIWrapper.cs
Original file line number Diff line number Diff line change
Expand Up @@ -96,8 +96,9 @@ protected static string GetToolPath(string relativePath)
/// Read data from CLI tool
/// </summary>
/// <param name="timeoutms">will return empty string if we don't finish reading all data in the timeout provided in milliseconds.</param>
/// <param name="mockReadLine"> if this delegate is non null, it will be used instead of communicating with std out of the process. Used for testing only.</param>
/// <returns></returns>
protected virtual async Task<string> GetData(int timeoutms)
protected virtual string GetData(int timeoutms, Func<string> mockReadLine = null)
{
var readStdOutTask = Task.Run(() =>
{
Expand All @@ -114,7 +115,17 @@ protected virtual async Task<string> GetData(int timeoutms)
{
try
{
var line = process.StandardOutput.ReadLine();
string line = null;
if(mockReadLine != null)
{
line = mockReadLine.Invoke();
}
else
{
line = process.StandardOutput.ReadLine();
}


MessageLogged?.Invoke(line);
if (line == null || line == startofDataToken)
{
Expand Down Expand Up @@ -145,7 +156,7 @@ protected virtual async Task<string> GetData(int timeoutms)
return writer.ToString();
}
});
var completedTask = await Task.WhenAny(readStdOutTask, Task.Delay(TimeSpan.FromMilliseconds(timeoutms)));
var completedTask = Task.WhenAny(readStdOutTask, Task.Delay(TimeSpan.FromMilliseconds(timeoutms))).Result;
//if the completed task was our read std out task, then return the data
//else we timed out, so return an empty string.
return completedTask == readStdOutTask ? readStdOutTask.Result : string.Empty;
Expand Down
2 changes: 1 addition & 1 deletion src/DynamoUtilities/DynamoFeatureFlagsManager.cs
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ internal void CacheAllFlags()
{

//wait for response
var dataFromCLI = GetData(featureFlagTimeoutMs).Result;
var dataFromCLI = GetData(featureFlagTimeoutMs);
//convert from json string to dictionary.
try
{
Expand Down
8 changes: 2 additions & 6 deletions src/DynamoUtilities/Md2Html.cs
Original file line number Diff line number Diff line change
Expand Up @@ -73,9 +73,7 @@ internal string ParseMd2Html(string mdString, string mdPath)
return GetCantCommunicateErrorMessage();
}

var output = GetData(processCommunicationTimeoutms);

return output.Result;
return GetData(processCommunicationTimeoutms);
}

/// <summary>
Expand All @@ -102,9 +100,7 @@ internal string SanitizeHtml(string content)
return GetCantCommunicateErrorMessage();
}

var output = GetData(processCommunicationTimeoutms);

return output.Result;
return GetData(processCommunicationTimeoutms);
}

/// <summary>
Expand Down
Loading

0 comments on commit b8f8b05

Please sign in to comment.