validate chathub calls
This commit is contained in:
@ -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);
|
||||||
|
12
src/Yavsc/Resources/Yavsc.ChatHub.Designer.cs
generated
12
src/Yavsc/Resources/Yavsc.ChatHub.Designer.cs
generated
@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
@ -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);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user