Skip to content

Conversation

@lgund
Copy link

@lgund lgund commented Aug 17, 2020

A lot of Bugfixes like in pull request #57. But now it's also possible to create ssh connections and Telnet connections. See example here #58

I would like to prefer this as new mayor version 2.0. So we could have 1 big break and then we don't need to talk about this anymore 👍

using TeamSpeak3QueryApi.Net.Parameters;

namespace TeamSpeak3QueryApi.Net
namespace TeamSpeak3QueryApi.Net.Query
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is part of the query client and belongs to the TeamSpeak3QueryApi.Net namespace.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Cause a query command is still part of the query client. So it should stay in the query folder.

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The namespcae layout is as follows:

namespace TeamSpeak3QueryApi.Net: Everything related to the Query protocol itself (that also the regular TS client uses)
namespace TeamSpeak3QueryApi.Net.Specialised: While the name Specialised is disputable, this contains the concrete server query implementation.

One core principle is that the child namespaces should only rely on the parent namespaces (not some sibling namespace) if possible. Introducing a Query namespace would break this semantic.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You mean I should change the class name QueryClient to just Client cause it´s in the namespace Query? (For example)

@nikeee
Copy link
Owner

nikeee commented Aug 17, 2020

Thanks for the PR!
I reviewed parts of it. It's such a large PR that I cannot review this entirely in my spare time.
I think the best way to approach the review is to read all comments and then do some changes.

@lgund
Copy link
Author

lgund commented Aug 17, 2020

All changes they have a like will be changed until next week. I am this week not @home.

I know this is a big pr but this isn't a final version for sure. I just want to create a final version with ssh support for everyone. I am sure this brench need some investigation.

@lgund
Copy link
Author

lgund commented Aug 26, 2020

So I´am done. Let me know if something else should be fixed or changed.

@lgund lgund marked this pull request as draft August 26, 2020 11:30
@lgund lgund marked this pull request as ready for review August 26, 2020 11:30
@lgund lgund requested a review from nikeee August 26, 2020 12:31
public interface IProtocol
{
Task<CancellationTokenSource> ConnectAsync();
CancellationTokenSource Connect(string username, string password);
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A CancellationToken should be returned, not a CancellationTokenSource

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why? This function is not changed. You also returned the CancellationTokenSource. It´s needed for the processingloop. Did I miss something?

/// <summary>Gets the remote host of the Query API client.</summary>
/// <returns>The remote host of the Query API client.</returns>
public string Host { get; }
public string Host { get; internal set; }
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why internal?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don´t want that somebody outside this class could change the host. But the Ssh or Telnet client need to set the host and for that it must get more access.

using TeamSpeak3QueryApi.Net.Parameters;

namespace TeamSpeak3QueryApi.Net
namespace TeamSpeak3QueryApi.Net.Query
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The namespcae layout is as follows:

namespace TeamSpeak3QueryApi.Net: Everything related to the Query protocol itself (that also the regular TS client uses)
namespace TeamSpeak3QueryApi.Net.Specialised: While the name Specialised is disputable, this contains the concrete server query implementation.

One core principle is that the child namespaces should only rely on the parent namespaces (not some sibling namespace) if possible. Introducing a Query namespace would break this semantic.

using TeamSpeak3QueryApi.Net.Query.Parameters;
using TeamSpeak3QueryApi.Net.Query.Responses;
using TeamSpeak3QueryApi.Net.Query.Enums;
using TeamSpeak3QueryApi.Net.Query.Protocols;
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

While I think namespaces like Enums etc. might be good for applications, I don't think that a library should use that pattern. For example System.Windows.Forms doesn't have something like Controls, Components etc. either. This way, the core principle mentioned above is easier to follow.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this is a matter of taste. I would like to stay like this. It´s for me better readable if we stay in folder and not change the classnames. Or we could change the classnames and stay also in the folders?

@lgund lgund requested a review from nikeee August 27, 2020 09:11
@lgund
Copy link
Author

lgund commented Sep 4, 2020

Is still interested in this pr, if not I would release it as a new nuget package.

@nikeee
Copy link
Owner

nikeee commented Sep 4, 2020

I'm still interested in merging this! :)

Currently, I'm short on spare time for this project. Maybe we can settle this down this weekend.

@nikeee nikeee merged commit 8bd4048 into nikeee:ssh Sep 7, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants