Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Additional fields in Submission schema in API for 3.5 #10480

Open
jardakotesovec opened this issue Sep 27, 2024 · 4 comments
Open

Additional fields in Submission schema in API for 3.5 #10480

jardakotesovec opened this issue Sep 27, 2024 · 4 comments
Assignees
Labels
Enhancement:2:Moderate A new feature or improvement that can be implemented in less than 4 weeks.
Milestone

Comments

@jardakotesovec
Copy link
Contributor

jardakotesovec commented Sep 27, 2024

On the meeting we agreed to include following fields to the submission schema. These are computed fields from stage assignments.

We agreed that keeping business logic on server side is better to not spread business logic too much between server side and client side. All these fields also are very business specific information, not really UI specific. Client side makes its own decision how to present things based on these flags.

Opened to different names, but these should be quite self-explanatory.

Submission listing /_submissions

  • isCurrentUserRecommendOnly
  • isCurrentUserDecidingEditor
  • isDecidingEditorAssigned
  • canCurrentUserChangeMetadata
  • currentUserAccessRoles

Workflow side modal /submissions/{submissionId}

  • isCurrentUserRecommendOnly
  • isCurrentUserDecidingEditor
  • isDecidingEditorAssigned
  • canCurrentUserChangeMetadata
  • currentUserAccessRoles
  • currentUserRecommendation
  • recommendations

Description for each field

isCurrentUserRecommendOnly (per stage)

  • boolean
  • meaning is that current user is assigned with the recommendOnly flag
  • recommend only flag is relevant on multiple stages to decide what user can do, not only on review stage
  • would be calculated for every stage

isCurrentUserDecidingEditor

isDecidingEditorAssigned

  • boolean
  • If there is at least one recommendOnly editor - this indicates whether there is also ROLE_ID_MANAGER or ROLE_ID_SUB_EDITOR in stage assignments without recommendOnly flag
  • this can be included in review stages as its not relevant for others

canCurrentUserChangeMetadata (not per stage)

  • boolean
  • this is not specific to stage, so it can be outside of the stages array
  • reference implementation https://github.com/pkp/pkp-lib/blob/main/pages/workflow/PKPWorkflowHandler.php#L177
  • basically its checking canChangeMetadata for assigned users to the stage assignment (regardless of what stage they are assigned) and ROLE_ID_MANAGER can do always edit it. Thats my understanding, but please double check it from linked implementation.

currentUserAccessRoles (per stage)

  • array of roleIds
  • stage specific, would be calculated for every stage
  • it would follow the logic from (getAccessibleWorkflowStages)[https://github.com/pkp/pkp-lib/blob/b8d985fb8baebe981935ba2175616c6fd1a923b8/classes/user/Repository.php#L202], to combine assigned role and global ones.
  • this already exist, but its not accurate as its fetching stage assignments twice, once filtered by stage and once for all stages and combines them together. Desired would be to get only the roleId for current stage

currentUserRecommendation - if I am recommend only editor (only in review stages)

  • this be null or object, based on whether I am recommendOnly editor and whether decision has been made (last decision is relevant)
  • relevant for review stages (ideally to include also internal one for OMP), so it makes sense to include it only in these stages
  • object shape could be: {'decision': 3, label: 'Recommend Revisions'}
  • reference for retrieving such decision - https://github.com/pkp/pkp-lib/blob/main/pages/workflow/PKPWorkflowHandler.php#L611C1-L612C1

recommendations - if I am deciding editor (only in review stages)

@jardakotesovec jardakotesovec added the Enhancement:2:Moderate A new feature or improvement that can be implemented in less than 4 weeks. label Sep 27, 2024
@jardakotesovec jardakotesovec added this to the 3.5.0 LTS milestone Sep 27, 2024
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Oct 16, 2024
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Oct 17, 2024
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Oct 17, 2024
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Oct 17, 2024
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Oct 21, 2024
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Oct 22, 2024
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 2, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 2, 2025
@Vitaliy-1
Copy link
Collaborator

Vitaliy-1 commented Jan 2, 2025

PRs
pkp-lib: #10523
ui-library: pkp/ui-library#489
OJS: pkp/ojs#4471

@Vitaliy-1
Copy link
Collaborator

@jardakotesovec Can you take a look at the data added to the Schema? Do we need anything else there?

Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 6, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 6, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 6, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 6, 2025
@Vitaliy-1
Copy link
Collaborator

In short, changes in the schema affect 3 submission-related endpoints, to related to submissions list _submissions, _submissions/assigned and for retrieving data for individual submissions: submissions/[id]. Main changes are in the stage property, it now looks like:

{
  "stages": [
    {
      "id": 1,
      "label": "Submission",
      "isActiveStage": true,
      "editorAssigned": true,
      "isDecidingEditorAssigned": true,
      "isCurrentUserDecidingEditor": true,
      "currentUserAssignedRoles": [
        16
      ]
    },
    {
      "id": 3,
      "label": "Review",
      "isActiveStage": false,
      "editorAssigned": true,
      "isDecidingEditorAssigned": true,
      "isCurrentUserDecidingEditor": true,
      "currentUserAssignedRoles": [
        16
      ]
    },
    {
      "id": 4,
      "label": "Copyediting",
      "isActiveStage": false,
      "editorAssigned": true,
      "isDecidingEditorAssigned": true,
      "isCurrentUserDecidingEditor": true,
      "currentUserAssignedRoles": [
        16
      ]
    },
    {
      "id": 5,
      "label": "Production",
      "isActiveStage": false,
      "editorAssigned": true,
      "isDecidingEditorAssigned": true,
      "isCurrentUserDecidingEditor": true,
      "currentUserAssignedRoles": [
        16
      ]
    }
  ]
}

The trickiest part is with currentUserAssignedRoles, I've reproduced the logic from our authorization part of the system. I've also introduced new not stage related property - canCurrentUserChangeMetadata and moved availableEditorialDecisions out from stages. The latter was recently introduced and I'm not familiar with the logic there. Currently testing it, if it works as it should.

Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 7, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 7, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 7, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 7, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 9, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 9, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 9, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 15, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 15, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 15, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 15, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 15, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 16, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 16, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 16, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 16, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 16, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 16, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 16, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 16, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 16, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 16, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 17, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 19, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 19, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 19, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 19, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 19, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 19, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 19, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 19, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 19, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 19, 2025
Vitaliy-1 added a commit to Vitaliy-1/pkp-lib that referenced this issue Jan 19, 2025
Vitaliy-1 added a commit to Vitaliy-1/ojs that referenced this issue Jan 19, 2025
Vitaliy-1 pushed a commit to Vitaliy-1/ui-library that referenced this issue Jan 20, 2025
Vitaliy-1 pushed a commit to Vitaliy-1/ui-library that referenced this issue Jan 20, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Enhancement:2:Moderate A new feature or improvement that can be implemented in less than 4 weeks.
Projects
None yet
Development

No branches or pull requests

3 participants