1. 20 Mar, 2019 2 commits
    • Fix AccessToken login with ERP5 Login · 601e46e9
      Since the introduction of ERP5 Login, authentication by Access Token is broken, and it is only working if `erp5_login.getReference() == person.getUserId()`
      
      The scriptable part of access token changed, now scripts must return a user object - on which the plugin will call `getUserId` (it was not clear what they should return before, maybe login, but they should return a user id, not a login, as the token plays the same role as a login). To make it clear and to intentionally break compatibility as this is now something different, these scripts have been renamed to be `getUserValue` type based methods.
      
      /reviewed-on !838
      Jérome Perrin committed
    • test: fix python3 syntax errors on testAccounting · d8999426
      (because my editor runs python3 pytlint)
      Jérome Perrin committed
  2. 19 Mar, 2019 9 commits
  3. 14 Mar, 2019 13 commits
    • erp5_trade: drop caching method for resource list · f1bbc5aa
      benefit is very small and unusable for user
      
      1f254aa7
      Xiaowu Zhang committed
    • Base._getAcquireLocalRoles: Optimise. · 213974eb
      This is called when checking access permission on objects, which happens
      very often. CachingMethod has a hit cost which is too high for this use.
      Instead, generate this method as part of the portal type class, removing
      all call-time logic.
      Vincent Pelletier committed
    • all: Remove references to im_self. · 6b289998
      It is superseded by __self__, which (where applicable) prevents
      acquisition and getattr-based traversal, improving performance.
      Patch AccessControl.users.BasicUser._check_context to extend this change
      to zope code (and simplify it in the process).
      Also, make __ac_local_roles__ accesses consistent with other places in
      our own code as well as in PAS & AccessControl.
      Vincent Pelletier committed
    • {,Propertied}User: Reduce the overhead from Developer role processing. · 240a8d26
      getRoles is called a lot (on every restricted access, so hundreds of times
      per transaction), it is definitely not the right place to do extra
      computation, especially when their result does not change from one call
      to the next (configuration should only change on process restart, so not
      during a transaction - and even if it someday did, it should be fine to
      wait for next transaction for it to take effect).
      Instead, do the extra work when creating the user (typically once per
      transaction).
      Also, modernise python syntax (simplifications & style).
      Also, reduce code duplication from ERP5Security.ERP5UserFactory.
      Vincent Pelletier committed
    • DCWorkflowDefinition_listObjectActions: Always return a vector. · e793b164
      Simplifies callers, as they then do not have to test for None.
      Also, use sort(key=...), which removes the need for internal 2-tuple
      wrapping & unwrapping of all result entries.
      Also, coding style (helps line-based profiling readability) & better
      naming.
      Vincent Pelletier committed
    • WorkflowTool: Accelerate action generation. · bba23043
      Include worklist parameter generation in the scope of existing cache.
      Otherwise, it will be generated in pure loss if it is followed by a cache
      hit. Most of WorkflowTool change is just indentation change.
      
      Also, do some minor optimisations/simplifications in patchess.DCWorkflow.
      Some comments:
      - Guard_checkWithoutRoles return value is evaluated as a boolean, so no
        need to cast to int before returning based on boolean evaluation...
      - DCWorkflowDefinition.worklists is always true, even when empty.
      - Listing portal types per workflow requires checking all workflows, so
        build the whole mapping and cache it instead of caching for each workflow
        type individually (many more cache hits, fewer redundant computations)
      - getVarMatch is expensive just for a fallback and a wrap, bypass it to
        reduce redundant work.
      Vincent Pelletier committed
    • ERP5Type.Core.Folder: Optimise _getFolderHandlerData. · 43dd2515
      Backward-compatibility path does not need to be fast. Optimise for sane
      folders.
      Vincent Pelletier committed
    • ERP5Type.Core.Folder: Do not try to access subobjects with invalid names. · 735d4748
      This improves performance when unset protected properties are being
      accessed.
      Vincent Pelletier committed
    • erp5_base: Remove ParentDeliveryCategoryMovementGroup broken since its introduction apparently. · 1051b18f
      In contrary to the ParentDeliveryPropertyMovementGroup for property, it has
      never actually checked the parent Delivery but the current one.
      Arnaud Fontaine committed
    • ui_dump_test: No need to track Activities. · 2c8fcf67
      This also avoids KeyError exceptions when Activities have already been processed
      in the meantime.
      Arnaud Fontaine committed
    • ui_test_core: remove dead code · fcd4c826
      These extensions does not seem to be used.
      
      /reviewed-on !845
      Jérome Perrin committed
    • Repair testFunctionalStandaloneUserTutorial · ddd3e26c
      Test was never ending processing activities:
      
      ```
      2019-03-11T03:09:20 WARNING CMFActivity invalid after_path_and_method_id value: ('/erp5/organisation_module/2', 'immediateRecusriveReindexObject', 'immediateReindexObject')
      Traceback (most recent call last):
        File "product/CMFActivity/Activity/SQLBase.py", line 319, in getValidationSQL
          validate_list.append(' AND '.join(method(v, quote)))
        File "product/CMFActivity/Activity/SQLBase.py", line 345, in _validate_after_path_and_method_id
          path, method_id = value
      ValueError: too many values to unpack
      2019-03-11T03:09:20 WARNING CMFActivity invalid after_path_and_method_id value: ('/erp5/organisation_module/2', 'immediateRecusriveReindexObject', 'immediateReindexObject')
      Traceback (most recent call last):
        File "product/CMFActivity/Activity/SQLBase.py", line 319, in getValidationSQL
          validate_list.append(' AND '.join(method(v, quote)))
        File "product/CMFActivity/Activity/SQLBase.py", line 345, in _validate_after_path_and_method_id
          path, method_id = value
      ValueError: too many values to unpack
      2019-03-11T03:09:20 WARNING CMFActivity invalid after_path_and_method_id value: ('/erp5/organisation_module/2', 'immediateRecusriveReindexObject', 'immediateReindexObject')
      Traceback (most recent call last):
        File "product/CMFActivity/Activity/SQLBase.py", line 319, in getValidationSQL
          validate_list.append(' AND '.join(method(v, quote)))
        File "product/CMFActivity/Activity/SQLBase.py", line 345, in _validate_after_path_and_method_id
          path, method_id = value
      ValueError: too many values to unpack
      2019-03-11T03:09:20 ERROR CMFActivity message uid 7256619472683296857L has a circular dependency
       ```
      
      Fix this failing test by using the proper `after_path_and_method_id` syntax and also some other small changes to make the test fail earlier in case of problems.
      
      /reviewed-on !844
      Jérome Perrin committed
  4. 13 Mar, 2019 4 commits
  5. 12 Mar, 2019 1 commit
  6. 11 Mar, 2019 4 commits
  7. 08 Mar, 2019 1 commit
  8. 07 Mar, 2019 6 commits