sqlqueries.go 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. package dataprovider
  2. import "fmt"
  3. const (
  4. selectUserFields = "id,username,password,public_keys,home_dir,uid,gid,max_sessions,quota_size,quota_files,permissions," +
  5. "used_quota_size,used_quota_files,last_quota_update,upload_bandwidth,download_bandwidth"
  6. )
  7. func getSQLPlaceholders() []string {
  8. var placeholders []string
  9. for i := 1; i <= 20; i++ {
  10. if config.Driver == PGSSQLDataProviderName {
  11. placeholders = append(placeholders, fmt.Sprintf("$%v", i))
  12. } else {
  13. placeholders = append(placeholders, "?")
  14. }
  15. }
  16. return placeholders
  17. }
  18. func getUserByUsernameQuery() string {
  19. return fmt.Sprintf(`SELECT %v FROM %v WHERE username = %v`, selectUserFields, config.UsersTable, sqlPlaceholders[0])
  20. }
  21. func getUserByIDQuery() string {
  22. return fmt.Sprintf(`SELECT %v FROM %v WHERE id = %v`, selectUserFields, config.UsersTable, sqlPlaceholders[0])
  23. }
  24. func getUsersQuery(order string, username string) string {
  25. if len(username) > 0 {
  26. return fmt.Sprintf(`SELECT %v FROM %v WHERE username = %v ORDER BY username %v LIMIT %v OFFSET %v`,
  27. selectUserFields, config.UsersTable, sqlPlaceholders[0], order, sqlPlaceholders[1], sqlPlaceholders[2])
  28. }
  29. return fmt.Sprintf(`SELECT %v FROM %v ORDER BY username %v LIMIT %v OFFSET %v`, selectUserFields, config.UsersTable,
  30. order, sqlPlaceholders[0], sqlPlaceholders[1])
  31. }
  32. func getUpdateQuotaQuery(reset bool) string {
  33. if reset {
  34. return fmt.Sprintf(`UPDATE %v SET used_quota_size = %v,used_quota_files = %v,last_quota_update = %v
  35. WHERE username = %v`, config.UsersTable, sqlPlaceholders[0], sqlPlaceholders[1], sqlPlaceholders[2], sqlPlaceholders[3])
  36. }
  37. return fmt.Sprintf(`UPDATE %v SET used_quota_size = used_quota_size + %v,used_quota_files = used_quota_files + %v,last_quota_update = %v
  38. WHERE username = %v`, config.UsersTable, sqlPlaceholders[0], sqlPlaceholders[1], sqlPlaceholders[2], sqlPlaceholders[3])
  39. }
  40. func getQuotaQuery() string {
  41. return fmt.Sprintf(`SELECT used_quota_size,used_quota_files FROM %v WHERE username = %v`, config.UsersTable,
  42. sqlPlaceholders[0])
  43. }
  44. func getAddUserQuery() string {
  45. return fmt.Sprintf(`INSERT INTO %v (username,password,public_keys,home_dir,uid,gid,max_sessions,quota_size,quota_files,permissions,
  46. used_quota_size,used_quota_files,last_quota_update,upload_bandwidth,download_bandwidth)
  47. VALUES (%v,%v,%v,%v,%v,%v,%v,%v,%v,%v,0,0,0,%v,%v)`, config.UsersTable, sqlPlaceholders[0], sqlPlaceholders[1],
  48. sqlPlaceholders[2], sqlPlaceholders[3], sqlPlaceholders[4], sqlPlaceholders[5], sqlPlaceholders[6], sqlPlaceholders[7],
  49. sqlPlaceholders[8], sqlPlaceholders[9], sqlPlaceholders[10], sqlPlaceholders[11])
  50. }
  51. func getUpdateUserQuery() string {
  52. return fmt.Sprintf(`UPDATE %v SET password=%v,public_keys=%v,home_dir=%v,uid=%v,gid=%v,max_sessions=%v,quota_size=%v,
  53. quota_files=%v,permissions=%v,upload_bandwidth=%v,download_bandwidth=%v WHERE id = %v`, config.UsersTable,
  54. sqlPlaceholders[0], sqlPlaceholders[1], sqlPlaceholders[2], sqlPlaceholders[3], sqlPlaceholders[4], sqlPlaceholders[5],
  55. sqlPlaceholders[6], sqlPlaceholders[7], sqlPlaceholders[8], sqlPlaceholders[9], sqlPlaceholders[10], sqlPlaceholders[11])
  56. }
  57. func getDeleteUserQuery() string {
  58. return fmt.Sprintf(`DELETE FROM %v WHERE id = %v`, config.UsersTable, sqlPlaceholders[0])
  59. }