status-go/protocol/requests/edit_community.go
Eric Mastro 4d8d3fb0e8
feat: Add edit communities (#2229)
* feat: Add edit communities

Allow Communities to be edited, including display name, description, color, membership, and permissions.

* Added EditCommunity request type

* Fix lint errors

* Allow editing community without changing image

Previously, retaining an existing community image was not possible because the existing community image path had to be provided in the `editCommunity` RPC call to retain the image. However, once the image is processed by status-go, it is encoded as a base64 string and therefore it is not possible to get the original file path back from this string.

This commit allows for the original to be retained by passing an empty string for the image field in the RPC call.

* Don't change permissions. Fixed clock updating

Co-authored-by: Volodymyr Kozieiev <vkjr.sp@gmail.com>
2021-05-18 15:32:15 -04:00

48 lines
1.1 KiB
Go

package requests
import (
"errors"
"github.com/status-im/status-go/eth-node/types"
"github.com/status-im/status-go/protocol/protobuf"
)
var (
ErrEditCommunityInvalidID = errors.New("edit-community: invalid id")
ErrEditCommunityInvalidName = errors.New("edit-community: invalid name")
ErrEditCommunityInvalidColor = errors.New("edit-community: invalid color")
ErrEditCommunityInvalidDescription = errors.New("edit-community: invalid description")
ErrEditCommunityInvalidMembership = errors.New("edit-community: invalid membership")
)
type EditCommunity struct {
CommunityID types.HexBytes
CreateCommunity
}
func (u *EditCommunity) Validate() error {
if len(u.CommunityID) == 0 {
return ErrEditCommunityInvalidID
}
if u.Name == "" {
return ErrEditCommunityInvalidName
}
if u.Description == "" {
return ErrEditCommunityInvalidDescription
}
if u.Membership == protobuf.CommunityPermissions_UNKNOWN_ACCESS {
return ErrEditCommunityInvalidMembership
}
if u.Color == "" {
return ErrEditCommunityInvalidColor
}
return nil
}