3
0
mirror of https://github.com/ergochat/ergo.git synced 2025-01-24 11:14:10 +01:00

channel: Give founder mode if channel already exists and founder joins

This commit is contained in:
Daniel Oaks 2017-03-27 14:52:34 +10:00
parent 127d0ff681
commit 013635a827

View File

@ -269,23 +269,26 @@ func (channel *Channel) Join(client *Client, key string) {
client.channels.Add(channel) client.channels.Add(channel)
channel.members.Add(client) channel.members.Add(client)
var givenMode *Mode
if len(channel.members) == 1 {
client.server.registeredChannelsMutex.Lock()
defer client.server.registeredChannelsMutex.Unlock()
client.server.store.Update(func(tx *buntdb.Tx) error {
chanReg := client.server.loadChannelNoMutex(tx, channel.nameCasefolded)
if chanReg == nil { // give channel mode if necessary
channel.createdTime = time.Now() var givenMode *Mode
channel.members[client][ChannelOperator] = true client.server.registeredChannelsMutex.Lock()
givenMode = &ChannelOperator defer client.server.registeredChannelsMutex.Unlock()
} else { client.server.store.Update(func(tx *buntdb.Tx) error {
// we should only do this on registered channels chanReg := client.server.loadChannelNoMutex(tx, channel.nameCasefolded)
if client.account != nil && client.account.Name == chanReg.Founder {
channel.members[client][ChannelFounder] = true if chanReg == nil {
givenMode = &ChannelFounder channel.createdTime = time.Now()
} channel.members[client][ChannelOperator] = true
givenMode = &ChannelOperator
} else {
// we should only do this on registered channels
if client.account != nil && client.account.Name == chanReg.Founder {
channel.members[client][ChannelFounder] = true
givenMode = &ChannelFounder
}
if len(channel.members) == 1 {
// apply other details if new channel
channel.topic = chanReg.Topic channel.topic = chanReg.Topic
channel.topicSetBy = chanReg.TopicSetBy channel.topicSetBy = chanReg.TopicSetBy
channel.topicSetTime = chanReg.TopicSetTime channel.topicSetTime = chanReg.TopicSetTime
@ -301,9 +304,9 @@ func (channel *Channel) Join(client *Client, key string) {
channel.lists[InviteMask].Add(mask) channel.lists[InviteMask].Add(mask)
} }
} }
return nil }
}) return nil
} })
if client.capabilities[ExtendedJoin] { if client.capabilities[ExtendedJoin] {
client.Send(nil, client.nickMaskString, "JOIN", channel.name, client.account.Name, client.realname) client.Send(nil, client.nickMaskString, "JOIN", channel.name, client.account.Name, client.realname)
@ -313,7 +316,9 @@ func (channel *Channel) Join(client *Client, key string) {
channel.getTopicNoMutex(client) // we already have Lock channel.getTopicNoMutex(client) // we already have Lock
channel.namesNoMutex(client) channel.namesNoMutex(client)
if givenMode != nil { if givenMode != nil {
client.Send(nil, client.server.name, "MODE", channel.name, fmt.Sprintf("+%v", *givenMode), client.nick) for member := range channel.members {
member.Send(nil, client.server.name, "MODE", channel.name, fmt.Sprintf("+%v", *givenMode), client.nick)
}
} }
} }