validate chathub calls

This commit is contained in:
2019-06-18 00:24:22 +01:00
parent 883a6e2bd9
commit b964e0523d
5 changed files with 96 additions and 27 deletions

View File

@ -199,12 +199,50 @@ namespace Yavsc
return base.OnReconnected(); return base.OnReconnected();
} }
static bool IsLetterOrDigit(string s)
{
foreach (var c in s)
if (!char.IsLetterOrDigit(c))
return false;
return true;
}
bool ValidateRoomName (string roomName)
{
bool valid = ValidateStringLength(roomName,1,25);
if (valid) valid = IsLetterOrDigit(roomName);
if (!valid) NotifyUser(NotificationTypes.Error, "roomName", InvalidRoomName);
return valid;
}
bool ValidateUserName (string userName)
{
bool valid = ValidateStringLength(userName, 1,12);
if (valid) valid = IsLetterOrDigit(userName);
NotifyUser(NotificationTypes.Error, "char:"+userName.First (c => !char.IsLetterOrDigit(c)), InvalidUserName);
return valid;
}
bool ValidateMessage (string message)
{
if (!ValidateStringLength(message, 1,240))
{
NotifyUser(NotificationTypes.Error, "message", InvalidMessage);
return false;
}
return true;
}
bool ValidateReason (string reason)
{
if (!ValidateStringLength(reason, 1,240))
{
NotifyUser(NotificationTypes.Error, "reason", InvalidReason);
return false;
}
return true;
}
public void Nick(string nickName) public void Nick(string nickName)
{ {
if (!ValidateStringLength(nickName, 1,12)) if (!ValidateUserName(nickName)) return;
{
NotifyUser(NotificationTypes.Error, "user", InvalidUserName);
}
var candidate = "?" + nickName; var candidate = "?" + nickName;
if (_cxManager.IsConnected(candidate)) if (_cxManager.IsConnected(candidate))
@ -234,13 +272,10 @@ namespace Yavsc
return true; return true;
} }
public ChatRoomInfo Join(string roomName) public ChatRoomInfo Join(string roomName)
{ {
if (!ValidateStringLength(roomName,1,25)) if (!ValidateRoomName(roomName)) return null;
{
NotifyUser(NotificationTypes.Error, "room", InvalidRoomName);
return null;
}
var roomGroupName = ChatHubConstants.HubGroupRomsPrefix + roomName; var roomGroupName = ChatHubConstants.HubGroupRomsPrefix + roomName;
var user = _cxManager.GetUserName(Context.ConnectionId); var user = _cxManager.GetUserName(Context.ConnectionId);
@ -261,8 +296,9 @@ namespace Yavsc
} }
[Authorize] [Authorize]
public void Register([Required] string room) public void Register(string room)
{ {
if (!ValidateRoomName(room)) return ;
var existent = _dbContext.ChatRoom.Any(r => r.Name == room); var existent = _dbContext.ChatRoom.Any(r => r.Name == room);
if (existent) if (existent)
{ {
@ -284,13 +320,19 @@ namespace Yavsc
_dbContext.ChatRoom.Add(newroom); _dbContext.ChatRoom.Add(newroom);
_dbContext.SaveChanges(user.Id); _dbContext.SaveChanges(user.Id);
} }
public void KickBan([Required] string roomName, [Required] string userName, [Required] string reason) public void KickBan(string roomName, string userName, string reason)
{ {
if (!ValidateRoomName(roomName)) return ;
if (!ValidateUserName(userName)) return ;
if (!ValidateReason(reason)) return;
Kick(roomName, userName, reason); Kick(roomName, userName, reason);
Ban(roomName, userName, reason); Ban(roomName, userName, reason);
} }
public void Kick([Required] string roomName, [Required] string userName, [Required] string reason) public void Kick(string roomName, string userName, string reason)
{ {
if (!ValidateRoomName(roomName)) return ;
if (!ValidateUserName(userName)) return ;
if (!ValidateReason(reason)) return;
ChatRoomInfo chanInfo; ChatRoomInfo chanInfo;
var roomGroupName = ChatHubConstants.HubGroupRomsPrefix + roomName; var roomGroupName = ChatHubConstants.HubGroupRomsPrefix + roomName;
if (_cxManager.TryGetChanInfo(roomName, out chanInfo)) if (_cxManager.TryGetChanInfo(roomName, out chanInfo))
@ -311,18 +353,25 @@ namespace Yavsc
Clients.Group(roomGroupName).notifyRoom(NotificationTypes.Kick, roomName, $"{userName}: {reason}"); Clients.Group(roomGroupName).notifyRoom(NotificationTypes.Kick, roomName, $"{userName}: {reason}");
} }
public void Ban([Required] string roomName, [Required] string userName, [Required] string reason) public void Ban(string roomName, string userName, string reason)
{ {
if (!ValidateRoomName(roomName)) return ;
if (!ValidateUserName(userName)) return ;
if (!ValidateReason(reason)) return;
var cxIds = _cxManager.GetConnexionIds(userName); var cxIds = _cxManager.GetConnexionIds(userName);
throw new NotImplementedException(); throw new NotImplementedException();
} }
public void Gline([Required] string userName, [Required] string reason) public void Gline(string userName, string reason)
{ {
if (!ValidateUserName(userName)) return ;
if (!ValidateReason(reason)) return;
throw new NotImplementedException(); throw new NotImplementedException();
} }
public void Part([Required] string roomName, [Required] string reason) public void Part(string roomName, string reason)
{ {
if (!ValidateRoomName(roomName)) return ;
if (!ValidateReason(reason)) return;
if (_cxManager.Part(Context.ConnectionId, roomName, reason)) if (_cxManager.Part(Context.ConnectionId, roomName, reason))
{ {
var roomGroupName = ChatHubConstants.HubGroupRomsPrefix + roomName; var roomGroupName = ChatHubConstants.HubGroupRomsPrefix + roomName;
@ -342,8 +391,11 @@ namespace Yavsc
_logger.LogError($"NotifyErrorToCallerInRoom: {room}, {reason}"); _logger.LogError($"NotifyErrorToCallerInRoom: {room}, {reason}");
} }
public void Send([Required] string roomName, [Required] string message) public void Send(string roomName, string message)
{ {
if (!ValidateRoomName(roomName)) return ;
if (!ValidateMessage(message)) return ;
var groupname = ChatHubConstants.HubGroupRomsPrefix + roomName; var groupname = ChatHubConstants.HubGroupRomsPrefix + roomName;
ChatRoomInfo chanInfo ; ChatRoomInfo chanInfo ;
if (!_cxManager.TryGetChanInfo(roomName, out chanInfo)) if (!_cxManager.TryGetChanInfo(roomName, out chanInfo))
@ -371,13 +423,10 @@ namespace Yavsc
} }
[Authorize] [Authorize]
public void SendPV([Required] string userName, [Required] string message) public void SendPV(string userName, string message)
{ {
if (string.IsNullOrWhiteSpace(userName)) if (!ValidateUserName(userName)) return ;
{ if (!ValidateMessage(message)) return ;
NotifyUser(NotificationTypes.Error, "none!", "specify an user.");
return;
}
if (userName[0] != '?') if (userName[0] != '?')
if (!Context.User.IsInRole(Constants.AdminGroupName)) if (!Context.User.IsInRole(Constants.AdminGroupName))
@ -405,8 +454,9 @@ namespace Yavsc
[Authorize] [Authorize]
public void SendStream([Required] string connectionId, long streamId, [Required] string message) public void SendStream(string connectionId, long streamId, string message)
{ {
if (!ValidateMessage(message)) return;
var sender = Context.User.Identity.Name; var sender = Context.User.Identity.Name;
var cli = Clients.Client(connectionId); var cli = Clients.Client(connectionId);
cli.addStreamInfo(sender, streamId, message); cli.addStreamInfo(sender, streamId, message);

View File

@ -66,5 +66,17 @@ namespace Yavsc {
return ResourceManager.GetString("InvalidUserName", resourceCulture); return ResourceManager.GetString("InvalidUserName", resourceCulture);
} }
} }
public static string InvalidMessage {
get {
return ResourceManager.GetString("InvalidMessage", resourceCulture);
}
}
public static string InvalidReason {
get {
return ResourceManager.GetString("InvalidReason", resourceCulture);
}
}
} }
} }

View File

@ -65,4 +65,5 @@
<data name="LabnoJoinNoSend"><value>could not send to channel (not joint)</value></data> <data name="LabnoJoinNoSend"><value>could not send to channel (not joint)</value></data>
<data name="InvalidRoomName"><value>Invalid room name</value></data> <data name="InvalidRoomName"><value>Invalid room name</value></data>
<data name="InvalidUserName"><value>Invalid user name</value></data> <data name="InvalidUserName"><value>Invalid user name</value></data>
<data name="InvalidReason"><value>invalid Reason</value></data>
</root> </root>

View File

@ -65,5 +65,7 @@
<data name="LabnoJoinNoSend"><value>Envoi impossible: vous devez joindre le canal pour y contribuer.</value></data> <data name="LabnoJoinNoSend"><value>Envoi impossible: vous devez joindre le canal pour y contribuer.</value></data>
<data name="InvalidRoomName"><value>Nom de salon invalide</value></data> <data name="InvalidRoomName"><value>Nom de salon invalide</value></data>
<data name="InvalidUserName"><value>Nom d'utilisateur invalide</value></data> <data name="InvalidUserName"><value>Nom d'utilisateur invalide</value></data>
<data name="InvalidMessage"><value>Message invalide</value></data>
<data name="InvalidReason"><value>Raison invalide</value></data>
</root> </root>

View File

@ -110,8 +110,10 @@ window.ChatHubHandler = (function ($) {
}; };
var setChanInfo = function (chanInfo) { var setChanInfo = function (chanInfo) {
var chanId = 'r' + chanInfo.Name; if (chanInfo) {
$('#tv_' + chanId).replaceWith(chanInfo.Topic); var chanId = 'r' + chanInfo.Name;
$('#tv_' + chanId).replaceWith(chanInfo.Topic);
}
} }
var setActiveChan = function (chanId) { var setActiveChan = function (chanId) {
@ -130,8 +132,10 @@ window.ChatHubHandler = (function ($) {
function join(roomName) function join(roomName)
{ {
chat.server.join(roomName).done(function (chatInfo) { chat.server.join(roomName).done(function (chatInfo) {
setChanInfo(chatInfo); if (chatInfo) {
setActiveChan('r'+chatInfo.Name); setChanInfo(chatInfo);
setActiveChan('r'+chatInfo.Name);
}
}); });
} }