Project

General

Profile

Actions

Patch #35769

open

Add a Revision (Changeset) API end-point with support for inclusion of associated issues

Added by Jan Catrysse about 3 years ago. Updated about 3 years ago.

Status:
New
Priority:
Normal
Assignee:
-
Category:
REST API
Target version:
-
Start date:
Due date:
% Done:

0%

Estimated time:

Description

This is a small patch to add an API call to get details about a revision and the linked issues.
It should be reviewed by someone with some more experience.

EDIT: app/controllers/repositories_controller.rb
ADD: app/views/repositories/revision.rsb

USE: https://www.redminexxx.org/projects/{project_name}/repository/{repository_name}/revisions/{revison_name}.json


Files

repositories_controller.rb.patch (975 Bytes) repositories_controller.rb.patch patch file Jan Catrysse, 2021-08-17 01:17
revision.rsb (588 Bytes) revision.rsb file to add Jan Catrysse, 2021-08-17 01:18
Actions #1

Updated by Mischa The Evil about 3 years ago

  • Subject changed from Feature: patch to add simple repositories API call to view revision details + related issues to Add a Revision (Changeset) API end-point with support for inclusion of associated issues

This could be a nice feature. Do you have some specific use-cases in mind with this addition? How do you see this being used without a dedicated end-point to fetch all repository revisions (changesets)?

Some notes on the patch(es):
  • Please provide a single, unified diff file (git format-patch and git diff output is ok).
  • Do not include commented-out code in your diffs unless there's a specific reason to do so.
  • No tests are included; to get your code integrated you'd need to write some test coverage to:
    • show that your code works as expected;
    • show (some) example API-calls with their expectations, given that you're adding to/modifying the API.

What this patch provides:

  • GET /projects/[id]/repository/[repository_id]/revisions/[revision_id].[format]
    • Example response in JSON for a Git commit:
      {
          "changeset": {
              "revision": {
                  "id": 24,
                  "repository_id": 2,
                  "revision": "git_commit_hash",
                  "committer": "Committer name <committer_email>",
                  "committed_on": "2021-01-01T00:00:00.000Z",
                  "comments": "Commit message",
                  "commit_date": "2021-01-01",
                  "scmid": "git_commit_hash",
                  "user_id": null
              },
              "issues": [
                  {
                      "id": 6,
                      "subject": "Issue subject",
                      "root_id": 6,
                      "parent_id": 5
                  }
              ]
          }
      }
      
Some questions about this feature:
  • Do we really want to include associated issues like this? It may be better to add an additional include parameter with an issues value to fetch the associated issue data on-demand only.
  • Do we really want to name the issues array issues instead of something like related_issues or associated_issues?
  • Do we really want to expose all these revision attributes?
  • Do we really want to expose the issue parent_id through this end-point?
  • Do we really want to expose the issue root_id through this end-point? AFAIK this attribute isn't exposed to any user at all in the UI.
Some possible, future additions/improvements:
  • Add an actual listing of files added/modified/copied/renamed/deleted to the output via an include=changes parameter value.
    An example of what this could look like.
Actions #2

Updated by Jan Catrysse about 3 years ago

Thank you for your help, I will look into that when I am back from holiday.

Actions

Also available in: Atom PDF