12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- using System;
- using System.Collections.Generic;
- using SMBLibrary.Authentication.GSSAPI;
- using SMBLibrary.Authentication.NTLM;
- using SMBLibrary.SMB2;
- using Utilities;
- namespace SMBLibrary.Server.SMB2
- {
-
-
-
- internal class SessionSetupHelper
- {
- internal static SMB2Command GetSessionSetupResponse(SessionSetupRequest request, GSSProvider securityProvider, SMB2ConnectionState state)
- {
-
- SessionSetupResponse response = new SessionSetupResponse();
- byte[] outputToken;
- NTStatus status = securityProvider.AcceptSecurityContext(ref state.AuthenticationContext, request.SecurityBuffer, out outputToken);
- if (status != NTStatus.STATUS_SUCCESS && status != NTStatus.SEC_I_CONTINUE_NEEDED)
- {
- string userName = securityProvider.GetContextAttribute(state.AuthenticationContext, GSSAttributeName.UserName) as string;
- state.LogToServer(Severity.Information, "User '{0}' failed authentication, NTStatus: {1}", userName, status);
- return new ErrorResponse(request.CommandName, status);
- }
- if (outputToken != null)
- {
- response.SecurityBuffer = outputToken;
- }
-
- if (request.Header.SessionID == 0)
- {
- ulong? sessionID = state.AllocateSessionID();
- if (!sessionID.HasValue)
- {
- return new ErrorResponse(request.CommandName, NTStatus.STATUS_TOO_MANY_SESSIONS);
- }
- response.Header.SessionID = sessionID.Value;
- }
- if (status == NTStatus.SEC_I_CONTINUE_NEEDED)
- {
- response.Header.Status = NTStatus.STATUS_MORE_PROCESSING_REQUIRED;
- }
- else
- {
- string userName = securityProvider.GetContextAttribute(state.AuthenticationContext, GSSAttributeName.UserName) as string;
- string machineName = securityProvider.GetContextAttribute(state.AuthenticationContext, GSSAttributeName.MachineName) as string;
- byte[] sessionKey = securityProvider.GetContextAttribute(state.AuthenticationContext, GSSAttributeName.SessionKey) as byte[];
- object accessToken = securityProvider.GetContextAttribute(state.AuthenticationContext, GSSAttributeName.AccessToken);
- bool? isGuest = securityProvider.GetContextAttribute(state.AuthenticationContext, GSSAttributeName.IsGuest) as bool?;
- if (!isGuest.HasValue || !isGuest.Value)
- {
- state.LogToServer(Severity.Information, "User '{0}' authenticated successfully.", userName);
- state.CreateSession(request.Header.SessionID, userName, machineName, sessionKey, accessToken);
- }
- else
- {
- state.LogToServer(Severity.Information, "User '{0}' failed authentication, logged in as guest.", userName);
- state.CreateSession(request.Header.SessionID, "Guest", machineName, sessionKey, accessToken);
- response.SessionFlags = SessionFlags.IsGuest;
- }
- }
- return response;
- }
- }
- }
|