RepoXplorer provides a web UI and a REST API to browse git stats such as:
- projects (composed of one or multiple repositories)
- contributors
- groups of contributors
Stats for a project are such as:
- commits and authors count
- date histogram of commits
- date histogram of authors
- top authors by commits
- top authors by lines changed
- top new authors by commits
Stats for a contributor or a group are such as:
- commits, lines changed and projects count
- date histogram of commits
- date histogram of authors (only for group)
- top projects by commits
- top projects by lines changed
Filters can be used to refine stats by:
- dates boundaries
- releases or tags dates
- repositories
- metadata (grabbed from commit message eg. fix-bug: 12)
RepoXplorer is composed of:
- YAML configuration file(s)
- a Git indexer service
- a WSGI application
- an ElasticSearch backend
RepoXplorer is the right tool to continuously watch and index your repositories like for instance your Github organization.
The docker container bundles ElasticSearch + the last repoXplorer version.
Simply run docker-compose to deploy.
git clone --depth 1 https://github.com/morucci/repoxplorer
cd repoxplorer
mkdir -p docker-data/conf
docker-compose up -d
firefox http://localhost:51000/index.html
Then use the github helper to create the configuration file. Here we index the Github organization of the git project.
./bin/helpers/github/repoxplorer-github-organization --org git --skip-fork --output-path docker-data/conf/git
Indexation will take between 2 and 5 minutes. See docker/README to see how to check indexation logs. Repoxplorer will check repositories every 60 seconds for news commits and index them if any.
Stop the container. Data are stored in docker volumes so you can safely stop and restart the container. docker-compose down -v can be used to remove data.
docker-compose down
The installation process described here is for CentOS 7 only.
RepoXplorer relies on ElasticSearch. Below are the installation steps for ElasticSearch 2.x:
sudo rpm --import https://packages.elastic.co/GPG-KEY-elasticsearch
cat << EOF | sudo tee /etc/yum.repos.d/elasticsearch.repo
[elasticsearch-2.x]
name=Elasticsearch repository for 2.x packages
baseurl=https://packages.elastic.co/elasticsearch/2.x/centos
gpgcheck=1
gpgkey=https://packages.elastic.co/GPG-KEY-elasticsearch
enabled=1
EOF
sudo yum install -y elasticsearch java-1.8.0-openjdk
sudo sed -i s/.*ES_HEAP_SIZE=.*/ES_HEAP_SIZE=2g/ /etc/sysconfig/elasticsearch
sudo systemctl enable elasticsearch
sudo systemctl start elasticsearch
This is method to follow especially if you intend to try the master version.
sudo yum install -y python-virtualenv libffi-devel openssl-devel python-devel git gcc
mkdir git && cd git
git clone https://github.com/morucci/repoxplorer.git
cd repoxplorer
virtualenv ~/repoxplorer
. ~/repoxplorer/bin/activate
pip install -U pip
pip install -r requirements.txt
python setup.py install
./bin/repoxplorer-fetch-web-assets
cat > ~/start-ui.sh << EOF
gunicorn_pecan --workers 10 --chdir / -b 0.0.0.0:51000 \
--name repoxplorer ~/repoxplorer/local/share/repoxplorer/config.py
EOF
chmod +x ~/start-ui.sh
~/start-ui.sh
Then open a Web browser to access http://localhost:51000/index.html
python ~/repoxplorer/bin/repoxplorer-indexer
In order to run the indexer continuously you can use the command's argument "--forever". When indexing continuously, it will sleep for 60 seconds between runs.
RepoXplorer comes with an helper to create a yaml file for from indexing a Github organization. The yaml file can then be moved to the configuration directory of repoXplorer.
repoxplorer-github-organization --org <orgname>
mv <orgname>.yaml ~/repoxplorer/local/share/repoxplorer/
# or
mv <orgname>.yaml /etc/repoxplorer/
Using the --repo argument in addition to the --org argument will create the yaml file for indexing a single repository.
This configuration directory will be called <configuration directory>/
in this documentation.
If RepoXplorer has been installed via the virtualenv method then
<configuration directory>/
will be ~/repoxplorer/local/share/repoxplorer.
Using the RPM installtion method it will be /etc/repoxplorer.
Please note that projects, groups, contributors can be defined in any YAML files in the configuration directory. RepoXplorer will load YAML files and do a basic data update when definition's keys appears in multiple YAML files. The loading is performed by alphabetical order.
Below is an example of a yaml file, note that Barbican and Swift projects are composed of two Git repositories each, a server and a client.
By default, the configuration file is <configuration directory>/projects.yaml
.
---
project-templates:
default:
uri: https://github.com/openstack/%(name)s
branches:
- master
- stable/mitaka
- stable/newton
- stable/ocata
gitweb: https://github.com/openstack/%(name)s/commit/%%(sha)s
projects:
Barbican:
description: The Barbican project
repos:
barbican:
template: default
python-barbicanclient:
template: default
Swift:
description: The Swift project
repos:
swift:
template: default
python-swiftclient:
template: default
After a change in this file you can start the Git indexer manually or let the indexer daemon reads the file (every minute) and handles changes.
The branches key of a template definition permits to define which branches to index. This key expects a list of branches name.
A list of tags can be given to each Git repositories. This tag concept should not be understood as Git tags but only as a way to mark Git repositories. For example tags like 'documentation', 'librairies', packaging, ...) could be considered. Tags defined at repositories level will be appended to those defined at the template level.
project-templates:
default:
uri: https://github.com/openstack/%(name)s
branches:
- master
tags:
- openstack
projects:
Barbican:
repos:
barbican:
templates: default
tags:
- language:python
If the list of the repository branches differs to the one defined in the template then you can overwrite it like below.
project-templates:
default:
uri: https://github.com/openstack/%(name)s
branches:
- master
projects:
Barbican:
repos:
barbican:
templates: default
branches:
- devel
- stable/1.0.x
python-barbicanclient:
templates: default
A list of releases can be defined. It is useful when you want to define release dates across all repositories defined in a project. Release dates with %Y-%m-%d format can be defined and will be merged with detected Git tags dates.
project-templates:
default:
uri: https://github.com/openstack/%(name)s
branches:
- master
releases:
- name: 2.0
date: 2016-12-20
projects:
Barbican:
repos:
barbican:
template: default
A list of paths can be given under the paths key. When defined for project repository then only commits including a file changed under one of the list of paths will match during statistics computation. If you want to define a special project Barbian-Tests that is limited to tests directory then:
project-templates:
default:
uri: https://github.com/openstack/%(name)s
branches:
- master
projects:
Barbican:
repos:
barbican:
template: default
paths:
- barbican/tests/
- barbican/functional-tests/
python-barbicanclient:
templates: default
paths:
- barbicanclient/tests/
It is also possible to define metadata parsers. Please refer to the Metadata automatic indexation section.
An unique author can use multiple emails (identities) when contributing
to a project. The identities configuration permits to define
emails that belong to a contributor. By default, the configuration file is
<configuration directory>/idents.yaml
.
In the example below, contributions from both author emails 'john.doe@server' and 'jdoe@server' will be stacked for John Doe.
---
identities:
0000-0000:
name: John Doe
default-email: john.doe@server.com
emails:
john.doe@server.com:
groups:
barbican-ptl:
begin-date: 2016-12-31
end-date: 2017-12-31
jdoe@server.com:
groups: {}
Group's membership can be defined via the groups key. A group must have been defined (Define groups of authors) before use. Membership bounces can be defined via begin-date and end-date to declare a group's membership between given dates (%Y-%m-%d).
When an identity declares a group's membership then that's not needed to define it again at groups level.
You may want to define groups of authors and be able to compute
stats for those groups. By default, the configuration file is
<configuration directory>/groups.yaml
.
---
groups:
barbican-ptl:
description: Project team leaders of Barbican project
emails:
john.doe@server.com:
jane.doe@server.com:
begin-date: 2015-12-31
end-date: 2016-12-31
barbican-core:
description: Project team leaders of Barbican project
emails: {}
acme:
description: ACME corp group
emails: {}
domains:
- acme.com
- acme.org
Group's membership is defined via an author email. Bounces can be defined via begin-date and end-date to declare a group's membership between given dates (%Y-%m-%d).
If an identity has been defined with emails part of a defined group then date bounces will overwrite those defined at the groups level.
To define a group that implicitly include commits of authors from specific domains use the domains key to list domains.
In addition to the standard Git object fields, the indexer detects metadata such as:
- close-bug: #123
- implement-feature: bp-new-scheduler
All "key: value" that match this default regex will be indexed:
'^([a-zA-Z-0-9_-]+):([^//].+)$'
Furthermore it is possible to specify custom capturing regexs to extract metadata that does not follow to the default regex.
All regexs specified in the parsers key will be executed on each commit message line. You need to have two captured elements and the first one will be used as the key, the second as the value.
project-templates:
default:
uri: https://github.com/openstack/%(name)s
branches:
- master
gitweb: https://github.com/openstack/%(name)s/commit/%%(sha)s
parsers:
- .*(blueprint) ([^ .]+).*
Custom capturing regexs must be defined prior to the indexation of the Git repository it apply.
The command repoxplorer-config-validate can be used to check
that yaml definition files follow the right format. Please use
the --config option to target <configuration directory>/config.py
when repoXplorer has been installed via the RPM package.
repoxplorer-config-validate
All endpoints can be called with or without the suffix .json. If called without the .json suffix then the request's header Accept: application/json must be set.
Some endpoints can return CSV data by adding the suffix .csv or without the suffix but by adding the request's header Accept: text/csv (curl -H "accept: text/csv").
See below for available parameters. Keep in mind that some parameters are mandatory, while some others are optional or only available for certain calls.
This endpoint permits to retrieve the platform status.
curl "http://localhost:51000/api/v1/status/status"
{
"customtext": "",
"projects": 2,
"repos": 4,
"users_endpoint": False,
"version": "1.3.1"
}
This endpoint permits to retrieve defined projects.
curl "http://localhost:51000/api/v1/projects/projects"
{
"projects": {
"Barbican": {
"description": "The barbican project",
"repos": [
{
"branch": "master",
"gitweb": "https://github.com/openstack/barbican/commit/%(sha)s",
"name": "barbican",
"parsers": [],
"releases": [],
"tags": [],
"uri": "https://github.com/openstack/barbican"
},
{
"branch": "stable/ocata",
"gitweb": "https://github.com/openstack/barbican/commit/%(sha)s",
"name": "barbican",
"parsers": [],
"releases": [],
"tags": [],
"uri": "https://github.com/openstack/barbican"
},
{
"branch": "master",
"gitweb": "https://github.com/openstack/python-barbicanclient/commit/%(sha)s",
"name": "python-barbicanclient",
"parsers": [],
"releases": [],
"tags": [],
"uri": "https://github.com/openstack/python-barbicanclient"
},
{
"branch": "stable/ocata",
"gitweb": "https://github.com/openstack/python-barbicanclient/commit/%(sha)s",
"name": "python-barbicanclient",
"parsers": [],
"releases": [],
"tags": [],
"uri": "https://github.com/openstack/python-barbicanclient"
}
]
}
}
}
This endpoint permits to retrieve repositories for a project or tag.
curl "http://localhost:51000/api/v1/projects/repos?pid=Barbican"
[
{
"branch": "master",
"gitweb": "https://github.com/openstack/barbican/commit/%(sha)s",
"name": "barbican",
"parsers": [],
"releases": [],
"tags": [],
"uri": "https://github.com/openstack/barbican"
},
...
]
This endpoint is used to fetch project, contributor, group or tag general information.
curl "http://localhost:51000/api/v1/infos/infos?cid=DwAQCBtCFg0WDg4FLAYFBg0SBQ0XAUsFDhg-"
{
"authors_amount": 1,
"commits_amount": 13,
"duration": 33695365,
"first": 1401312787,
"last": 1435008152,
"line_modifieds_amount": 4180,
"ttl_average": 184525
}
This endpoint can also output to CSV.
curl "http://localhost:51000/api/v1/infos/infos.csv?cid=DwAQCBtCFg0WDg4FLAYFBg0SBQ0XAUsFDhg-"
# or
curl -H "accept: text/csv" "http://localhost:51000/api/v1/infos/infos?cid=DwAQCBtCFg0WDg4FLAYFBg0SBQ0XAUsFDhg-"
last,authors_amount,commits_amount,ttl_average,duration,line_modifieds_amount,first
1435008152,1,13,184525,33695365,4180,1401312787
This endpoint is used to fetch contributor-specific information. Note the cid parameter is mandatory.
curl "http://localhost:51000/api/v1/infos/contributor?cid=DwAQCBtCFg0WDg4FLAYFBg0SBQ0XAUsFDhg-"
{ "repos_amount": 75,
"name": "rdo-trunk",
"mails_amount": 1,
"gravatar": "b726b19f8e7c2e23e403e4b5d3ab4508",
"projects_amount": 2
}
This endpoint is used to fetch commits.
Examples:
curl "http://localhost:51000/api/v1/commits/commits.json?pid=Barbican&limit=1"
[
1,
2214,
[
{
"Change-Id": [
"I03080db776eb4c9c2991eca8f5df43f74eb6bf24"
],
"author_date": 1507229976,
"author_email_domain": "lists.openstack.org",
"author_gravatar": "5718d97082d0499d42ea0a291c46ec40",
"author_name": "OpenStack Proposal Bot",
"ccid": "CxUDDwYYFQcOSwgbCgYFJQoIBhgHSgoWBBsfAAUGDU8aHhM-",
"cid": "CxUDDwYYFQcOSwgbCgYFJQoIBhgHSgoWBBsfAAUGDU8aHhM-",
"commit_msg": "Updated from global requirements",
"committer_date": 1507229976,
"committer_gravatar": "5718d97082d0499d42ea0a291c46ec40",
"committer_name": "OpenStack Proposal Bot",
"files_list": [
"requirements.txt"
],
"gitwebs": [
"https://github.com/openstack/python-barbicanclient/commit/77eedac597fb99745751a049a11d0719c4b67a85"
],
"line_modifieds": 2,
"merge_commit": false,
"metadata": [
"Change-Id"
],
"repos": [
"python-barbicanclient:master"
],
"sha": "77eedac597fb99745751a049a11d0719c4b67a85",
"ttl": "0:00:00"
}
]
]
This endpoint is used to fetch the top authors list by the amount of commits. It makes more sense to use it with the pid or tid parameter.
curl "http://localhost:51000/api/v1/tops/authors/bycommits?pid=Barbican"
[
{
"amount": 73,
"cid": "CxUDDwYYFQcOSwgbCgYFJQoIBhgHSgoWBBsfAAUGDU8aHhM-",
"gravatar": "5718d97082d0499d42ea0a291c46ec40",
"name": "OpenStack Proposal Bot"
},
{
"amount": 39,
"cid": "AAoTBhkNB0oIAw8RBQ4FBwcNNR4VBw4VERQPEUoGCQw-",
"gravatar": "ae4be8ffcc6d487934c3df3d3708049a",
"name": "Douglas Mendizabal"
},
{
"amount": 35,
"cid": "BRcHEh0LHAsXAxgGBB0kAgsAHABaBwoL",
"gravatar": "0ac9841e2c93f631d5f5d88f2aed0910",
"name": "Arash Ghoreyshi"
},
...
]
This endpoint can also output to CSV.
curl "http://localhost:51000/api/v1/tops/authors/bycommits.csv?pid=Barbican"
amount,gravatar,name,cid
73,5718d97082d0499d42ea0a291c46ec40,OpenStack Proposal Bot,CxUDDwYYFQcOSwgbCgYFJQoIBhgHSgoWBBsfAAUGDU8aHhM-
39,ae4be8ffcc6d487934c3df3d3708049a,Douglas Mendizabal,AAoTBhkNB0oIAw8RBQ4FBwcNNR4VBw4VERQPEUoGCQw-
35,0ac9841e2c93f631d5f5d88f2aed0910,Arash Ghoreyshi,BRcHEh0LHAsXAxgGBB0kAgsAHABaBwoL
...
This endpoint is used to fetch the top authors list by the amount of lines changed. It makes more sense to use it with the pid or tid parameter.
curl "http://localhost:51000/api/v1/tops/authors/bylchanged?pid=Barbican"
[
{
"amount": 5663,
"cid": "AAoTBhkNB0oIAw8RBQ4FBwcNNR4VBw4VERQPEUoGCQw-",
"gravatar": "ae4be8ffcc6d487934c3df3d3708049a",
"name": "Douglas Mendizabal"
},
{
"amount": 3816,
"cid": "AgkTGVsNEAUIJgYYDR0ISwUOGA--",
"gravatar": "ac3cb4707ed65da7764a4b3a9fe825e6",
"name": "Adam Harwell"
},
{
"amount": 3814,
"cid": "DgQUExAYWhYEDww1HhUHDhURFA8RSgYJDA--",
"gravatar": "fec13c0a2aa5f2db76eb72a35cd80be0",
"name": "Jarret Raim"
},
...
]
This endpoint can also output to CSV.
curl "http://localhost:51000/api/v1/tops/authors/bylchanged.csv?pid=Barbican"
amount,gravatar,name,cid
5663,ae4be8ffcc6d487934c3df3d3708049a,Douglas Mendizabal,AAoTBhkNB0oIAw8RBQ4FBwcNNR4VBw4VERQPEUoGCQw-
3816,ac3cb4707ed65da7764a4b3a9fe825e6,Adam Harwell,AgkTGVsNEAUIJgYYDR0ISwUOGA--
3814,fec13c0a2aa5f2db76eb72a35cd80be0,Jarret Raim,DgQUExAYWhYEDww1HhUHDhURFA8RSgYJDA--
...
This endpoint is used to fetch the top projects list by the amount of commits. It makes more sense to use it with the cid or gid parameter. Note this endpoint can also output to CSV. When the CSV endpoint is used with the inc_repos_detail parameter, the project field can contain values separated by ';'. Indeed a ref (reponame:branch) can be part of multiple projects. Then make sure your CSV loader is properly configured to not interpret ';' as a separator.
curl "http://localhost:51000/api/v1/tops/projects/bycommits.json?cid=CQoUBQcJECQMCAAACwEXEUgCGgE-"
[
{
"amount": 56,
"name": "Swift"
},
{
"amount": 4,
"name": "Barbican"
}
]
curl "http://localhost:51000/api/v1/tops/projects/bycommits.csv?cid=CQoUBQcJECQMCAAACwEXEUgCGgE-"
amount,name
56,Swift
4,Barbican
By using the parameter inc_repos_detail the response outputs the top repositories instead of projects.
curl "http://localhost:51000/api/v1/tops/projects/bycommits.json?cid=CQoUBQcJECQMCAAACwEXEUgCGgE-&inc_repos_detail=true"
[
{
"amount": 41,
"name": "swift:master",
"projects": [
"Swift"
]
},
{
"amount": 39,
"name": "swift:stable/ocata",
"projects": [
"Swift"
]
},
...
]
curl "http://localhost:51000/api/v1/tops/projects/bycommits.csv?cid=CQoUBQcJECQMCAAACwEXEUgCGgE-&inc_repos_detail=true"
amount,name,projects
41,swift:master,Swift
39,swift:stable/ocata,Swift
...
This endpoint is used to fetch the top projects list by the amount of lines changed. It makes more sense to use it with the cid or gid parameter. Note this endpoint can also output to CSV. When the CSV endpoint is used with the inc_repos_detail parameter, the project field can contain values separated by ';'. Indeed a ref (reponame:branch) can be part of multiple projects. Then make sure your CSV loader is properly configured to not interpret ';' as a separator.
curl "http://localhost:51000/api/v1/tops/projects/bylchanged.json?cid=CQoUBQcJECQMCAAACwEXEUgCGgE-"
[
{
"amount": 21853,
"name": "Swift"
},
{
"amount": 205,
"name": "Barbican"
}
]
curl "http://localhost:51000/api/v1/tops/projects/bylchanged.csv?cid=CQoUBQcJECQMCAAACwEXEUgCGgE-"
amount,name
21853,Swift
205,Barbican
By using the parameter inc_repos_detail the response outputs the top repositories instead of projects.
curl "http://localhost:51000/api/v1/tops/projects/bylchanged.json?cid=CQoUBQcJECQMCAAACwEXEUgCGgE-&inc_repos_detail=true"
[
{
"amount": 20172,
"name": "swift:master",
"projects": [
"Swift"
]
},
{
"amount": 20033,
"name": "swift:stable/ocata",
"projects": [
"Swift"
]
},
...
]
curl "http://localhost:51000/api/v1/tops/projects/bylchanged.csv?cid=CQoUBQcJECQMCAAACwEXEUgCGgE-&inc_repos_detail=true"
amount,name,projects
20172,swift:master,Swift
20033,swift:stable/ocata,Swift
...
This endpoint takes a reference timeframe (parameters dfromref/dtoref) and a new timeframe (parameters dfrom/dto), and returns the authors in the new timeframe that were not present in the reference timeframe. In other words, it returns the new contributors to the project in the specified timeframe.
curl "http://localhost:51000/api/v1/tops/authors/diff?pid=Barbican&dfromref=2017-11-01&dtoref=2017-11-05&dfrom=2017-11-06&dto=2017-11-16"
This command will return the new contributors between November 6th and November 16th 2017, using the period from November 1st and November 5th 2017 as a reference.
[
{
"amount": 13,
"cid": "AAoTBhkNB0oIAw8RBQ4FBwcNNR4VBw4VERQPEUoGCQw-",
"gravatar": "ae4be8ffcc6d487934c3df3d3708049a",
"name": "Douglas Mendizabal"
},
{
"amount": 2,
"cid": "AgkTGVsNEAUIJgYYDR0ISwUOGA--",
"gravatar": "ac3cb4707ed65da7764a4b3a9fe825e6",
"name": "Adam Harwell"
},
...
]
This endpoint can also output to CSV.
curl "http://localhost:51000/api/v1/tops/authors/diff.csv?pid=Barbican&dfromref=2017-11-01&dtoref=2017-11-05&dfrom=2017-11-06&dto=2017-11-16"
amount,gravatar,name,cid
13,ae4be8ffcc6d487934c3df3d3708049a,Douglas Mendizabal,AAoTBhkNB0oIAw8RBQ4FBwcNNR4VBw4VERQPEUoGCQw-
2,ac3cb4707ed65da7764a4b3a9fe825e6,Adam Harwell,AgkTGVsNEAUIJgYYDR0ISwUOGA--
...
This endpoint is used to fetch ready to use histogram data about commits amount.
curl "http://localhost:51000/api/v1/histo/commits?pid=Barbican"
[
{
"date": "2013-02-01",
"value": 16
},
{
"date": "2013-03-01",
"value": 28
},
....
]
This endpoint is used to fetch ready to use histogram data authors amount.
curl "http://localhost:51000/api/v1/histo/authors?pid=Barbican"
[
{
"date": "2013-02-01",
"value": 1
},
{
"date": "2013-03-01",
"value": 5
},
...
]
This endpoint is used to retrieve detected releases (Git tags, or user defined ones).
curl "http://localhost:51000/api/v1/tags/tags?pid=Barbican"
[
{
"date": 1367962025,
"name": "0.1.36",
"repo": "https://github.com/openstack/barbican:barbican",
"sha": "e2a599872041429ddf1d078092b9da5ab839ed83"
},
{
"date": 1368651959,
"name": "0.1.43",
"repo": "https://github.com/openstack/barbican:barbican",
"sha": "ac5df0080930bcfb0872c40d00a7cb99f2179f09"
},
...
]
This endpoint is used to fetch detected commit's metadata.
curl "http://localhost:51000/api/v1/metadata/metadata?pid=Barbican"
{
"Author": 3,
"Closes-Bug": 245,
"Closes-bug": 89,
"Co-Authored-By": 16,
"Co-authored-by": 7,
"Depends-On": 21,
"Fixes": 7,
"Implementing": 2,
"Implements": 102,
"Partial-Bug": 18,
"Partial-bug": 2,
"Partially-Implements": 27,
"Partially-implements": 17,
...
}
curl "http://localhost:51000/api/v1/metadata/metadata?pid=Barbican&key=Implements"
[
"blueprint add-authentication-token-support",
"blueprint add-cas",
"blueprint add-certificate-to-the-container-type",
"blueprint add-local-installer-script",
"blueprint add-metadata-to-secrets",
"blueprint add-missing-alembic-modules",
...
]
This endpoint can be used to search a commit's author. The search is performed against the full name.
curl "http://localhost:51000/api/v1/search/search_authors?query=john"
{
"CQAmDxoYWgkL": {
"gravatar": "957192aaa5b95658443fa90b63e10d6a",
"name": "John Dickinson"
},
"DgMRDhoINBEHEw8BGVpMCwkPEEU-": {
"gravatar": "67b96b16c256d01f79d0d330382229b3",
"name": "John Wood"
},
"DggFChwCECQCCwAcAFoHCgs-": {
"gravatar": "3d1233d9f185ca8ccfc84654d5bb1d0a",
"name": "John McKenzie"
},
...
}
This endpoint can be used to retrieve the defined groups, and search for groups that start with a specific prefix.
curl "http://localhost:51000/api/v1/groups/"
{
"Doe Organization": {
"domains": [],
"description": "People from the Doe organization",
"members": {
"DhUDDxQsBgEBDgABQhcLCA--": {
"gravatar": "659d8254ef5235d8a163734889131b0e",
"name": "John Doe"
},
"DgQQCBAeWhQACAA1HhEADQcVWw8bCQ--": {
"gravatar": "b726b19f8e7c2e23e403e4b5d3ab4508",
"name": "Doe John"
}
},
},
"redhatters": {
"domains": [
"redhat.com"
],
"description": "People from Red Hat",
"members": {},
}
}
Only one of:
- pid: project ID as in projects definitions.
- tid: tag ID as in projects definitions.
- cid: contributor ID as in contributors definitions or auto computed ID.
- gid: group ID as in groups definitions.
- dfrom: From date with the format: %Y-%m-%d.
- dto: To date with the format: %Y-%m-%d.
- metadata: key:value list of metadata grabbed from commit messages. example: 'implement-feature:bp-new-scheduler,implement:bp-new-scheduler'
- inc_merge_commit: Include merge commits in computation (default is no) set in to 'on' to include them.
- inc_repos: A list of repository IDs to only include in the computation. example: 'barbican:master,python-barbicanclient:master'
- exc_groups: group ID as in groups definitions to exclude from the computation. Can be used only with pid or tid. Only one group is supported. This parameter is exclusive with inc_groups.
- inc_groups: group ID as in groups definitions to only include in the computation. Can be used only with pid or tid. Only one group is supported. This parameter is exclusive with exc_groups.
- limit: amount of results returned by page (default: 10).
- start: page cursor (default: 0).
- key: The metadata key.
- query: The query terms. Wildcards are authorized and a logical AND is used between terms.
- prefix: Return groups that start by
prefix
. - nameonly: if set to
true
, return only the group names. Otherwise, return all information. - withstats: if set to
true
, return the amount of projects and repos that the group have contributed on.
- inc_repos_detail: Set to true or unset to include or not repositories details in the response.
- limit: Max amount of items returned (default: 10).
- limit: Max amount of items returned (default: 10).
- dfromref: Start of the reference period to use when getting new contributors, using the format: %Y-%m-%d.
- dtoref: End of the reference period to use when getting new contributors, using the format: %Y-%m-%d.
- limit: Max amount of items returned (default: 10).
Feel free to help ! I'll be happy to accept any contributions.
You can have a look to the backlog (Do not hesitate to add some - add the 'repoxplorer' tag please):
If you find an issue please fill a bug report on Github:
RepoXplorer is hosted and developed via this Gerrit instance Software Factory. Contributions should preferably be done via Gerrit but I will accept them on Github too :).
If you want to help via Github then use the regular Github workflow. Below are instructions to follow if your prefer to use Gerrit:
git clone https://softwarefactory-project.io/r/repoxplorer
git review -s # You should have login on Software Factory using your Github identity first
Your local copy is now configured. Please read the following instructions to learn about Git review sub-command git-review.
# make some changes
git add -a
git commit # local commit your changes
git review # propose your changes
The unittest suite requires a local ElasticSearch server accessible on the default port 9200/tcp. RepoXplorer is tested with ElasticSearch 2.x. No specific configuration is needed. The suite uses specific indexes destroyed and re-created at each run.
# First install required system libraries
sudo yum install -y python-virtualenv libffi-devel openssl-devel python-devel git gcc python-tox
# Then run the test suite
tox
Let's join the #repoxplorer channel on freenode.