Polling System developed for the Institute for Ascertaining Scientific Consensus (IASC). This platform provides a tailored architecture for surveying consensus across the scientific community, and is hosted at https://iasc.awh.durham.ac.uk/
Project Member | Contact address | Role | Unit |
---|---|---|---|
Dr. Samantha Finnigan | [email protected] | Research Software Engineer (RSE) | Advanced Research Computing |
Joanne Sheppard | [email protected] | Research Software Engineer (RSE) | Advanced Research Computing |
Prof. Peter Vickers | [email protected] | IASC Principal Investigator | Department of Philosophy |
Humanity needs a way to pool scientific community opinion quickly and efficiently on a given statement of interest. This should be on a very large scale, such that one can have confidence that the result reflects international scientific opinion. For this pilot project (2022-23), Peter Vickers has built a network of 30+ academic institutions around the world. Personal, one-to-one emails are to be sent locally to all relevant scientists at those institutions, asking for a yes/no answer to a given question. The scientist answers by hitting a button embedded in the email, and confirming the response in a second step. Each scientist on our list should have one vote only, and nobody else gets to vote. Voting should be anonymous, with any 'token' linking the scientist to their vote being destroyed after voting. Votes should be tagged to academic department, and institution, for subsequent data analysis. Originally the project was set up with Word, Excel, and Microsoft Forms, but several problems were encountered; tailored architecture is needed.
This project is developed in Python Django and React.
There are some prerequisites to be aware of: please see Dependencies for more information.
The django development server can be run using the command:
python manage.py runserver
The Black code style is used to lint this
repository on-push. Set up a pre-commit hook to ensure that any code you push is
passing this code style or Linting may fail for your commit. The
.pre-commit-config.yaml
file contains the configuration for this. You need to
tell Git to run it with the following command:
pre-commit install
If you see command not found: pre-commit
, you need to first install the
pre-commit framework.
You can also run black manually by installing the python module and then
python -m black ./src
.
Please feel free to comment on and create issues. When creating an issue, please use the correct issue template, e.g. for Bug Reports or Feature Requests.
Protected and should only be pushed to via pull requests. Should be considered stable and a representation of production code.
Should be considered fragile, code should compile and run but features may be prone to errors.
Feature branches should be created from the main
and devel
branches to track
commits per feature being worked on. External developers should fork the
repository and add their commits to a Pull Request. This follows the
"github-flow" model of branching.
Pushing to the release
branch triggers the CI/CD workflow to build the Docker
images and upload them to the DurhamARC DockerHub
repositories, then release to Azure and the backend servers. The release branch
is protected and can only be pushed to by authorized members.
The release branch is managed by rebasing on top of the main
branch and
creating a tag. For example:
$ git checkout release
$ git rebase main
$ git tag -a v1.x -m "Release v1.x"
$ git push origin release v1.x
$ git checkout main
We are using the following frameworks and tools to develop this software:
A CI/CD pipeline is used to test and release this software, using GitHub Actions and Azure Pipelines.
This work is licensed under the MIT License, a permissive license which allows Commercial use, Modification, and Distribution, but does not admit liability or warranty for use of this code.
This project was supported by the Durham University Seedcorn project fund, Durham University Department of Philosophy, and the Centre for Humanities Engaging Science and Society (CHESS).
Please cite the codebase for this work if you use or reference it in academic publications:
Mitchell Finnigan, S., Sheppard, J., & Vickers, P. (2023). IASCPolls: The Institute for Ascertaining Scientific Consensus Polling Platform (Version 1.0) [Computer software]. https://doi.org/10.5281/zenodo.8155054
@software{
Mitchell_Finnigan_IASCPolls_The_Institute_2023,
author = {Mitchell Finnigan, Samantha and Sheppard, Joanne and Vickers, Peter},
doi = {10.5281/zenodo.8155054},
license = {MIT},
month = jul,
title = {{IASCPolls: The Institute for Ascertaining Scientific Consensus Polling Platform}},
url = {https://github.com/DurhamARC/IASCPolls},
version = {1.0},
year = {2023}
}