sqlqueries.go 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. package dataprovider
  2. import (
  3. "fmt"
  4. "strconv"
  5. "strings"
  6. "github.com/drakkan/sftpgo/vfs"
  7. )
  8. const (
  9. selectUserFields = "id,username,password,public_keys,home_dir,uid,gid,max_sessions,quota_size,quota_files,permissions,used_quota_size," +
  10. "used_quota_files,last_quota_update,upload_bandwidth,download_bandwidth,expiration_date,last_login,status,filters,filesystem"
  11. selectFolderFields = "id,path,used_quota_size,used_quota_files,last_quota_update"
  12. )
  13. func getSQLPlaceholders() []string {
  14. var placeholders []string
  15. for i := 1; i <= 20; i++ {
  16. if config.Driver == PGSQLDataProviderName {
  17. placeholders = append(placeholders, fmt.Sprintf("$%v", i))
  18. } else {
  19. placeholders = append(placeholders, "?")
  20. }
  21. }
  22. return placeholders
  23. }
  24. func getUserByUsernameQuery() string {
  25. return fmt.Sprintf(`SELECT %v FROM %v WHERE username = %v`, selectUserFields, sqlTableUsers, sqlPlaceholders[0])
  26. }
  27. func getUserByIDQuery() string {
  28. return fmt.Sprintf(`SELECT %v FROM %v WHERE id = %v`, selectUserFields, sqlTableUsers, sqlPlaceholders[0])
  29. }
  30. func getUsersQuery(order string, username string) string {
  31. if len(username) > 0 {
  32. return fmt.Sprintf(`SELECT %v FROM %v WHERE username = %v ORDER BY username %v LIMIT %v OFFSET %v`,
  33. selectUserFields, sqlTableUsers, sqlPlaceholders[0], order, sqlPlaceholders[1], sqlPlaceholders[2])
  34. }
  35. return fmt.Sprintf(`SELECT %v FROM %v ORDER BY username %v LIMIT %v OFFSET %v`, selectUserFields, sqlTableUsers,
  36. order, sqlPlaceholders[0], sqlPlaceholders[1])
  37. }
  38. func getDumpUsersQuery() string {
  39. return fmt.Sprintf(`SELECT %v FROM %v`, selectUserFields, sqlTableUsers)
  40. }
  41. func getDumpFoldersQuery() string {
  42. return fmt.Sprintf(`SELECT %v FROM %v`, selectFolderFields, sqlTableFolders)
  43. }
  44. func getUpdateQuotaQuery(reset bool) string {
  45. if reset {
  46. return fmt.Sprintf(`UPDATE %v SET used_quota_size = %v,used_quota_files = %v,last_quota_update = %v
  47. WHERE username = %v`, sqlTableUsers, sqlPlaceholders[0], sqlPlaceholders[1], sqlPlaceholders[2], sqlPlaceholders[3])
  48. }
  49. return fmt.Sprintf(`UPDATE %v SET used_quota_size = used_quota_size + %v,used_quota_files = used_quota_files + %v,last_quota_update = %v
  50. WHERE username = %v`, sqlTableUsers, sqlPlaceholders[0], sqlPlaceholders[1], sqlPlaceholders[2], sqlPlaceholders[3])
  51. }
  52. func getUpdateLastLoginQuery() string {
  53. return fmt.Sprintf(`UPDATE %v SET last_login = %v WHERE username = %v`, sqlTableUsers, sqlPlaceholders[0], sqlPlaceholders[1])
  54. }
  55. func getQuotaQuery() string {
  56. return fmt.Sprintf(`SELECT used_quota_size,used_quota_files FROM %v WHERE username = %v`, sqlTableUsers,
  57. sqlPlaceholders[0])
  58. }
  59. func getAddUserQuery() string {
  60. return fmt.Sprintf(`INSERT INTO %v (username,password,public_keys,home_dir,uid,gid,max_sessions,quota_size,quota_files,permissions,
  61. used_quota_size,used_quota_files,last_quota_update,upload_bandwidth,download_bandwidth,status,last_login,expiration_date,filters,
  62. filesystem)
  63. VALUES (%v,%v,%v,%v,%v,%v,%v,%v,%v,%v,0,0,0,%v,%v,%v,0,%v,%v,%v)`, sqlTableUsers, sqlPlaceholders[0], sqlPlaceholders[1],
  64. sqlPlaceholders[2], sqlPlaceholders[3], sqlPlaceholders[4], sqlPlaceholders[5], sqlPlaceholders[6], sqlPlaceholders[7],
  65. sqlPlaceholders[8], sqlPlaceholders[9], sqlPlaceholders[10], sqlPlaceholders[11], sqlPlaceholders[12], sqlPlaceholders[13],
  66. sqlPlaceholders[14], sqlPlaceholders[15])
  67. }
  68. func getUpdateUserQuery() string {
  69. return fmt.Sprintf(`UPDATE %v SET password=%v,public_keys=%v,home_dir=%v,uid=%v,gid=%v,max_sessions=%v,quota_size=%v,
  70. quota_files=%v,permissions=%v,upload_bandwidth=%v,download_bandwidth=%v,status=%v,expiration_date=%v,filters=%v,filesystem=%v
  71. WHERE id = %v`, sqlTableUsers, sqlPlaceholders[0], sqlPlaceholders[1], sqlPlaceholders[2], sqlPlaceholders[3],
  72. sqlPlaceholders[4], sqlPlaceholders[5], sqlPlaceholders[6], sqlPlaceholders[7], sqlPlaceholders[8], sqlPlaceholders[9],
  73. sqlPlaceholders[10], sqlPlaceholders[11], sqlPlaceholders[12], sqlPlaceholders[13], sqlPlaceholders[14], sqlPlaceholders[15])
  74. }
  75. func getDeleteUserQuery() string {
  76. return fmt.Sprintf(`DELETE FROM %v WHERE id = %v`, sqlTableUsers, sqlPlaceholders[0])
  77. }
  78. func getFolderByPathQuery() string {
  79. return fmt.Sprintf(`SELECT %v FROM %v WHERE path = %v`, selectFolderFields, sqlTableFolders, sqlPlaceholders[0])
  80. }
  81. func getAddFolderQuery() string {
  82. return fmt.Sprintf(`INSERT INTO %v (path,used_quota_size,used_quota_files,last_quota_update) VALUES (%v,%v,%v,%v)`,
  83. sqlTableFolders, sqlPlaceholders[0], sqlPlaceholders[1], sqlPlaceholders[2], sqlPlaceholders[3])
  84. }
  85. func getDeleteFolderQuery() string {
  86. return fmt.Sprintf(`DELETE FROM %v WHERE id = %v`, sqlTableFolders, sqlPlaceholders[0])
  87. }
  88. func getClearFolderMappingQuery() string {
  89. return fmt.Sprintf(`DELETE FROM %v WHERE user_id = (SELECT id FROM %v WHERE username = %v)`, sqlTableFoldersMapping,
  90. sqlTableUsers, sqlPlaceholders[0])
  91. }
  92. func getAddFolderMappingQuery() string {
  93. return fmt.Sprintf(`INSERT INTO %v (virtual_path,quota_size,quota_files,folder_id,user_id)
  94. VALUES (%v,%v,%v,%v,(SELECT id FROM %v WHERE username = %v))`, sqlTableFoldersMapping, sqlPlaceholders[0],
  95. sqlPlaceholders[1], sqlPlaceholders[2], sqlPlaceholders[3], sqlTableUsers, sqlPlaceholders[4])
  96. }
  97. func getFoldersQuery(order, folderPath string) string {
  98. if len(folderPath) > 0 {
  99. return fmt.Sprintf(`SELECT %v FROM %v WHERE path = %v ORDER BY path %v LIMIT %v OFFSET %v`,
  100. selectFolderFields, sqlTableFolders, sqlPlaceholders[0], order, sqlPlaceholders[1], sqlPlaceholders[2])
  101. }
  102. return fmt.Sprintf(`SELECT %v FROM %v ORDER BY path %v LIMIT %v OFFSET %v`, selectFolderFields, sqlTableFolders,
  103. order, sqlPlaceholders[0], sqlPlaceholders[1])
  104. }
  105. func getUpdateFolderQuotaQuery(reset bool) string {
  106. if reset {
  107. return fmt.Sprintf(`UPDATE %v SET used_quota_size = %v,used_quota_files = %v,last_quota_update = %v
  108. WHERE path = %v`, sqlTableFolders, sqlPlaceholders[0], sqlPlaceholders[1], sqlPlaceholders[2], sqlPlaceholders[3])
  109. }
  110. return fmt.Sprintf(`UPDATE %v SET used_quota_size = used_quota_size + %v,used_quota_files = used_quota_files + %v,last_quota_update = %v
  111. WHERE path = %v`, sqlTableFolders, sqlPlaceholders[0], sqlPlaceholders[1], sqlPlaceholders[2], sqlPlaceholders[3])
  112. }
  113. func getQuotaFolderQuery() string {
  114. return fmt.Sprintf(`SELECT used_quota_size,used_quota_files FROM %v WHERE path = %v`, sqlTableFolders,
  115. sqlPlaceholders[0])
  116. }
  117. func getRelatedFoldersForUsersQuery(users []User) string {
  118. var sb strings.Builder
  119. for _, u := range users {
  120. if sb.Len() == 0 {
  121. sb.WriteString("(")
  122. } else {
  123. sb.WriteString(",")
  124. }
  125. sb.WriteString(strconv.FormatInt(u.ID, 10))
  126. }
  127. if sb.Len() > 0 {
  128. sb.WriteString(")")
  129. }
  130. return fmt.Sprintf(`SELECT f.id,f.path,f.used_quota_size,f.used_quota_files,f.last_quota_update,fm.virtual_path,fm.quota_size,fm.quota_files,fm.user_id
  131. FROM %v f INNER JOIN %v fm ON f.id = fm.folder_id WHERE fm.user_id IN %v ORDER BY fm.user_id`, sqlTableFolders,
  132. sqlTableFoldersMapping, sb.String())
  133. }
  134. func getRelatedUsersForFoldersQuery(folders []vfs.BaseVirtualFolder) string {
  135. var sb strings.Builder
  136. for _, f := range folders {
  137. if sb.Len() == 0 {
  138. sb.WriteString("(")
  139. } else {
  140. sb.WriteString(",")
  141. }
  142. sb.WriteString(strconv.FormatInt(f.ID, 10))
  143. }
  144. if sb.Len() > 0 {
  145. sb.WriteString(")")
  146. }
  147. return fmt.Sprintf(`SELECT fm.folder_id,u.username FROM %v fm INNER JOIN %v u ON fm.user_id = u.id
  148. WHERE fm.folder_id IN %v ORDER BY fm.folder_id`, sqlTableFoldersMapping, sqlTableUsers, sb.String())
  149. }
  150. func getDatabaseVersionQuery() string {
  151. return fmt.Sprintf("SELECT version from %v LIMIT 1", sqlTableSchemaVersion)
  152. }
  153. func getUpdateDBVersionQuery() string {
  154. return fmt.Sprintf(`UPDATE %v SET version=%v`, sqlTableSchemaVersion, sqlPlaceholders[0])
  155. }
  156. func getCompatVirtualFoldersQuery() string {
  157. return fmt.Sprintf(`SELECT id,username,virtual_folders FROM %v`, sqlTableUsers)
  158. }