Go Back

0 package db

1

2 import (

3 "errors"

4 )

5

6 func groupAlreadyExist(group string) (error) {

7 rows, err := db.Query(

8 "SELECT * FROM groups WHERE UPPER(name) LIKE UPPER(?)",

9 group)

10 if err != nil {

11 return err

12 }

13 defer rows.Close()

14 if rows.Next() {

15 return errors.New(

16 "A group with the same name already exist")

17 }

18 return nil

19 }

20

21 func (user User) CreateGroup(group string, signature string) error {

22 if err := user.VerifySignature(signature); err != nil {

23 return err

24 }

25

26 if err := isGroupNameValid(group); err != nil {

27 return err

28 }

29

30 err := groupAlreadyExist(group)

31 if err != nil {

32 return err

33 }

34

35 rows, err := db.Exec("INSERT INTO groups " +

36 "(owner, name, description, creation) " +

37 "VALUES(?, ?, \"\", " + unixTime + ")",

38 user.ID, group)

39 if err != nil {

40 return err

41 }

42

43 groupID, err := rows.LastInsertId()

44 if err != nil {

45 return err

46 }

47

48 _, err = db.Exec("INSERT INTO member (groupID, userID) " +

49 "VALUES(?, ?)", groupID, user.ID)

50 if err != nil {

51 return err

52 }

53

54 return nil

55 }

56

57 func GetGroupDesc(name string) (string, error) {

58 query := "SELECT description FROM groups WHERE UPPER(?) = UPPER(name);"

59 rows, err := db.Query(query, name)

60 if err != nil {

61 return "", err

62 }

63 defer rows.Close()

64 if !rows.Next() {

65 return "", errors.New("Group not found")

66 }

67 var desc string

68 err = rows.Scan(&desc)

69 if err != nil {

70 return "", err

71 }

72 return desc, nil

73 }

74

75 func GetGroupID(name string) (int, error) {

76 query := "SELECT groupID FROM groups WHERE UPPER(?) = UPPER(name);"

77 rows, err := db.Query(query, name)

78 if err != nil {

79 return -1, err

80 }

81 defer rows.Close()

82 if !rows.Next() {

83 return -1, errors.New("Group not found")

84 }

85 var id int

86 err = rows.Scan(&id)

87 if err != nil {

88 return -1, err

89 }

90 return id, nil

91 }

92

93 func IsInGroup(userID int, groupID int) (error) {

94 query := "SELECT * FROM member WHERE userID=? AND groupID=?"

95 rows, err := db.Query(query, userID, groupID)

96 if err != nil {

97 return err

98 }

99 defer rows.Close()

100 if rows.Next() {

101 return errors.New("The user is already in the group")

102 }

103 return nil

104 }

105

106 func (u User) AddUserToGroup(group string, user string) error {

107 owner, err := GetGroupOwner(group)

108 if err != nil {

109 return err

110 }

111 if u.ID != owner.UserID {

112 return errors.New("only the group owner can add members")

113 }

114 id, err := GetGroupID(group)

115 if err != nil {

116 return err

117 }

118 userID, err := GetUserID(user)

119 if err != nil {

120 return err

121 }

122 if err = IsInGroup(userID, id); err != nil {

123 return err

124 }

125 _, err = db.Exec("INSERT INTO member (groupID, userID) " +

126 "VALUES(?, ?)", id, userID)

127 if err != nil {

128 return err

129 }

130 return nil

131 }

132

133 func DeleteMember(user int, group int) error {

134 statement, err := db.Exec("DELETE FROM member " +

135 "WHERE userID = ? AND groupID = ?",

136 user, group)

137 if err != nil {

138 return err

139 }

140 rows, err := statement.RowsAffected()

141 if err != nil {

142 return err

143 }

144 if rows < 1 {

145 return errors.New("The user is not a member of the group")

146 }

147 return nil

148 }

149

150 func SetGroupDescription(group int, desc string) error {

151 if len(desc) >= descriptionMaxLength {

152 return errors.New("description too long")

153 }

154 res, err := db.Exec("UPDATE groups SET description = ? " +

155 "WHERE groupID = ?", desc, group)

156 if err != nil {

157 return err

158 }

159 rows, err := res.RowsAffected()

160 if rows < 1 {

161 return errors.New("group not found")

162 }

163 return err

164 }

165

166 func DeleteGroup(group int) error {

167 statement, err := db.Exec("DELETE FROM groups " +

168 "WHERE groupID = ?", group)

169 if err != nil {

170 return err

171 }

172 rows, err := statement.RowsAffected()

173 if err != nil {

174 return err

175 }

176 if rows < 1 {

177 return errors.New("There's no such group")

178 }

179 statement, err = db.Exec("DELETE FROM member " +

180 "WHERE groupID = ?", group)

181 if err != nil {

182 return err

183 }

184 return nil

185 }

186

187 func (user User) IsInGroupID(groupID int) (bool, error) {

188 query := "SELECT owner FROM member a " +

189 "INNER JOIN groups b ON a.groupID = b.groupID " +

190 "WHERE a.userID = ? AND a.groupID = ? "

191 rows, err := db.Query(query, user.ID, groupID)

192 if err != nil {

193 return false, err

194 }

195 defer rows.Close()

196 if !rows.Next() {

197 return false, errors.New("Group not found")

198 }

199 var owner int

200 err = rows.Scan(&owner)

201 if err != nil {

202 return false, err

203 }

204 return owner == user.ID, nil

205 }

206

207 func GetGroupOwner(group string) (Member, error) {

208 query := "SELECT c.name, a.userID FROM member a " +

209 "INNER JOIN groups b ON a.groupID = b.groupID " +

210 "INNER JOIN user c ON a.userID = c.userID " +

211 "WHERE a.userID = b.owner AND b.name = ? "

212 rows, err := db.Query(query, group)

213 if err != nil {

214 return Member{}, err

215 }

216 defer rows.Close()

217 var m = Member{}

218 if rows.Next() {

219 err = rows.Scan(&m.Name, &m.UserID)

220 if err != nil {

221 return Member{}, err

222 }

223 } else {

224 return Member{}, errors.New("invalid group")

225 }

226 return m, nil

227 }

228

229 func (user User) GetMembers(group string) ([]Member, error) {

230 query := "SELECT b.Name, b.UserID FROM member a " +

231 "INNER JOIN user b ON a.userID=b.userID " +

232 "INNER JOIN groups c ON a.groupID=c.groupID " +

233 "WHERE c.name = ?"

234 rows, err := db.Query(query, group)

235 if err != nil {

236 return nil, err

237 }

238 defer rows.Close()

239 var members []Member

240 for rows.Next() {

241 var m = Member{}

242 err = rows.Scan(&m.Name, &m.UserID)

243 if err != nil {

244 return nil, err

245 }

246 members = append(members, m)

247 }

248 if len(members) == 0 {

249 return nil, errors.New("invalid group")

250 }

251 return members, nil

252 }

253

254 func (user User) IsInGroup(group string) (bool, error) {

255 id, err := GetGroupID(group)

256 if err != nil {

257 return false, err

258 }

259 return user.IsInGroupID(id)

260 }

261

262 func (user User) GetGroups() ([]Group, error) {

263 query := "SELECT a.groupID, a.name, a.description FROM groups a " +

264 "INNER JOIN member b ON a.groupID = b.groupID " +

265 "WHERE b.userID = ?"

266 rows, err := db.Query(query, user.ID)

267 if err != nil {

268 return nil, err

269 }

270 defer rows.Close()

271 var groups []Group

272 for rows.Next() {

273 var g = Group{}

274 err = rows.Scan(&g.ID, &g.Name, &g.Description)

275 if err != nil {

276 return nil, err

277 }

278 groups = append(groups, g)

279 }

280 return groups, nil

281 }

282