Skip to content

dxworks/jira-miner

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

63 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Jira Miner

This app is a command line application built to extract Issue information from JIRA.

Visit us on Github.

Configuration

To run the application you first need to create a file called config/jiraminer-config.properties in the config folder next to the runnable files. An example configuration file for a local environment could be:

projectID=yourProjectID
jira_home=http://localhost:6060
projects=COM
exportTypes=detailed,basic
authentication=cookie
cookie=JSESSIONID=E96741F7E5C783D3FCC7E82E3874D51B; atlassian.xsrf.token=BBPK-PX8B-NPTB-5W5S_babd22b7c0c76f69c628902b0a08daf1e9bdb609_lin
useCache=true

The file has the following fields:

projectID

The analyzed project's ID. The value of this field will be used to prefix the result file.

jira_home

The url to the jira instance you want to extract the issues from. Examples: http://localhos:8080, https://jira.<your_domain>.com, https//<your_domain>.com/jira, etc.

projects

A list of comma separated strings representing the JIRA project IDs you want to extract issues from. For example if we would have 3 projects in our JIRA instance with the IDs: PRO, NUL and SAN and we sould only want the issues from NUL and SAN, we would populate the projects field as follows: projects=NUL,SAM __

exportTypes

A list of comma separated types for export. Available types are basic and detailed, basic by default (if property is omitted). Details like changelog and comments are only retrieved and cached if detailed is present.

useCache

Whether to use the cache or not. If set to true, the app will not request the issues updated after the cache date. If set to false, the app will request all issues from the JIRA server. Default is true.

authentication

There are 4 possible values for this field:

basic

This field value requires two additional fields to be added to the configuration file: username and password, representing the username and the password of an authorized user who can access the JIRA REST API. Example usage:

...
authentication=basic
username=john.doe@my-company.com
password=Password123!
...
cookie

This field value requires one additional field to be added to the configuration file: cookie. The value of this field should be the cookie that the browser sends for an authorized user to access the JIRA Server instance. To get this Cookie value, please open a browser, login to your JIRA Server instance and access the following link <jira_home>/rest/api/2/serverInfo

The server response should be a JSON that looks similar to this one:

{
    baseUrl: "<jira_home>",
    version: "8.3.4",
    versionNumbers: [ 8, 3, 4 ],
    deploymentType: "Server",
    buildDate: "2019-09-13T00:00:00.000+0300",
    databaseBuildNumber: 803005,
    ...
    serverTitle: "Jira"
}

If you see a similar response, it means that you can access the Jira REST API using the cookie in your browser. To get the cookie from your browser, open the Developer Console (right click anywhere on the page and from the context menu select Inspect).

You should see a new Window open in your browser. Search for the Network tab and refresh the page. You should see a list of requests being made. Amongst them should be a request to serverInfo. Click on that request and look at the Request Headers Section. Copy the Cookie field value in the configuration file.

NOTE: You may have multiple fields in your cookie. Copy the entire Cookie to the jiraminer-config.properties under the cookie field.

oauth

Not Yet Implemented!!!

none

The default value for the authentication field. If selected, and if the JIRA server or JIRA Cloud you are trying to connect to requires authentication for the REST API, JiraMiner will fail.

Run

Run the jiraminer.sh or jiraminer.bat scripts to run the application after you have entered all fields to the configuration file (config/jiraminer-config.properties). You will find the output in the results folder.

NOTE: The app caches the response for each project and at a later date will request only the issues updated after the cache date. To prevent this you may delete the file at cache/yourProjectID.

Export Data Format

The application extracts the following fields from all JIRA Issues for the desired projects:

basic

    key: String
    issueType: String
    parentKey: String
    status: String
    startDate: String
    endDate: String
    summary: String
    description: String
    components: List<String>

detailed

    issueStatuses: List<ExportIssueStatus>
    issueTypes: private List<ExportIssueType>
    users: private List<ExportUser>
    issues: private List<ExportIssue> 

where:

ExportIssueStatus
    name: String
    id: String
    statusCategory: {
        name: String
        key: String
    }
ExportIssueType
    name: String
    id: String
    description: String
    isSubTask: Boolean
ExportUser
    name: String
    id: String
    avatarUrl: String
ExportIssue: check it out here

Accessing the JIRA REST API

Before using the app, make sure you can access the JIRA REST API. go to your Jira page and log in. The access the following link: <your_jira_home>/rest/api/2/serverInfo.

The server response should be a JSON that looks similar to this one:

{
    baseUrl: "<jira_home>",
    version: "8.3.4",
    versionNumbers: [
        8,
        3,
        4
    ],
    deploymentType: "Server",
    buildDate: "2019-09-13T00:00:00.000+0300",
    databaseBuildNumber: 803005,
    ...
    serverTitle: "Jira"
}

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Languages