ProviderMeta.java 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338
  1. /*
  2. * Nextcloud - Android Client
  3. *
  4. * SPDX-FileCopyrightText: 2022 Álvaro Brey <alvaro@alvarobrey.com>
  5. * SPDX-FileCopyrightText: 2016-2021 Tobias Kaminsky <tobias@kaminsky.me>
  6. * SPDX-FileCopyrightText: 2016 ownCloud Inc.
  7. * SPDX-FileCopyrightText: 2014-2015 María Asensio Valverde <masensio@solidgear.es>
  8. * SPDX-FileCopyrightText: 2012 David A. Velasco <dvelasco@solidgear.es>
  9. * SPDX-FileCopyrightText: 2011 Bartosz Przybylski <bart.p.pl@gmail.com>
  10. * SPDX-License-Identifier: GPL-2.0-only AND (AGPL-3.0-or-later OR GPL-2.0-only)
  11. */
  12. package com.owncloud.android.db;
  13. import android.net.Uri;
  14. import android.provider.BaseColumns;
  15. import com.owncloud.android.MainApp;
  16. import java.util.Arrays;
  17. import java.util.Collections;
  18. import java.util.List;
  19. /**
  20. * Meta-Class that holds various static field information
  21. */
  22. public class ProviderMeta {
  23. public static final String DB_NAME = "filelist";
  24. public static final int DB_VERSION = 83;
  25. private ProviderMeta() {
  26. // No instance
  27. }
  28. static public class ProviderTableMeta implements BaseColumns {
  29. public static final String FILE_TABLE_NAME = "filelist";
  30. public static final String OCSHARES_TABLE_NAME = "ocshares";
  31. public static final String CAPABILITIES_TABLE_NAME = "capabilities";
  32. public static final String UPLOADS_TABLE_NAME = "list_of_uploads";
  33. public static final String SYNCED_FOLDERS_TABLE_NAME = "synced_folders";
  34. public static final String EXTERNAL_LINKS_TABLE_NAME = "external_links";
  35. public static final String ARBITRARY_DATA_TABLE_NAME = "arbitrary_data";
  36. public static final String VIRTUAL_TABLE_NAME = "virtual";
  37. public static final String FILESYSTEM_TABLE_NAME = "filesystem";
  38. public static final String EDITORS_TABLE_NAME = "editors";
  39. public static final String CREATORS_TABLE_NAME = "creators";
  40. private static final String CONTENT_PREFIX = "content://";
  41. public static final Uri CONTENT_URI = Uri.parse(CONTENT_PREFIX
  42. + MainApp.getAuthority() + "/");
  43. public static final Uri CONTENT_URI_FILE = Uri.parse(CONTENT_PREFIX
  44. + MainApp.getAuthority() + "/file");
  45. public static final Uri CONTENT_URI_DIR = Uri.parse(CONTENT_PREFIX
  46. + MainApp.getAuthority() + "/dir");
  47. public static final Uri CONTENT_URI_SHARE = Uri.parse(CONTENT_PREFIX
  48. + MainApp.getAuthority() + "/shares");
  49. public static final Uri CONTENT_URI_CAPABILITIES = Uri.parse(CONTENT_PREFIX
  50. + MainApp.getAuthority() + "/capabilities");
  51. public static final Uri CONTENT_URI_UPLOADS = Uri.parse(CONTENT_PREFIX
  52. + MainApp.getAuthority() + "/uploads");
  53. public static final Uri CONTENT_URI_SYNCED_FOLDERS = Uri.parse(CONTENT_PREFIX
  54. + MainApp.getAuthority() + "/synced_folders");
  55. public static final Uri CONTENT_URI_EXTERNAL_LINKS = Uri.parse(CONTENT_PREFIX
  56. + MainApp.getAuthority() + "/external_links");
  57. public static final Uri CONTENT_URI_VIRTUAL = Uri.parse(CONTENT_PREFIX + MainApp.getAuthority() + "/virtual");
  58. public static final Uri CONTENT_URI_FILESYSTEM = Uri.parse(CONTENT_PREFIX
  59. + MainApp.getAuthority() + "/filesystem");
  60. public static final String CONTENT_TYPE = "vnd.android.cursor.dir/vnd.owncloud.file";
  61. public static final String CONTENT_TYPE_ITEM = "vnd.android.cursor.item/vnd.owncloud.file";
  62. // Columns of filelist table
  63. public static final String FILE_PARENT = "parent";
  64. public static final String FILE_NAME = "filename";
  65. public static final String FILE_ENCRYPTED_NAME = "encrypted_filename";
  66. public static final String FILE_CREATION = "created";
  67. public static final String FILE_MODIFIED = "modified";
  68. public static final String FILE_MODIFIED_AT_LAST_SYNC_FOR_DATA = "modified_at_last_sync_for_data";
  69. public static final String FILE_CONTENT_LENGTH = "content_length";
  70. public static final String FILE_CONTENT_TYPE = "content_type";
  71. public static final String FILE_STORAGE_PATH = "media_path";
  72. public static final String FILE_PATH = "path";
  73. public static final String FILE_PATH_DECRYPTED = "path_decrypted";
  74. public static final String FILE_ACCOUNT_OWNER = "file_owner";
  75. public static final String FILE_LAST_SYNC_DATE = "last_sync_date";// _for_properties, but let's keep it as it is
  76. public static final String FILE_LAST_SYNC_DATE_FOR_DATA = "last_sync_date_for_data";
  77. public static final String FILE_KEEP_IN_SYNC = "keep_in_sync";
  78. public static final String FILE_ETAG = "etag";
  79. public static final String FILE_ETAG_ON_SERVER = "etag_on_server";
  80. public static final String FILE_SHARED_VIA_LINK = "share_by_link";
  81. public static final String FILE_SHARED_WITH_SHAREE = "shared_via_users";
  82. public static final String FILE_PERMISSIONS = "permissions";
  83. public static final String FILE_LOCAL_ID = "local_id";
  84. public static final String FILE_REMOTE_ID = "remote_id";
  85. public static final String FILE_UPDATE_THUMBNAIL = "update_thumbnail";
  86. public static final String FILE_IS_DOWNLOADING = "is_downloading";
  87. public static final String FILE_ETAG_IN_CONFLICT = "etag_in_conflict";
  88. public static final String FILE_FAVORITE = "favorite";
  89. public static final String FILE_HIDDEN = "hidden";
  90. public static final String FILE_IS_ENCRYPTED = "is_encrypted";
  91. public static final String FILE_MOUNT_TYPE = "mount_type";
  92. public static final String FILE_HAS_PREVIEW = "has_preview";
  93. public static final String FILE_UNREAD_COMMENTS_COUNT = "unread_comments_count";
  94. public static final String FILE_OWNER_ID = "owner_id";
  95. public static final String FILE_OWNER_DISPLAY_NAME = "owner_display_name";
  96. public static final String FILE_NOTE = "note";
  97. public static final String FILE_SHAREES = "sharees";
  98. public static final String FILE_RICH_WORKSPACE = "rich_workspace";
  99. public static final String FILE_METADATA_SIZE = "metadata_size";
  100. public static final String FILE_METADATA_GPS = "metadata_gps";
  101. public static final String FILE_METADATA_LIVE_PHOTO = "metadata_live_photo";
  102. public static final String FILE_LOCKED = "locked";
  103. public static final String FILE_LOCK_TYPE = "lock_type";
  104. public static final String FILE_LOCK_OWNER = "lock_owner";
  105. public static final String FILE_LOCK_OWNER_DISPLAY_NAME = "lock_owner_display_name";
  106. public static final String FILE_LOCK_OWNER_EDITOR = "lock_owner_editor";
  107. public static final String FILE_LOCK_TIMESTAMP = "lock_timestamp";
  108. public static final String FILE_LOCK_TIMEOUT = "lock_timeout";
  109. public static final String FILE_LOCK_TOKEN = "lock_token";
  110. public static final String FILE_TAGS = "tags";
  111. public static final String FILE_E2E_COUNTER = "e2e_counter";
  112. public static final String FILE_INTERNAL_TWO_WAY_SYNC_TIMESTAMP = "internal_two_way_sync_timestamp";
  113. public static final String FILE_INTERNAL_TWO_WAY_SYNC_RESULT = "internal_two_way_sync_result";
  114. public static final List<String> FILE_ALL_COLUMNS = Collections.unmodifiableList(Arrays.asList(
  115. _ID,
  116. FILE_PARENT,
  117. FILE_NAME,
  118. FILE_ENCRYPTED_NAME,
  119. FILE_CREATION,
  120. FILE_MODIFIED,
  121. FILE_MODIFIED_AT_LAST_SYNC_FOR_DATA,
  122. FILE_CONTENT_LENGTH,
  123. FILE_CONTENT_TYPE,
  124. FILE_STORAGE_PATH,
  125. FILE_PATH,
  126. FILE_PATH_DECRYPTED,
  127. FILE_ACCOUNT_OWNER,
  128. FILE_LAST_SYNC_DATE,
  129. FILE_LAST_SYNC_DATE_FOR_DATA,
  130. FILE_KEEP_IN_SYNC,
  131. FILE_ETAG,
  132. FILE_ETAG_ON_SERVER,
  133. FILE_SHARED_VIA_LINK,
  134. FILE_SHARED_WITH_SHAREE,
  135. FILE_PERMISSIONS,
  136. FILE_REMOTE_ID,
  137. FILE_LOCAL_ID,
  138. FILE_UPDATE_THUMBNAIL,
  139. FILE_IS_DOWNLOADING,
  140. FILE_ETAG_IN_CONFLICT,
  141. FILE_FAVORITE,
  142. FILE_HIDDEN,
  143. FILE_IS_ENCRYPTED,
  144. FILE_MOUNT_TYPE,
  145. FILE_HAS_PREVIEW,
  146. FILE_UNREAD_COMMENTS_COUNT,
  147. FILE_OWNER_ID,
  148. FILE_OWNER_DISPLAY_NAME,
  149. FILE_NOTE,
  150. FILE_SHAREES,
  151. FILE_RICH_WORKSPACE,
  152. FILE_LOCKED,
  153. FILE_LOCK_TYPE,
  154. FILE_LOCK_OWNER,
  155. FILE_LOCK_OWNER_DISPLAY_NAME,
  156. FILE_LOCK_OWNER_EDITOR,
  157. FILE_LOCK_TIMESTAMP,
  158. FILE_LOCK_TIMEOUT,
  159. FILE_LOCK_TOKEN,
  160. FILE_METADATA_SIZE,
  161. FILE_METADATA_LIVE_PHOTO,
  162. FILE_E2E_COUNTER,
  163. FILE_TAGS,
  164. FILE_METADATA_GPS,
  165. FILE_INTERNAL_TWO_WAY_SYNC_TIMESTAMP,
  166. FILE_INTERNAL_TWO_WAY_SYNC_RESULT));
  167. public static final String FILE_DEFAULT_SORT_ORDER = FILE_NAME + " collate nocase asc";
  168. // Columns of ocshares table
  169. public static final String OCSHARES_FILE_SOURCE = "file_source";
  170. public static final String OCSHARES_ITEM_SOURCE = "item_source";
  171. public static final String OCSHARES_SHARE_TYPE = "share_type";
  172. public static final String OCSHARES_SHARE_WITH = "shate_with";
  173. public static final String OCSHARES_PATH = "path";
  174. public static final String OCSHARES_PERMISSIONS = "permissions";
  175. public static final String OCSHARES_SHARED_DATE = "shared_date";
  176. public static final String OCSHARES_EXPIRATION_DATE = "expiration_date";
  177. public static final String OCSHARES_TOKEN = "token";
  178. public static final String OCSHARES_SHARE_WITH_DISPLAY_NAME = "shared_with_display_name";
  179. public static final String OCSHARES_IS_DIRECTORY = "is_directory";
  180. public static final String OCSHARES_USER_ID = "user_id";
  181. public static final String OCSHARES_ID_REMOTE_SHARED = "id_remote_shared";
  182. public static final String OCSHARES_ACCOUNT_OWNER = "owner_share";
  183. public static final String OCSHARES_IS_PASSWORD_PROTECTED = "is_password_protected";
  184. public static final String OCSHARES_NOTE = "note";
  185. public static final String OCSHARES_HIDE_DOWNLOAD = "hide_download";
  186. public static final String OCSHARES_SHARE_LINK = "share_link";
  187. public static final String OCSHARES_SHARE_LABEL = "share_label";
  188. public static final String OCSHARES_DEFAULT_SORT_ORDER = OCSHARES_FILE_SOURCE
  189. + " collate nocase asc";
  190. // Columns of capabilities table
  191. public static final String CAPABILITIES_ACCOUNT_NAME = "account";
  192. public static final String CAPABILITIES_VERSION_MAYOR = "version_mayor";
  193. public static final String CAPABILITIES_VERSION_MINOR = "version_minor";
  194. public static final String CAPABILITIES_VERSION_MICRO = "version_micro";
  195. public static final String CAPABILITIES_VERSION_STRING = "version_string";
  196. public static final String CAPABILITIES_VERSION_EDITION = "version_edition";
  197. public static final String CAPABILITIES_EXTENDED_SUPPORT = "extended_support";
  198. public static final String CAPABILITIES_CORE_POLLINTERVAL = "core_pollinterval";
  199. public static final String CAPABILITIES_SHARING_API_ENABLED = "sharing_api_enabled";
  200. public static final String CAPABILITIES_SHARING_PUBLIC_ENABLED = "sharing_public_enabled";
  201. public static final String CAPABILITIES_SHARING_PUBLIC_PASSWORD_ENFORCED = "sharing_public_password_enforced";
  202. public static final String CAPABILITIES_SHARING_PUBLIC_ASK_FOR_OPTIONAL_PASSWORD =
  203. "sharing_public_ask_for_optional_password";
  204. public static final String CAPABILITIES_SHARING_PUBLIC_EXPIRE_DATE_ENABLED =
  205. "sharing_public_expire_date_enabled";
  206. public static final String CAPABILITIES_SHARING_PUBLIC_EXPIRE_DATE_DAYS =
  207. "sharing_public_expire_date_days";
  208. public static final String CAPABILITIES_SHARING_PUBLIC_EXPIRE_DATE_ENFORCED =
  209. "sharing_public_expire_date_enforced";
  210. public static final String CAPABILITIES_SHARING_PUBLIC_SEND_MAIL = "sharing_public_send_mail";
  211. public static final String CAPABILITIES_SHARING_PUBLIC_UPLOAD = "sharing_public_upload";
  212. public static final String CAPABILITIES_SHARING_USER_SEND_MAIL = "sharing_user_send_mail";
  213. public static final String CAPABILITIES_SHARING_RESHARING = "sharing_resharing";
  214. public static final String CAPABILITIES_SHARING_FEDERATION_OUTGOING = "sharing_federation_outgoing";
  215. public static final String CAPABILITIES_SHARING_FEDERATION_INCOMING = "sharing_federation_incoming";
  216. public static final String CAPABILITIES_FILES_BIGFILECHUNKING = "files_bigfilechunking";
  217. public static final String CAPABILITIES_FILES_UNDELETE = "files_undelete";
  218. public static final String CAPABILITIES_FILES_VERSIONING = "files_versioning";
  219. public static final String CAPABILITIES_FILES_LOCKING_VERSION = "files_locking_version";
  220. public static final String CAPABILITIES_EXTERNAL_LINKS = "external_links";
  221. public static final String CAPABILITIES_SERVER_NAME = "server_name";
  222. public static final String CAPABILITIES_SERVER_COLOR = "server_color";
  223. public static final String CAPABILITIES_SERVER_TEXT_COLOR = "server_text_color";
  224. public static final String CAPABILITIES_SERVER_ELEMENT_COLOR = "server_element_color";
  225. public static final String CAPABILITIES_SERVER_BACKGROUND_URL = "background_url";
  226. public static final String CAPABILITIES_SERVER_SLOGAN = "server_slogan";
  227. public static final String CAPABILITIES_SERVER_LOGO = "server_logo";
  228. public static final String CAPABILITIES_SERVER_BACKGROUND_DEFAULT = "background_default";
  229. public static final String CAPABILITIES_SERVER_BACKGROUND_PLAIN = "background_plain";
  230. public static final String CAPABILITIES_END_TO_END_ENCRYPTION = "end_to_end_encryption";
  231. public static final String CAPABILITIES_END_TO_END_ENCRYPTION_KEYS_EXIST = "end_to_end_encryption_keys_exist";
  232. public static final String CAPABILITIES_END_TO_END_ENCRYPTION_API_VERSION = "end_to_end_encryption_api_version";
  233. public static final String CAPABILITIES_ACTIVITY = "activity";
  234. public static final String CAPABILITIES_RICHDOCUMENT = "richdocument";
  235. public static final String CAPABILITIES_RICHDOCUMENT_MIMETYPE_LIST = "richdocument_mimetype_list";
  236. public static final String CAPABILITIES_RICHDOCUMENT_OPTIONAL_MIMETYPE_LIST =
  237. "richdocument_optional_mimetype_list";
  238. public static final String CAPABILITIES_RICHDOCUMENT_DIRECT_EDITING = "richdocument_direct_editing";
  239. public static final String CAPABILITIES_RICHDOCUMENT_TEMPLATES = "richdocument_direct_templates";
  240. public static final String CAPABILITIES_RICHDOCUMENT_PRODUCT_NAME = "richdocument_product_name";
  241. public static final String CAPABILITIES_DEFAULT_SORT_ORDER = CAPABILITIES_ACCOUNT_NAME
  242. + " collate nocase asc";
  243. public static final String CAPABILITIES_DIRECT_EDITING_ETAG = "direct_editing_etag";
  244. public static final String CAPABILITIES_ETAG = "etag";
  245. public static final String CAPABILITIES_USER_STATUS = "user_status";
  246. public static final String CAPABILITIES_USER_STATUS_SUPPORTS_EMOJI = "user_status_supports_emoji";
  247. public static final String CAPABILITIES_ASSISTANT = "assistant";
  248. public static final String CAPABILITIES_GROUPFOLDERS = "groupfolders";
  249. public static final String CAPABILITIES_DROP_ACCOUNT = "drop_account";
  250. public static final String CAPABILITIES_SECURITY_GUARD = "security_guard";
  251. public static final String CAPABILITIES_FORBIDDEN_FILENAME_CHARACTERS = "forbidden_filename_characters";
  252. public static final String CAPABILITIES_FORBIDDEN_FILENAMES = "forbidden_filenames";
  253. public static final String CAPABILITIES_FORBIDDEN_FORBIDDEN_FILENAME_EXTENSIONS = "forbidden_filename_extensions";
  254. public static final String CAPABILITIES_FORBIDDEN_FORBIDDEN_FILENAME_BASE_NAMES = "forbidden_filename_basenames";
  255. //Columns of Uploads table
  256. public static final String UPLOADS_LOCAL_PATH = "local_path";
  257. public static final String UPLOADS_REMOTE_PATH = "remote_path";
  258. public static final String UPLOADS_ACCOUNT_NAME = "account_name";
  259. public static final String UPLOADS_FILE_SIZE = "file_size";
  260. public static final String UPLOADS_STATUS = "status";
  261. public static final String UPLOADS_LOCAL_BEHAVIOUR = "local_behaviour";
  262. public static final String UPLOADS_UPLOAD_TIME = "upload_time";
  263. public static final String UPLOADS_NAME_COLLISION_POLICY = "name_collision_policy";
  264. public static final String UPLOADS_IS_CREATE_REMOTE_FOLDER = "is_create_remote_folder";
  265. public static final String UPLOADS_UPLOAD_END_TIMESTAMP = "upload_end_timestamp";
  266. public static final String UPLOADS_LAST_RESULT = "last_result";
  267. public static final String UPLOADS_CREATED_BY = "created_by";
  268. public static final String UPLOADS_DEFAULT_SORT_ORDER = ProviderTableMeta._ID + " collate nocase desc";
  269. public static final String UPLOADS_IS_WHILE_CHARGING_ONLY = "is_while_charging_only";
  270. public static final String UPLOADS_IS_WIFI_ONLY = "is_wifi_only";
  271. public static final String UPLOADS_FOLDER_UNLOCK_TOKEN = "folder_unlock_token";
  272. // Columns of synced folder table
  273. public static final String SYNCED_FOLDER_LOCAL_PATH = "local_path";
  274. public static final String SYNCED_FOLDER_REMOTE_PATH = "remote_path";
  275. public static final String SYNCED_FOLDER_WIFI_ONLY = "wifi_only";
  276. public static final String SYNCED_FOLDER_CHARGING_ONLY = "charging_only";
  277. public static final String SYNCED_FOLDER_EXISTING = "existing";
  278. public static final String SYNCED_FOLDER_ENABLED = "enabled";
  279. public static final String SYNCED_FOLDER_ENABLED_TIMESTAMP_MS = "enabled_timestamp_ms";
  280. public static final String SYNCED_FOLDER_TYPE = "type";
  281. public static final String SYNCED_FOLDER_SUBFOLDER_BY_DATE = "subfolder_by_date";
  282. public static final String SYNCED_FOLDER_ACCOUNT = "account";
  283. public static final String SYNCED_FOLDER_UPLOAD_ACTION = "upload_option";
  284. public static final String SYNCED_FOLDER_NAME_COLLISION_POLICY = "name_collision_policy";
  285. public static final String SYNCED_FOLDER_HIDDEN = "hidden";
  286. public static final String SYNCED_FOLDER_SUBFOLDER_RULE = "sub_folder_rule";
  287. public static final String SYNCED_FOLDER_EXCLUDE_HIDDEN = "exclude_hidden";
  288. public static final String SYNCED_FOLDER_LAST_SCAN_TIMESTAMP_MS = "last_scan_timestamp_ms";
  289. // Columns of external links table
  290. public static final String EXTERNAL_LINKS_ICON_URL = "icon_url";
  291. public static final String EXTERNAL_LINKS_LANGUAGE = "language";
  292. public static final String EXTERNAL_LINKS_TYPE = "type";
  293. public static final String EXTERNAL_LINKS_NAME = "name";
  294. public static final String EXTERNAL_LINKS_URL = "url";
  295. public static final String EXTERNAL_LINKS_REDIRECT = "redirect";
  296. // Columns of arbitrary data table
  297. public static final String ARBITRARY_DATA_CLOUD_ID = "cloud_id";
  298. public static final String ARBITRARY_DATA_KEY = "key";
  299. public static final String ARBITRARY_DATA_VALUE = "value";
  300. // Columns of virtual
  301. public static final String VIRTUAL_TYPE = "type";
  302. public static final String VIRTUAL_OCFILE_ID = "ocfile_id";
  303. // Columns of filesystem data table
  304. public static final String FILESYSTEM_FILE_LOCAL_PATH = "local_path";
  305. public static final String FILESYSTEM_FILE_MODIFIED = "modified_at";
  306. public static final String FILESYSTEM_FILE_IS_FOLDER = "is_folder";
  307. public static final String FILESYSTEM_FILE_FOUND_RECENTLY = "found_at";
  308. public static final String FILESYSTEM_FILE_SENT_FOR_UPLOAD = "upload_triggered";
  309. public static final String FILESYSTEM_SYNCED_FOLDER_ID = "syncedfolder_id";
  310. public static final String FILESYSTEM_CRC32 = "crc32";
  311. private ProviderTableMeta() {
  312. // No instance
  313. }
  314. }
  315. }