permissions.py 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465
  1. """Permission definitions for the group-based access control system.
  2. This module defines all permissions using a string enum with `resource:action` naming.
  3. Permissions are additive across groups - a user has all permissions from all their groups.
  4. """
  5. from backend.app.core.compat import StrEnum
  6. class Permission(StrEnum):
  7. """All available permissions in the system.
  8. Permissions follow the pattern: resource:action
  9. Actions typically include: read, create, update, delete, plus resource-specific actions.
  10. """
  11. # Printers
  12. PRINTERS_READ = "printers:read"
  13. PRINTERS_CREATE = "printers:create"
  14. PRINTERS_UPDATE = "printers:update"
  15. PRINTERS_DELETE = "printers:delete"
  16. PRINTERS_CONTROL = "printers:control" # Start/stop/pause/resume prints
  17. PRINTERS_FILES = "printers:files" # Send files to printer
  18. PRINTERS_AMS_RFID = "printers:ams_rfid" # Re-read AMS RFID tags
  19. PRINTERS_CLEAR_PLATE = "printers:clear_plate" # Confirm plate cleared for next print
  20. # Archives
  21. ARCHIVES_READ = "archives:read"
  22. ARCHIVES_CREATE = "archives:create"
  23. ARCHIVES_UPDATE_OWN = "archives:update_own"
  24. ARCHIVES_UPDATE_ALL = "archives:update_all"
  25. ARCHIVES_DELETE_OWN = "archives:delete_own"
  26. ARCHIVES_DELETE_ALL = "archives:delete_all"
  27. ARCHIVES_REPRINT_OWN = "archives:reprint_own"
  28. ARCHIVES_REPRINT_ALL = "archives:reprint_all"
  29. ARCHIVES_PURGE = "archives:purge"
  30. # Queue
  31. QUEUE_READ = "queue:read"
  32. QUEUE_CREATE = "queue:create"
  33. QUEUE_UPDATE_OWN = "queue:update_own"
  34. QUEUE_UPDATE_ALL = "queue:update_all"
  35. QUEUE_DELETE_OWN = "queue:delete_own"
  36. QUEUE_DELETE_ALL = "queue:delete_all"
  37. QUEUE_REORDER = "queue:reorder"
  38. # Library
  39. LIBRARY_READ = "library:read"
  40. LIBRARY_UPLOAD = "library:upload"
  41. LIBRARY_UPDATE_OWN = "library:update_own"
  42. LIBRARY_UPDATE_ALL = "library:update_all"
  43. LIBRARY_DELETE_OWN = "library:delete_own"
  44. LIBRARY_DELETE_ALL = "library:delete_all"
  45. # Admin-only: bulk purge of old files + trash retention settings (#1008).
  46. # Routine per-user trash management (restore-own, hard-delete-own) is
  47. # gated by the existing LIBRARY_DELETE_* permissions instead.
  48. LIBRARY_PURGE = "library:purge"
  49. # Projects
  50. PROJECTS_READ = "projects:read"
  51. PROJECTS_CREATE = "projects:create"
  52. PROJECTS_UPDATE = "projects:update"
  53. PROJECTS_DELETE = "projects:delete"
  54. # Filaments
  55. FILAMENTS_READ = "filaments:read"
  56. FILAMENTS_CREATE = "filaments:create"
  57. FILAMENTS_UPDATE = "filaments:update"
  58. FILAMENTS_DELETE = "filaments:delete"
  59. # Inventory (Spool Inventory, Spool Catalog, Color Catalog)
  60. INVENTORY_READ = "inventory:read"
  61. INVENTORY_CREATE = "inventory:create"
  62. INVENTORY_UPDATE = "inventory:update"
  63. INVENTORY_DELETE = "inventory:delete"
  64. INVENTORY_VIEW_ASSIGNMENTS = "inventory:view_assignments" # View spool-to-AMS assignments on printer cards
  65. INVENTORY_FORECAST_READ = "inventory:forecast_read" # View forecast/reorder intelligence panel
  66. INVENTORY_FORECAST_WRITE = "inventory:forecast_write" # Modify SKU settings, lead times, shopping list
  67. # Smart Plugs
  68. SMART_PLUGS_READ = "smart_plugs:read"
  69. SMART_PLUGS_CREATE = "smart_plugs:create"
  70. SMART_PLUGS_UPDATE = "smart_plugs:update"
  71. SMART_PLUGS_DELETE = "smart_plugs:delete"
  72. SMART_PLUGS_CONTROL = "smart_plugs:control" # Turn on/off
  73. # Camera
  74. CAMERA_VIEW = "camera:view"
  75. # Maintenance
  76. MAINTENANCE_READ = "maintenance:read"
  77. MAINTENANCE_CREATE = "maintenance:create"
  78. MAINTENANCE_UPDATE = "maintenance:update"
  79. MAINTENANCE_DELETE = "maintenance:delete"
  80. # K-Profiles
  81. KPROFILES_READ = "kprofiles:read"
  82. KPROFILES_CREATE = "kprofiles:create"
  83. KPROFILES_UPDATE = "kprofiles:update"
  84. KPROFILES_DELETE = "kprofiles:delete"
  85. # Notifications
  86. NOTIFICATIONS_READ = "notifications:read"
  87. NOTIFICATIONS_CREATE = "notifications:create"
  88. NOTIFICATIONS_UPDATE = "notifications:update"
  89. NOTIFICATIONS_DELETE = "notifications:delete"
  90. NOTIFICATIONS_USER_EMAIL = "notifications:user_email" # Receive per-user print email notifications
  91. # Notification Templates
  92. NOTIFICATION_TEMPLATES_READ = "notification_templates:read"
  93. NOTIFICATION_TEMPLATES_UPDATE = "notification_templates:update"
  94. # External Links
  95. EXTERNAL_LINKS_READ = "external_links:read"
  96. EXTERNAL_LINKS_CREATE = "external_links:create"
  97. EXTERNAL_LINKS_UPDATE = "external_links:update"
  98. EXTERNAL_LINKS_DELETE = "external_links:delete"
  99. # Discovery (network scanning)
  100. DISCOVERY_SCAN = "discovery:scan"
  101. # Firmware
  102. FIRMWARE_READ = "firmware:read"
  103. FIRMWARE_UPDATE = "firmware:update"
  104. # AMS History
  105. AMS_HISTORY_READ = "ams_history:read"
  106. # Stats/Metrics
  107. STATS_READ = "stats:read"
  108. STATS_FILTER_BY_USER = "stats:filter_by_user"
  109. # System Info
  110. SYSTEM_READ = "system:read"
  111. # Settings (admin-level)
  112. SETTINGS_READ = "settings:read"
  113. SETTINGS_UPDATE = "settings:update"
  114. SETTINGS_BACKUP = "settings:backup"
  115. SETTINGS_RESTORE = "settings:restore"
  116. # GitHub Backup (admin-level)
  117. GITHUB_BACKUP = "github:backup"
  118. GITHUB_RESTORE = "github:restore"
  119. # Cloud Auth (admin-level)
  120. CLOUD_AUTH = "cloud:auth"
  121. # MakerWorld Integration
  122. MAKERWORLD_VIEW = "makerworld:view" # Resolve MakerWorld URLs and view model metadata
  123. MAKERWORLD_IMPORT = "makerworld:import" # Download 3MFs from MakerWorld into the library
  124. # API Keys (admin-level)
  125. API_KEYS_READ = "api_keys:read"
  126. API_KEYS_CREATE = "api_keys:create"
  127. API_KEYS_UPDATE = "api_keys:update"
  128. API_KEYS_DELETE = "api_keys:delete"
  129. # Users (admin-level)
  130. USERS_READ = "users:read"
  131. USERS_CREATE = "users:create"
  132. USERS_UPDATE = "users:update"
  133. USERS_DELETE = "users:delete"
  134. # Groups (admin-level)
  135. GROUPS_READ = "groups:read"
  136. GROUPS_CREATE = "groups:create"
  137. GROUPS_UPDATE = "groups:update"
  138. GROUPS_DELETE = "groups:delete"
  139. # WebSocket connection
  140. WEBSOCKET_CONNECT = "websocket:connect"
  141. # Permission categories for UI organization
  142. PERMISSION_CATEGORIES = {
  143. "Printers": [
  144. Permission.PRINTERS_READ,
  145. Permission.PRINTERS_CREATE,
  146. Permission.PRINTERS_UPDATE,
  147. Permission.PRINTERS_DELETE,
  148. Permission.PRINTERS_CONTROL,
  149. Permission.PRINTERS_FILES,
  150. Permission.PRINTERS_AMS_RFID,
  151. Permission.PRINTERS_CLEAR_PLATE,
  152. ],
  153. "Archives": [
  154. Permission.ARCHIVES_READ,
  155. Permission.ARCHIVES_CREATE,
  156. Permission.ARCHIVES_UPDATE_OWN,
  157. Permission.ARCHIVES_UPDATE_ALL,
  158. Permission.ARCHIVES_DELETE_OWN,
  159. Permission.ARCHIVES_DELETE_ALL,
  160. Permission.ARCHIVES_REPRINT_OWN,
  161. Permission.ARCHIVES_REPRINT_ALL,
  162. Permission.ARCHIVES_PURGE,
  163. ],
  164. "Queue": [
  165. Permission.QUEUE_READ,
  166. Permission.QUEUE_CREATE,
  167. Permission.QUEUE_UPDATE_OWN,
  168. Permission.QUEUE_UPDATE_ALL,
  169. Permission.QUEUE_DELETE_OWN,
  170. Permission.QUEUE_DELETE_ALL,
  171. Permission.QUEUE_REORDER,
  172. ],
  173. "Library": [
  174. Permission.LIBRARY_READ,
  175. Permission.LIBRARY_UPLOAD,
  176. Permission.LIBRARY_UPDATE_OWN,
  177. Permission.LIBRARY_UPDATE_ALL,
  178. Permission.LIBRARY_DELETE_OWN,
  179. Permission.LIBRARY_DELETE_ALL,
  180. Permission.LIBRARY_PURGE,
  181. ],
  182. "Projects": [
  183. Permission.PROJECTS_READ,
  184. Permission.PROJECTS_CREATE,
  185. Permission.PROJECTS_UPDATE,
  186. Permission.PROJECTS_DELETE,
  187. ],
  188. "Filaments": [
  189. Permission.FILAMENTS_READ,
  190. Permission.FILAMENTS_CREATE,
  191. Permission.FILAMENTS_UPDATE,
  192. Permission.FILAMENTS_DELETE,
  193. ],
  194. "Inventory": [
  195. Permission.INVENTORY_READ,
  196. Permission.INVENTORY_CREATE,
  197. Permission.INVENTORY_UPDATE,
  198. Permission.INVENTORY_DELETE,
  199. Permission.INVENTORY_VIEW_ASSIGNMENTS,
  200. Permission.INVENTORY_FORECAST_READ,
  201. Permission.INVENTORY_FORECAST_WRITE,
  202. ],
  203. "Smart Plugs": [
  204. Permission.SMART_PLUGS_READ,
  205. Permission.SMART_PLUGS_CREATE,
  206. Permission.SMART_PLUGS_UPDATE,
  207. Permission.SMART_PLUGS_DELETE,
  208. Permission.SMART_PLUGS_CONTROL,
  209. ],
  210. "Camera": [
  211. Permission.CAMERA_VIEW,
  212. ],
  213. "Maintenance": [
  214. Permission.MAINTENANCE_READ,
  215. Permission.MAINTENANCE_CREATE,
  216. Permission.MAINTENANCE_UPDATE,
  217. Permission.MAINTENANCE_DELETE,
  218. ],
  219. "K-Profiles": [
  220. Permission.KPROFILES_READ,
  221. Permission.KPROFILES_CREATE,
  222. Permission.KPROFILES_UPDATE,
  223. Permission.KPROFILES_DELETE,
  224. ],
  225. "Notifications": [
  226. Permission.NOTIFICATIONS_READ,
  227. Permission.NOTIFICATIONS_CREATE,
  228. Permission.NOTIFICATIONS_UPDATE,
  229. Permission.NOTIFICATIONS_DELETE,
  230. Permission.NOTIFICATIONS_USER_EMAIL,
  231. Permission.NOTIFICATION_TEMPLATES_READ,
  232. Permission.NOTIFICATION_TEMPLATES_UPDATE,
  233. ],
  234. "External Links": [
  235. Permission.EXTERNAL_LINKS_READ,
  236. Permission.EXTERNAL_LINKS_CREATE,
  237. Permission.EXTERNAL_LINKS_UPDATE,
  238. Permission.EXTERNAL_LINKS_DELETE,
  239. ],
  240. "Discovery": [
  241. Permission.DISCOVERY_SCAN,
  242. ],
  243. "Firmware": [
  244. Permission.FIRMWARE_READ,
  245. Permission.FIRMWARE_UPDATE,
  246. ],
  247. "Stats & History": [
  248. Permission.AMS_HISTORY_READ,
  249. Permission.STATS_READ,
  250. Permission.STATS_FILTER_BY_USER,
  251. ],
  252. "System": [
  253. Permission.SYSTEM_READ,
  254. ],
  255. "Settings": [
  256. Permission.SETTINGS_READ,
  257. Permission.SETTINGS_UPDATE,
  258. Permission.SETTINGS_BACKUP,
  259. Permission.SETTINGS_RESTORE,
  260. ],
  261. "Backup": [
  262. Permission.GITHUB_BACKUP,
  263. Permission.GITHUB_RESTORE,
  264. ],
  265. "Cloud": [
  266. Permission.CLOUD_AUTH,
  267. ],
  268. "MakerWorld": [
  269. Permission.MAKERWORLD_VIEW,
  270. Permission.MAKERWORLD_IMPORT,
  271. ],
  272. "API Keys": [
  273. Permission.API_KEYS_READ,
  274. Permission.API_KEYS_CREATE,
  275. Permission.API_KEYS_UPDATE,
  276. Permission.API_KEYS_DELETE,
  277. ],
  278. "User Management": [
  279. Permission.USERS_READ,
  280. Permission.USERS_CREATE,
  281. Permission.USERS_UPDATE,
  282. Permission.USERS_DELETE,
  283. Permission.GROUPS_READ,
  284. Permission.GROUPS_CREATE,
  285. Permission.GROUPS_UPDATE,
  286. Permission.GROUPS_DELETE,
  287. ],
  288. "WebSocket": [
  289. Permission.WEBSOCKET_CONNECT,
  290. ],
  291. }
  292. # All permissions as a list
  293. ALL_PERMISSIONS = [p.value for p in Permission]
  294. # Default group definitions
  295. DEFAULT_GROUPS = {
  296. "Administrators": {
  297. "description": "Full access to all features and settings",
  298. "permissions": ALL_PERMISSIONS, # All permissions
  299. "is_system": True,
  300. },
  301. "Operators": {
  302. "description": "Can control printers, manage queue and archives, view settings",
  303. "permissions": [
  304. # Printers - full control
  305. Permission.PRINTERS_READ.value,
  306. Permission.PRINTERS_CREATE.value,
  307. Permission.PRINTERS_UPDATE.value,
  308. Permission.PRINTERS_DELETE.value,
  309. Permission.PRINTERS_CONTROL.value,
  310. Permission.PRINTERS_FILES.value,
  311. Permission.PRINTERS_AMS_RFID.value,
  312. Permission.PRINTERS_CLEAR_PLATE.value,
  313. # Archives - own items only
  314. Permission.ARCHIVES_READ.value,
  315. Permission.ARCHIVES_CREATE.value,
  316. Permission.ARCHIVES_UPDATE_OWN.value,
  317. Permission.ARCHIVES_DELETE_OWN.value,
  318. Permission.ARCHIVES_REPRINT_OWN.value,
  319. # Queue - own items only
  320. Permission.QUEUE_READ.value,
  321. Permission.QUEUE_CREATE.value,
  322. Permission.QUEUE_UPDATE_OWN.value,
  323. Permission.QUEUE_DELETE_OWN.value,
  324. Permission.QUEUE_REORDER.value,
  325. # Library - own items only
  326. Permission.LIBRARY_READ.value,
  327. Permission.LIBRARY_UPLOAD.value,
  328. Permission.LIBRARY_UPDATE_OWN.value,
  329. Permission.LIBRARY_DELETE_OWN.value,
  330. # MakerWorld integration
  331. Permission.MAKERWORLD_VIEW.value,
  332. Permission.MAKERWORLD_IMPORT.value,
  333. # Projects - full access
  334. Permission.PROJECTS_READ.value,
  335. Permission.PROJECTS_CREATE.value,
  336. Permission.PROJECTS_UPDATE.value,
  337. Permission.PROJECTS_DELETE.value,
  338. # Filaments - full access
  339. Permission.FILAMENTS_READ.value,
  340. Permission.FILAMENTS_CREATE.value,
  341. Permission.FILAMENTS_UPDATE.value,
  342. Permission.FILAMENTS_DELETE.value,
  343. # Inventory - full access
  344. Permission.INVENTORY_READ.value,
  345. Permission.INVENTORY_CREATE.value,
  346. Permission.INVENTORY_UPDATE.value,
  347. Permission.INVENTORY_DELETE.value,
  348. Permission.INVENTORY_VIEW_ASSIGNMENTS.value,
  349. Permission.INVENTORY_FORECAST_READ.value,
  350. Permission.INVENTORY_FORECAST_WRITE.value,
  351. # Smart Plugs - full access
  352. Permission.SMART_PLUGS_READ.value,
  353. Permission.SMART_PLUGS_CREATE.value,
  354. Permission.SMART_PLUGS_UPDATE.value,
  355. Permission.SMART_PLUGS_DELETE.value,
  356. Permission.SMART_PLUGS_CONTROL.value,
  357. # Camera - view
  358. Permission.CAMERA_VIEW.value,
  359. # Maintenance - full access
  360. Permission.MAINTENANCE_READ.value,
  361. Permission.MAINTENANCE_CREATE.value,
  362. Permission.MAINTENANCE_UPDATE.value,
  363. Permission.MAINTENANCE_DELETE.value,
  364. # K-Profiles - full access
  365. Permission.KPROFILES_READ.value,
  366. Permission.KPROFILES_CREATE.value,
  367. Permission.KPROFILES_UPDATE.value,
  368. Permission.KPROFILES_DELETE.value,
  369. # Notifications - full access
  370. Permission.NOTIFICATIONS_READ.value,
  371. Permission.NOTIFICATIONS_CREATE.value,
  372. Permission.NOTIFICATIONS_UPDATE.value,
  373. Permission.NOTIFICATIONS_DELETE.value,
  374. Permission.NOTIFICATIONS_USER_EMAIL.value,
  375. Permission.NOTIFICATION_TEMPLATES_READ.value,
  376. Permission.NOTIFICATION_TEMPLATES_UPDATE.value,
  377. # External Links - full access
  378. Permission.EXTERNAL_LINKS_READ.value,
  379. Permission.EXTERNAL_LINKS_CREATE.value,
  380. Permission.EXTERNAL_LINKS_UPDATE.value,
  381. Permission.EXTERNAL_LINKS_DELETE.value,
  382. # Discovery
  383. Permission.DISCOVERY_SCAN.value,
  384. # Firmware - read only
  385. Permission.FIRMWARE_READ.value,
  386. # Stats & History
  387. Permission.AMS_HISTORY_READ.value,
  388. Permission.STATS_READ.value,
  389. Permission.SYSTEM_READ.value,
  390. # Settings - read only
  391. Permission.SETTINGS_READ.value,
  392. # WebSocket
  393. Permission.WEBSOCKET_CONNECT.value,
  394. ],
  395. "is_system": True,
  396. },
  397. "Viewers": {
  398. "description": "Read-only access to printers, archives, and queue",
  399. "permissions": [
  400. # Read-only access
  401. Permission.PRINTERS_READ.value,
  402. Permission.ARCHIVES_READ.value,
  403. Permission.QUEUE_READ.value,
  404. Permission.LIBRARY_READ.value,
  405. Permission.PROJECTS_READ.value,
  406. Permission.FILAMENTS_READ.value,
  407. Permission.INVENTORY_READ.value,
  408. Permission.INVENTORY_VIEW_ASSIGNMENTS.value,
  409. Permission.INVENTORY_FORECAST_READ.value,
  410. Permission.SMART_PLUGS_READ.value,
  411. Permission.CAMERA_VIEW.value,
  412. Permission.MAINTENANCE_READ.value,
  413. Permission.KPROFILES_READ.value,
  414. Permission.NOTIFICATIONS_READ.value,
  415. Permission.NOTIFICATION_TEMPLATES_READ.value,
  416. Permission.EXTERNAL_LINKS_READ.value,
  417. Permission.FIRMWARE_READ.value,
  418. Permission.AMS_HISTORY_READ.value,
  419. Permission.STATS_READ.value,
  420. Permission.SYSTEM_READ.value,
  421. Permission.SETTINGS_READ.value,
  422. Permission.WEBSOCKET_CONNECT.value,
  423. # MakerWorld browsing only (no import — that writes to library)
  424. Permission.MAKERWORLD_VIEW.value,
  425. ],
  426. "is_system": True,
  427. },
  428. }