Commit 4f531b80 authored by Juliusz Chroboczek's avatar Juliusz Chroboczek

Implement commands /lock and /unlock.

parent fc6c26e1
...@@ -1214,6 +1214,16 @@ func handleClientMessage(c *client, m clientMessage) error { ...@@ -1214,6 +1214,16 @@ func handleClientMessage(c *client, m clientMessage) error {
if err != nil { if err != nil {
return c.error(err) return c.error(err)
} }
case "lock", "unlock":
if !c.permissions.Op {
c.error(userError("not authorised"))
return nil
}
var locked uint32
if m.Type == "lock" {
locked = 1
}
atomic.StoreUint32(&c.group.locked, locked)
case "kick": case "kick":
if !c.permissions.Op { if !c.permissions.Op {
c.error(userError("not authorised")) c.error(userError("not authorised"))
......
...@@ -183,6 +183,7 @@ type group struct { ...@@ -183,6 +183,7 @@ type group struct {
dead bool dead bool
description *groupDescription description *groupDescription
videoCount uint32 videoCount uint32
locked uint32
mu sync.Mutex mu sync.Mutex
clients map[string]*client clients map[string]*client
...@@ -351,6 +352,10 @@ func addClient(name string, client *client, user, pass string) (*group, []userid ...@@ -351,6 +352,10 @@ func addClient(name string, client *client, user, pass string) (*group, []userid
} }
client.permissions = perms client.permissions = perms
if !perms.Op && atomic.LoadUint32(&g.locked) != 0 {
return nil, nil, userError("group is locked")
}
g.mu.Lock() g.mu.Lock()
defer g.mu.Unlock() defer g.mu.Unlock()
......
...@@ -867,6 +867,16 @@ function handleInput() { ...@@ -867,6 +867,16 @@ function handleInput() {
type: 'clearchat', type: 'clearchat',
}); });
return; return;
case '/lock':
case '/unlock':
if(!permissions.op) {
displayError("You're not an operator");
return;
}
send({
type: cmd === '/lock' ? 'lock' : 'unlock',
});
return;
case '/op': case '/op':
case '/unop': case '/unop':
case '/kick': case '/kick':
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment