An open API service indexing awesome lists of open source software.

https://github.com/evref-bl/sonarqube-pharo-api


https://github.com/evref-bl/sonarqube-pharo-api

Last synced: 6 months ago
JSON representation

Awesome Lists containing this project

README

          

# Sonarqube-Pharo-API

[![Continuous](https://github.com/Evref-BL/Gitlab-Pharo-API/actions/workflows/continuous.yml/badge.svg)](https://github.com/Evref-BL/Sonarqube-Pharo-API/actions/workflows/continuous.yml)
[![Coverage Status](https://coveralls.io/repos/github/Evref-BL/Sonarqube-Pharo-API/badge.svg?branch=develop)](https://coveralls.io/github/Evref-BL/Sonarqube-Pharo-API?branch=develop)

This is a Pharo client for the [Sonarqube Web API](https://next.sonarqube.com/sonarqube/web_api)

### Usage

### Installation

```st
Metacello new
githubUser: 'Evref-BL' project: 'Sonarqube-Pharo-API' commitish: 'develop' path: 'src';
baseline: 'SonarqubePharoAPI';
onConflict: [ :ex | ex useIncoming ];
load
```

### Client

To start using the API, you need to create a client instance with your Sonarqube host and a pivate token for authentication. Here’s an example:

```st
sonarApi := SonarqubeApi new host: '.com';
privateToken: ''.
```

Replace `` with your Sonarqube domain and `` with your private token.

### Ressources

The API is divided into several resources, each corresponding to a specific part of the Sonarqube API. Here are the current available resources:

- projectAnalyses
- issues

Each resource provides methods for interacting with the corresponding Bitbucket resource. You can access them like this:

```st
sonarApi projectAnalyses
```

### Examples

#### Get all analyses of a project

```st
params := {
'project' -> ''
} asDictionary.

sonarApi projectAnalyses searchWithParams: params.
```

Replace `` with the key of the project you want to get the analyses of.

### Utils

DateAndTime's `printString` does not return the correct format required by the Sonarqube API. To convert a Pharo `DateAndTime` into the appropriate format for Sonarqube, use the method `formatDate: aDateAndTime`.

For exemple if you want to get all the analyses of a project durring the last 7 days you can use this code:

```st
params := {
'project' -> ''.
'from' -> (sonarApi formatDate: (DateAndTime now - 7 days))
} asDictionary.

sonarApi projectAnalyses searchWithParams: params.
```

replace `` with the key of the project you want to get the analyses of.