process.lua 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. --- Process functions for orgs
  2. function modpol.orgs:call_module(module_slug, initiator, config, result, parent_id)
  3. if not modpol.modules[module_slug] then
  4. modpol.ocutil.log('Error in ' .. self.name .. ':call_module -> module "' .. module_slug .. '" not found')
  5. return
  6. end
  7. local index = #self.processes + 1
  8. local module = modpol.modules[module_slug]
  9. -- sets default values for undeclared config variables
  10. if modpol.util.num_pairs(module.config) > 0 and config then
  11. for k, v in pairs(module.config) do
  12. if config[k] == nil then
  13. config[k] = v
  14. end
  15. end
  16. end
  17. -- setting default params
  18. local new_process = {
  19. metatable = {__index = module},
  20. initiator = initiator,
  21. org = self,
  22. id = index,
  23. parent_id = parent_id,
  24. children = {},
  25. config = config,
  26. data = module.data,
  27. slug = module_slug
  28. }
  29. -- call module wrapper for modules, passes its id to child process when called
  30. function new_process:call_module(module_slug, initiator, config, result)
  31. local child_id = self.org:call_module(module_slug, initiator, config, result, self.id)
  32. table.insert(self.children, child_id)
  33. end
  34. setmetatable(new_process, new_process.metatable)
  35. self.processes[index] = new_process
  36. self.processes[index]:initiate(result)
  37. local msg = "Initiating "..module_slug..
  38. " process id "..index.." in org "..self.name
  39. return index
  40. end
  41. function modpol.orgs:delete_process(id)
  42. local process = self.processes[id]
  43. if process and process ~= "deleted" then
  44. -- recursively deletes any children
  45. if #process.children > 0 then
  46. for i, child_id in pairs(process.children) do
  47. self:delete_process(child_id)
  48. end
  49. end
  50. local msg = "Deleting " .. self.processes[id].slug .. " process id "..id.." in org "..self.name
  51. modpol.ocutil.log(msg)
  52. self:record(msg, self.processes[id].slug)
  53. self:wipe_pending_actions(id)
  54. -- sets process to 'deleted' in process table
  55. self.processes[id] = 'deleted'
  56. end
  57. end
  58. function modpol.orgs:add_pending_action(process_id, user, callback)
  59. self.pending[user] = self.pending[user] or {}
  60. self.pending[user][process_id] = callback
  61. modpol.interactions.message(
  62. user, "New pending action in org "..self.name)
  63. end
  64. function modpol.orgs:remove_pending_action(process_id, user)
  65. if self.pending[user] then
  66. self.pending[user][process_id] = nil
  67. end
  68. end
  69. function modpol.orgs:wipe_pending_actions(process_id)
  70. for user in pairs(self.pending) do
  71. self.pending[user][process_id] = nil
  72. end
  73. end
  74. function modpol.orgs:has_pending_actions(user)
  75. -- next() will return the next pair in a table
  76. -- if next() returns nil, the table is empty
  77. if not self.pending[user] then
  78. return false
  79. else
  80. if not next(self.pending[user]) then
  81. return false
  82. else
  83. return true
  84. end
  85. end
  86. end
  87. function modpol.orgs:interact(process_id, user)
  88. local process = self.processes[process_id]
  89. if self.pending[user] then
  90. local callback = self.pending[user][process_id]
  91. if callback and process ~= "deleted" then
  92. -- get data in case callback ends process
  93. local slug = self.processes[process_id].slug
  94. -- run callback
  95. process[callback](process, user)
  96. -- record org data
  97. local msg = "Updating "..slug..
  98. " process id "..process_id.." in org "..self.name
  99. self:record(msg, slug)
  100. end
  101. end
  102. end