Refactor JoinChannel (whatsapp)
This commit is contained in:
parent
e3cafeaf92
commit
0205a67309
|
@ -147,51 +147,44 @@ func (b *Bwhatsapp) Disconnect() error {
|
||||||
func (b *Bwhatsapp) JoinChannel(channel config.ChannelInfo) error {
|
func (b *Bwhatsapp) JoinChannel(channel config.ChannelInfo) error {
|
||||||
byJid := isGroupJid(channel.Name)
|
byJid := isGroupJid(channel.Name)
|
||||||
|
|
||||||
|
groups, err := b.wc.GetJoinedGroups()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
// verify if we are member of the given group
|
// verify if we are member of the given group
|
||||||
if byJid {
|
if byJid {
|
||||||
gJID, err := types.ParseJID(channel.Name)
|
gJID, err := types.ParseJID(channel.Name)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
// channel.Name specifies static group jID, not the name
|
|
||||||
info, err := b.wc.Store.Contacts.GetContact(gJID)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
if !info.Found {
|
for _, group := range groups {
|
||||||
return fmt.Errorf("account doesn't belong to group with jid %s", channel.Name)
|
if group.JID == gJID {
|
||||||
}
|
return nil
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// channel.Name specifies group name that might change, warn about it
|
|
||||||
var jids []string
|
|
||||||
allContacts, err := b.wc.Store.Contacts.GetAllContacts()
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
for id := range allContacts {
|
|
||||||
if isGroupJid(id.String()) && id.String() == channel.Name {
|
|
||||||
jids = append(jids, id.String())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
switch len(jids) {
|
|
||||||
case 0:
|
|
||||||
// didn't match any group - print out possibilites
|
|
||||||
for id, contact := range allContacts {
|
|
||||||
if isGroupJid(id.String()) {
|
|
||||||
b.Log.Infof("%s %s", id, contact.FullName)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
foundGroups := []string{}
|
||||||
|
|
||||||
|
for _, group := range groups {
|
||||||
|
if group.Name == channel.Name {
|
||||||
|
foundGroups = append(foundGroups, group.Name)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
switch len(foundGroups) {
|
||||||
|
case 0:
|
||||||
|
// didn't match any group - print out possibilites
|
||||||
|
for _, group := range groups {
|
||||||
|
b.Log.Infof("%s %s", group.JID, group.Name)
|
||||||
|
}
|
||||||
return fmt.Errorf("please specify group's JID from the list above instead of the name '%s'", channel.Name)
|
return fmt.Errorf("please specify group's JID from the list above instead of the name '%s'", channel.Name)
|
||||||
case 1:
|
case 1:
|
||||||
return fmt.Errorf("group name might change. Please configure gateway with channel=\"%v\" instead of channel=\"%v\"", jids[0], channel.Name)
|
return fmt.Errorf("group name might change. Please configure gateway with channel=\"%v\" instead of channel=\"%v\"", foundGroups[0], channel.Name)
|
||||||
default:
|
default:
|
||||||
return fmt.Errorf("there is more than one group with name '%s'. Please specify one of JIDs as channel name: %v", channel.Name, jids)
|
return fmt.Errorf("there is more than one group with name '%s'. Please specify one of JIDs as channel name: %v", channel.Name, foundGroups)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue