Contributing to OsiriXgrpc
Welcome to the contributions section!
OsiriXgrpc is an emerging open-source initiative by the Institute of Cancer Research, dedicated to accelerating the field of medical image science and processing. At the heart of our mission lies a commitment to the democratization of knowledge and empowerment of medical imaging researchers worldwide. By harnessing the advanced capabilities of OsiriX's user interface and DICOM database, our project aims to streamline the development process of robust medical imaging tools, allowing researchers to concentrate on groundbreaking scientific discoveries, including pioneering AI.
As a community-driven project, we invite contributors from diverse backgrounds to join us in shaping the future of medical research, fostering an environment of collaboration and innovation.
Ways to Contribute
Example Scripts | We strongly encourage developers to share scripts of OsiriXgrpc in use. Please see Contributing pyOsiriX Example Scripts section for more information. |
Documentation | We encourage feedback on our documentation to improve the user experience and ensure it makes sense. We currently do not support localization, but should the project be successful we would encourage this moving forward. Please see our instructions for project documentation for more information. |
Testing | We greatly appreciate our testers, who provide core feedback on OsiriXgrpc and have a key role in deciding the future of the project. Please contact us if you would like to become an official tester! |
Bug Tracking | We will endeavour to fix all bugs encountered in OsiriXgrpc as soon as possible. If you encounter a bug, please see our bug reporting section. |
Feature Suggestions | We cannot improve OsiriXgrpc without good ideas coming from users. If you would like to request a new feature this can be done as a feature request on the project issue tracker. Please note that acceptance and importance of features will be discussed and agreed by our developers following discussion with you. We cannot guarantee that all feature requests will be implemented, or how quickly they will be delivered. |
Feature Development | If you would like to help develop the core OsiriXgrpc plugin, we are keen to improve and evolve every
aspect of it. This includes:
|
Code of Conduct
Please see our Code of Conduct for more information.
Prerequisites
In order to help contribute to the OsiriXgrpc project there are a few things you will need. Some may not be required depending on the level contributions you want to make.
Mac | OsiriX works on macOS. We currently support (and have tested) compatability of OsiriXgrpc on macOS Monterey and above, on both Intel and M1/M2/M3 native processors. We always advise ensuring that your operating system is up-to-date. |
OsiriX | A copy of the latest OsiriX app downloaded on your system. This will be crucial for testing the OsiriXgrpc plugin, developing new features, and authoring new OsiriXgrpc scripts. |
Xcode | Xcode is freely available from the App store, and is only required if you want to develop new features for the core OsiriXgrpc plugin, or build the source code. |
GitHub Account | You will need a GitHub account to interact with the OsiriXgrpc source code, create pull requests for new features that you have developed, and raise new issues or report bugs on the project issue tracker. |
Coding Guidelines
Project Structure
There are several core files and directories at the root of the project
Name | Description |
---|---|
.github | Issue templates and CI/CD workflows for GitHub Actions. |
cpp | Auto-generated C++ protobuf files (not under version control). |
docs | All externally-facing documentation (definition files in markdown). |
protos | gRPC protocol files, which need to be modified to provide additional OsiriX functionality. |
pyosirix | Source code for the pyOsiriX sub-project, including translation of all functionality into Python classes. . |
python | Source code for the osirixgrpc pip project. Sub-folder osirixgrpc is automatically generated (not under version control). |
src | Source files for building the OsiriXgrpc plugin. This is also where gRPC methods are implemented. |
tests | Integration tests for the plugin and protobuf files. Note these are not automated and run manually. |
.bumpversion.cfg | Rules to increment version numbers scattered throughout the project. |
build.sh | A utility shell script used to compile gRPC from source and build all protobuf files from definition (.proto) files on a host machine. |
Modifying Source Code
When making changes to the source code, we recommend the following process to ensure your contributions can be efficiently reviewed and integrated:
- Fork the Repository Start by forking the repository. This creates your own copy of the project where you can make your changes.
- Build the Plugin Before making any changes, please familiarize yourself with the build process.
- Make Your Changes Implement your changes in your forked repository. To facilitate a smooth review process, we
suggest:
- Isolate Changes: Keep your changes focused. Large or complex modifications may require more extensive review and have a higher chance of being rejected.
- Communicate Intentions: Let us know about your planned changes in advance. This helps us coordinate contributions and include them in our release planning.
- Submit a Pull Request (PR) Once you're satisfied with your changes, submit them back to the main project via a
pull request. Ensure your PR targets the
dev
branch. For guidance on creating a pull request, see GitHub's documentation on Creating a pull request from a fork. - Review Process Your pull request will undergo a review by the project maintainers. During this phase:
- Merge Upstream Changes: You may be asked to merge changes from the upstream
dev
branch into your fork to resolve any conflicts. - Version Bumping: If your changes are accepted, you'll be asked to bump the version by executing bumpversion build. This step is crucial for maintaining version control and ensuring compatibility.
- Merge Upstream Changes: You may be asked to merge changes from the upstream
- Final Steps After addressing any review comments and completing the version bump, your changes will be merged into
the
dev
branch.
Additional Tips for a Successful Contribution
- Follow Coding Standards Adhere to the coding standards and guidelines provided in the repository documentation to increase the likelihood of your changes being accepted.
- Test Thoroughly Before submitting your pull request, thoroughly test your changes to ensure they work as expected and do not introduce any new issues.
By following these guidelines, you can contribute valuable improvements to osirixgrpc and help enhance its functionality and user experience.
Version Control
OsiriXgrpc uses semantic versioning (major.minor.patch-releasebuild
) using a traditional Gitflow scheme as illustrated
in the figure below. All development takes place within the dev
branch prior to release in the main branch. This
branch exists in one of two phases:
- Development phase. Each version is appended by the
_devX
, whereX
increments after each additional feature is merged. New features are accepted in this stage. - Release Candidate phase. Each version will be appended by the
_rcX
, whereX
increments after each additional hot-fix applied during user testing. No new features will be accepted during this phase.
Once all tests are complete, the dev
branch is merged with main
, and the software remains a beta release for an
incubation period of 2 months, before being fully released. During this period, only hotfixes may be made with no
change to the core infrastructure (i.e. nomenclature to remain consistent). This provides us with some buffer to perform
tests on the main branch and obtain feedback from external users.
Any release with major
= 0 means that we may make subtle changes to the technology prior to 1.0.0 (i.e. no promises!).
Versioning is controlled by bump2version. Please don't bump the version until your code is ready to be merged after review of the pull request to ensure it uses the intended version. Below are the commands available to bump2version within this project, and example increments in each case:
bumpversion build |
1.0.0-dev0 → 1.0.0-dev1 → 1.0.0-dev2 → ... or 1.0.0-rc0 → 1.0.0-rc1 → 1.0.0-rc2 → ... |
bumpversion release |
1.0.0-dev5 → 1.0.0-rc0 → 1.0.0-beta0 → 1.0.0 |
bumpversion patch |
1.0.0 → 1.0.1-dev0 → 1.0.2-dev0 → ... |
bumpversion minor |
1.0.2 → 1.1.0-dev0 → 1.2.0-dev0 → ... |
bumpversion major |
1.2.0 → 2.0.0-dev0 → 3.0.0-dev0 → ... |
Building
To build the plugin, please use the build.sh
script provided, which emulates the final build performed as during
CI/CD in the main
and dev
branches. This script performs the following operations within your repository:
- Clone the correct version of gRPC (to a directory called
grpc
). - Build Intel (x86_64) and Apple Silicon (arm64) gRPC libraries and executables.
- Combine the libraries into universal binary files using the
lipo
tool. - Use the compiled executables to C++ and Python implementation files from the protocol files (in
protos
directory). - Ensure the OsiriXgrpc python package (
Python
directory) has the correctrequirements.txt
definitions. - Build and zip the plugin bundle. This will result in a file called
osirixgrpc.osirixplugin.zip
.
Note: The built file will not be signed and thus should not be shared. Please ensure you share your changes with us by issuing a pull request, and we will ensure your changes are incorporated into a signed plugin for distribution during the next release.
Documentation
All documentation is written in Markdown format and compiled using MkDocs. The organization of documentation should be kept consistent, and any changes to layout need to be fully discussed and agreed with all developers before being implemented.
Name | Description |
---|---|
docs/api | Description files for all OsiriXgrpc client API (in Python). |
docs/assets | Location for all figures and other supporting information not in Markdown format. |
docs/contributing | Instruction for how to contribute to the project. |
docs/pyosirix | Documentation for the pyOsiriX sub-package. |
docs/getting_started.md | Core instructions on how to install and use the OsiriX plugin (e.g. user-interface). |
docs/README.md | The homepage for the documentation. |
mkdocs.yaml | yaml configuration file for the mkdocs build |
Requirements
Building documentation requires both mkdocs and
Building Documentation
To build the documentation from source it is sufficient to run the following command, from the docs
folder within the
project root:
site
, which contains all built html documentation for deployment.
When developing documentation, however, it can be beneficial to run the MkDocs server (again from the docs
folder):
Deploying Documentation
Collaborators should not directly modify the deployed documentation. Instead, this will be performed as part
of OsiriXgrpc continuous integration. The OsiriXgrpc documentation will be deployed from either the main
or dev
branches to one of two sites, following a push to the GitHub repository:
Branch | Site | |
---|---|---|
main |
https://osirixgrpc.github.io/osirixgrpc | All documentation for OsiriXgrpc releases |
dev |
https://osirixgrpc.netlify.app | Documentation in development mode and for user testing of next release. |
Suggesting Changes
If you would like to suggest a change to the documentation please let us know through the project
issue tracker, ensuring you
choose a documentation
label for the issue. If you wish to help contribute to the documentation, then please fork the
latest copy of the repository, modify it, and submit a pull request to the main branch.
Bug Reporting
If you encounter any bugs with the OsiriXgrpc plugin then please let us know through the
issue tracker, ensuring you choose a bug
label. When
you raise the issue, please using the relevant template for bugs, which will include the following information:
- Is the bug related to the plugin (OsiriXgrpc) or a client issue (pyOsiriX)?
- What steps could we use to reproduce the bug?
- If the issue is related to a script that you used, please send us (where possible):
- The script that caused the issue.
- The output of the Task Console (from OsiriX click `Plugins` → `Database` → `osirixgrpc` → `Task Console`)
- If the issue is plugin related, please send us any information provided by Mac when the error occurred.
- OsiriX version.
- OsiriXgrpc version.
- macOS version.
- Processor (Intel or Mac M1/M2/M3).
User Testing
OsiriXgrpc relies on frequent user testing to ensure stability and usability of all developed features. We are keen to hear from anyone who would like to contribute to testing and help us improve OsiriXgrpc (please check our prerequisites for user testing).
User testing takes place prior to each major and minor release of OsiriXgrpc. Each user test consists of completing a Google Form that checks successful completion and obtains feedback on each of the following general operations:
- Installation of OsiriXgrpc.
- Initiating an OsiriXgrpc server.
- Installing a script.
- Running a script.
In addition, we will ask testers to run some automated unit tests. Automated unit testing for OsiriXgrpc presents substantial challenges - this complexity arises from its dependency on symbols and functions embedded within the OsiriX executable. Consequently, to maintain the quality and reliability of OsiriXgrpc, we incorporate unit testing into our user tests. This approach also ensures comprehensive validation through real-world usage scenarios.
To run automated unit tests:
- Clone the latest repository, or pull changes.
- Switch to the
dev
branch (git checkout dev
). - Open up OsiriX and move to or create an empty database (no Dicom studies/series displayed).
- Ensure that an OsiriXgrpc port
50001
is established and running (see Getting Started) - Change directory to
tests
(cd tests
from the main repository). - Run the shell script:
bash run_tests.sh
Please wait while OsiriX runs through all the tests (many screen will open and close). The shell script will indicate
testing is complete. Unit tests will save results to an output directory on your Desktop osirixgrpc_tests
. Please
zip this folder and send it to us. Contained files do not capture any personal information, other than the
versions of macOS, OsiriX, and OsiriXgrpc.
Feature Requests
We warmly invite fresh insights and suggestions for enhancing OsiriXgrpc. Your contributions could range from extending OsiriX features via our API, refining our user interface, to offering ideas for optimizing our workflow or enhancing our documentation. Every piece of feedback is invaluable to us. While we are committed to incorporating your suggestions to the best of our ability, please remember that OsiriXgrpc thrives on community involvement and operates on a voluntary basis. Consequently, we cannot provide specific timelines for the introduction of new features. Additionally, it's crucial to acknowledge that our ability to implement certain enhancements is contingent upon the functionalities available within the OsiriX application itself.
If you wish request new features, please use our
issue tracker ensuring that you use a feature request
label, using the feature_request
issue template. This includes the following information
- To which aspect of OsiriXgrpc is the feature request intended?
- Short description of the new functionality
- Why would this improve the functionality of OsiriXgrpc?
- Have you been using any work-around so far?
- How urgent is the new functionality to you?
- Would you be willing to help develop/test the new functionality?
Issues
Please use the relevant label for each issue that you submit on the GitHub project.
Label | Description |
---|---|
bug |
If you encounter a bug then please let us know using the provided template. See Bug Reporting for more information. |
feature_request |
What else would you like see from OsiriXgrpc? Is there any functionality in OsiriX that you think warrant exposure through API? |
documentation |
Tell us how we can improve our documentation. This includes everything from fixing spelling mistakes to improving interpretability. |
generic |
Any other issue you have with OsiriXgrpc. |
Contact
Name | Contact |
---|---|
Matt Blackledge | matthew.blackledge@icr.ac.uk |
Timothy Sum Hon Mun | timothy.sumhonmun@icr.ac.uk |