---
permalink: projects/reportabug
hastr: true
layout: project
title: Report a Bug
short: reportabug
tags: qt, c++, library, development
hasgui: false
hasdocs: true
developers:
- Evgeniy Alekseev
license: LGPLv3
links:
---
Qt application/library which allows users to create an issue for projects which
are hosted on GitHub. It may work over [GitHub](//github.com "GitHub") or
[GitReport](//gitreports.com/ "GitReports"). It works fine, but it was created
as proof-of-concept.
### Developers and contributors
{% for devel in page.developers %}
* {{ devel }}{% endfor %}
### License
* {{ page.license }}
## Installation
### Instruction
#### Build as a standalone application
* Download the actual source [tarball](//github.com/arcan1s/reportabug/releases
"GitHub").
* Extract it and set up your configuration.
* Install the application:
```bash
cd /path/to/extracted/archive
mkdir build && cd build
cmake -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_BUILD_TYPE=Release -DBUILD_AS_LIBRARY:BOOL=0 ../
make
sudo make install
```
#### Build as a library in your project
* Download the actual source [tarball](//github.com/arcan1s/reportabug/releases
"GitHub").
* Extract it and set up your configuration.
* include it into your project. For example if you use `cmake`:
```cmake
add_subdirectory (reportabug)
```
* Declare class in you sources. For example:
```cpp
Reportabug *reportWindow = new Reportabug(parent=this, debugCmd=false, params=0);
reportWindow->showWindow();
```
* Link your application with this library.
### Available cmake flags:
* `-DBUILD_AS_LIBRARY=0` - build the application but not a library.
* `-DBUILD_DOCS=1` - build developer documentation.
* `-DBUILD_SHARED_LIBRARY=1` - build the shared library instead of static one.
* `-DENABLE_GITHUB=0` - disable GitHub module.
* `-DENABLE_GITREPORT=0` - disable GitReport module.
* `-DOWN_GITHUB_TOKEN=STRING` - use STRING as own GitHub token.
* `-DUSE_QT5=0` - use Qt4 instead of Qt5.
### Dependencies
I want note that all were tested on latest version of dependencies.
* qt5-base *(if Qt5 is used)* **or** qt4 *(if Qt4 is used)*
* qt5-network (if Qt5 is used)
* automoc4 *(make)*
* cmake *(make)*
* doxygen *(make, documentation)*
* qt5-webkit (if Qt5 is used) **or** qtwebkit (if Qt4 is used) *(optional,
required by GitReports module)*
## How to use
### GitHub module
This module creates an issue over GitHub. [GitHub API](//developer.github.com/v3/issues/
"Documentation") is used for creating issue. User should type own username and
password. The typical POST request is:
```bash
curl -X POST -u user:pass -d '{"title":"A new bug","body":"Some error occurs"}' \
//api.github.com/repos/owner/repo/issues
```
To disable this module use `-DENABLE_GITHUB=0` cmake flag.
This module may send request using developer's token too. Please visit [this
page](//github.com/settings/applications "Settings") and generate a new one.
Needed scopes are `public_repo` (or `repo` if you will use it for a private
repository).
**Please keep in mind that passing the token in the clear, you may discredit your account.**
The typical POST request is:
```bash
curl -X POST -H "Authorization: token token" -d '{"title":"A new bug","body":"Some error occurs"}' \
//api.github.com/repos/owner/repo/issues
```
To enable this module set up your token using `-DOWN_GITHUB_TOKEN=0` cmake flag.
This module requires `QtNetwork` module.
### GitReports module
This module creates issue over [GitReports](//gitreports.com/about "GitReports").
Please visit [this page](//gitreports.com/ "GitReports") and set up it for your
repository.
To disable this module use `-DENABLE_GITREPORT=0` cmake flag. This module requires
`QtNetwork` and `QtWebKit` modules.
## Configuration
For the developer configuration please use `config.h` header. Also you may load
parametrs dynamically using `params` array (needed keys is the same as for the
header
### Main configuration
* `OWNER` - the owner of the source repository.
* `PROJECT` - the project name.
* `TAG_BODY` - default body of an issue. It may be used for both modules.
* `TAG_TITLE` - default title of an issue. It may be used only for GitHub module.
* `TAG_ASSIGNEE` - assign an issue to this account. It may be used only for
GitHub module. This tag will work only if user has push access. If it will be
empty, it will be ignored.
* `TAG_LABELS` - set these labels to an issue. Labels should be comma separated.
It may be used only for GitHub module. This tag will work only if user has push
access. If it will be empty, it will be ignored.
* `TAG_MILESTONE` - set this milestone to an issue. It may be used only for
GitHub module. This tag will work only if user has push access. If it will be
empty, it will be ignored.
### GitHub module settings
* `GITHUB_COMBOBOX` - text of this module into comboBox.
* `ISSUES_URL` - issues url, in the most cases do not touch it. Default is
`//api.github.com/repos/$OWNER/$PROJECT/issues`. Available tags here are
`$PROJECT`, `$OWNER`.
### GitReports module settings
* `CAPTCHA_URL` - captcha url, in the most cases do not touch it. Default is
`//gitreports.com/simple_captcha?code=`.
* `GITREPORT_COMBOBOX` - text of this module into comboBox.
* `PUBLIC_URL` - issues url, in the most cases do not touch it. Default is
`//gitreports.com/issue/$OWNER/$PROJECT`. Available tags here are `$PROJECT`,
`$OWNER`.