grimoirelab-panels


Namegrimoirelab-panels JSON
Version 1.1.2 PyPI version JSON
download
home_pagehttps://chaoss.github.io/grimoirelab/
SummaryPanels and visualizations for GrimoireLab dashboards
upload_time2025-01-15 11:53:01
maintainerNone
docs_urlNone
authorGrimoireLab Developers
requires_python<4.0,>=3.9
licenseGPL-3.0+
keywords development grimoirelab
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            Generic Dashboards for GrimoireLab
==================================

Each of the files found in this directory are a JSON file that contains all of the information related to a Kibana dashboard.
This usually has information about the following artifacts:
* Original indexes where the information come from.
* Searches on those indexes that provide a sub-set of the information.
* Widgets either built on top of the original indexes or on top of the searches.
* Final panels that are an aggregation of several widgets.

There are Dashboards for Kibana 6 right now stored in `panels/json`

Panels
------

A panel is composed by the several widgets this contains.
So far the panels proposed as generic are a mix of the several data sources available in a project. Those could be only focused on Git, but there are others such as review systems like Gerrit, IRC channels, mailing lists, etc.

The structure for naming files should be:
* For data sources: 
```
<data_source>[_<panel_name>].json

Examples:
git_<panel_name>.json
gerrit_<panel_name>.json
```
* For other panels not focused on particular data sources we just use the name of the panel:
```
<panel_name>.json

Examples:
about.json
overview.json
git.json
git_pair_programming.json
gerrit.json
gerrit_timing.json
```
To give some examples, below there is a list of some panels that can be found in this directory:
* git.json: provides aggregated information about all of the gits in the analysis.
* gerrit.json: provides aggregated information from all of the gerrit projects.
* gerrit-backlog.json: provides specific widgets to track the backlog of the project.
* mailinglists.json: provides information about the discussions that take place in the several mailing lists.
* about.json: provides some widgets detailing this information and how to interact with the panels.
* overview.json: provides a generic view of the dataset with some widgets that help to drill down the information from the whole list of data sources.

All panels will provide widgets for filtering information by project, domain, organization, etc. depending on the availability of that information in the corresponding index.

Widgets Naming
--------------

```
 <data_source>_<metric_used>

 Example: git_top_authors
 Example: git_authors
```

Where data source could be git, gerrit, mbox, etc.

Widgets Title Naming
--------------------

In general, titles should follow the same naming scheme as the widget itself, substituting underscore characters by single spaces and adding capital letters. Nevertheless, **widgets title depends on the name of the panel** in which the widgets are located: 

- **If the panel shows information for several data sources, then the name of the data source must be included**. For example, it's the case of Data Status Panel, because it contains the same information per data source, so using data source name in title is mandatory.  

- **If the name of the data source is included in the title of the panel, then the name of the data source shouldn't be included in widgets' title**, except in cases where it could help understand what the widget contains.


```
 <data_source> <metric_used>
 
 Example: 
   Same visualization for top authors would be named: 
 
   - 'Top Authors' in 'Git' panel, as the panel is giving us context.
   - 'Git Top Authors' in 'Overview' panel where we could have similar visualizations for other data sources.
```

Of course this is a general rule, just have context into account with naming widgets to know if data source is clear or not.

Searches Naming
---------------

```
Search:_<field>:<search>

Example: Search:_pull_request:true
```


Indexes Naming
--------------
Notice that optional date is included to allow keeping several copies of the same data source when needed.

Raw indexes should use suffix `-raw`:
```
<data_source>-raw[_date]

Example: git-raw
Example: gerrit-raw
Example: stackoverflow-raw
Example: jira-raw
Example: bugzilla-raw
```
Enriched indexes:
```
<data_source>_enriched[_date]

Example: git_enriched
Example: gerrit_enriched
Example: stackoverflow_enriched
Example: jira_enriched
Example: bugzilla_enriched
```

Aliases Naming
--------------

Finally, an alias should be created pointing to the enriched index. This allows to easily modify the data used under the hood in a transparent way from the point of view of panels. Its name should be just the name of the data source, but sometimes we need different indexes for the same data source. In that case we would add a suffix to indicate the functionality of that alias.
```
<data_source>

Example: git
Example: gerrit
Example: stackoverflow
Example: jira
Example: bugzilla
```

For each index there could be as many aliases as needed. The most usual use case is using aliases for building panels or visualizations based on different time series. E.g.:
```
<data_source>_<field_name>

Example for git index and metadata__timestamp:
git_metadata__timestamp

Example for git index and metadata__updated_on:
git_metadata__updated_on

Example for jenkins and created_at field:
jenkins_created_at
```

Index Pattern Naming
--------------------

Index patterns in Kibana should follow the same naming scheme as aliases in ES (see [Aliases Naming](#aliases-naming) section). This way, is easy to know what alias is being used by a given index pattern. Besides, it makes easier to select index patterns from kibana, because their names include the field configured for time series in that index pattern. 


Common Index Fields
-------------------

Following fields that should be included in any index pattern:

* id
* url
* metadata__timestamp
* metadata__updated_on
* author_bot
* author_name
* author_org_name
* author_uuid
* author_domain
* author_user_name
* origin
* grimoire_creation_date


Data model
----------

Each of the indexes are based on a previous definition. This
is declared in CSV format with two columns: name and type.

More information at the [Schema](https://github.com/chaoss/grimoirelab-elk/tree/main/schema) directory.


How this info was retrieved
---------------------------

These json files were retrieved using [Kidash](https://github.com/chaoss/grimoirelab-kidash).

Example of how to run this:

```
$ kidash -g -e <elasticsearch-url> --dashboard <dashboard-id>* --export <local-file-path> --split-index-patterns

example: 
$ kidash -g -e https://admin:admin@localhost:9200 --dashboard overview --export overview.json --split-index-patterns
```

More information: [Kidash - Usage](https://github.com/chaoss/grimoirelab-kidash#usage).

            

Raw data

            {
    "_id": null,
    "home_page": "https://chaoss.github.io/grimoirelab/",
    "name": "grimoirelab-panels",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<4.0,>=3.9",
    "maintainer_email": null,
    "keywords": "development, grimoirelab",
    "author": "GrimoireLab Developers",
    "author_email": null,
    "download_url": "https://files.pythonhosted.org/packages/0c/36/afcbb10b8d51b2407b882da93726e81f7548b17beaaae8d9e36c943c968b/grimoirelab_panels-1.1.2.tar.gz",
    "platform": null,
    "description": "Generic Dashboards for GrimoireLab\n==================================\n\nEach of the files found in this directory are a JSON file that contains all of the information related to a Kibana dashboard.\nThis usually has information about the following artifacts:\n* Original indexes where the information come from.\n* Searches on those indexes that provide a sub-set of the information.\n* Widgets either built on top of the original indexes or on top of the searches.\n* Final panels that are an aggregation of several widgets.\n\nThere are Dashboards for Kibana 6 right now stored in `panels/json`\n\nPanels\n------\n\nA panel is composed by the several widgets this contains.\nSo far the panels proposed as generic are a mix of the several data sources available in a project. Those could be only focused on Git, but there are others such as review systems like Gerrit, IRC channels, mailing lists, etc.\n\nThe structure for naming files should be:\n* For data sources: \n```\n<data_source>[_<panel_name>].json\n\nExamples:\ngit_<panel_name>.json\ngerrit_<panel_name>.json\n```\n* For other panels not focused on particular data sources we just use the name of the panel:\n```\n<panel_name>.json\n\nExamples:\nabout.json\noverview.json\ngit.json\ngit_pair_programming.json\ngerrit.json\ngerrit_timing.json\n```\nTo give some examples, below there is a list of some panels that can be found in this directory:\n* git.json: provides aggregated information about all of the gits in the analysis.\n* gerrit.json: provides aggregated information from all of the gerrit projects.\n* gerrit-backlog.json: provides specific widgets to track the backlog of the project.\n* mailinglists.json: provides information about the discussions that take place in the several mailing lists.\n* about.json: provides some widgets detailing this information and how to interact with the panels.\n* overview.json: provides a generic view of the dataset with some widgets that help to drill down the information from the whole list of data sources.\n\nAll panels will provide widgets for filtering information by project, domain, organization, etc. depending on the availability of that information in the corresponding index.\n\nWidgets Naming\n--------------\n\n```\n <data_source>_<metric_used>\n\n Example: git_top_authors\n Example: git_authors\n```\n\nWhere data source could be git, gerrit, mbox, etc.\n\nWidgets Title Naming\n--------------------\n\nIn general, titles should follow the same naming scheme as the widget itself, substituting underscore characters by single spaces and adding capital letters. Nevertheless, **widgets title depends on the name of the panel** in which the widgets are located: \n\n- **If the panel shows information for several data sources, then the name of the data source must be included**. For example, it's the case of Data Status Panel, because it contains the same information per data source, so using data source name in title is mandatory.  \n\n- **If the name of the data source is included in the title of the panel, then the name of the data source shouldn't be included in widgets' title**, except in cases where it could help understand what the widget contains.\n\n\n```\n <data_source> <metric_used>\n \n Example: \n   Same visualization for top authors would be named: \n \n   - 'Top Authors' in 'Git' panel, as the panel is giving us context.\n   - 'Git Top Authors' in 'Overview' panel where we could have similar visualizations for other data sources.\n```\n\nOf course this is a general rule, just have context into account with naming widgets to know if data source is clear or not.\n\nSearches Naming\n---------------\n\n```\nSearch:_<field>:<search>\n\nExample: Search:_pull_request:true\n```\n\n\nIndexes Naming\n--------------\nNotice that optional date is included to allow keeping several copies of the same data source when needed.\n\nRaw indexes should use suffix `-raw`:\n```\n<data_source>-raw[_date]\n\nExample: git-raw\nExample: gerrit-raw\nExample: stackoverflow-raw\nExample: jira-raw\nExample: bugzilla-raw\n```\nEnriched indexes:\n```\n<data_source>_enriched[_date]\n\nExample: git_enriched\nExample: gerrit_enriched\nExample: stackoverflow_enriched\nExample: jira_enriched\nExample: bugzilla_enriched\n```\n\nAliases Naming\n--------------\n\nFinally, an alias should be created pointing to the enriched index. This allows to easily modify the data used under the hood in a transparent way from the point of view of panels. Its name should be just the name of the data source, but sometimes we need different indexes for the same data source. In that case we would add a suffix to indicate the functionality of that alias.\n```\n<data_source>\n\nExample: git\nExample: gerrit\nExample: stackoverflow\nExample: jira\nExample: bugzilla\n```\n\nFor each index there could be as many aliases as needed. The most usual use case is using aliases for building panels or visualizations based on different time series. E.g.:\n```\n<data_source>_<field_name>\n\nExample for git index and metadata__timestamp:\ngit_metadata__timestamp\n\nExample for git index and metadata__updated_on:\ngit_metadata__updated_on\n\nExample for jenkins and created_at field:\njenkins_created_at\n```\n\nIndex Pattern Naming\n--------------------\n\nIndex patterns in Kibana should follow the same naming scheme as aliases in ES (see [Aliases Naming](#aliases-naming) section). This way, is easy to know what alias is being used by a given index pattern. Besides, it makes easier to select index patterns from kibana, because their names include the field configured for time series in that index pattern. \n\n\nCommon Index Fields\n-------------------\n\nFollowing fields that should be included in any index pattern:\n\n* id\n* url\n* metadata__timestamp\n* metadata__updated_on\n* author_bot\n* author_name\n* author_org_name\n* author_uuid\n* author_domain\n* author_user_name\n* origin\n* grimoire_creation_date\n\n\nData model\n----------\n\nEach of the indexes are based on a previous definition. This\nis declared in CSV format with two columns: name and type.\n\nMore information at the [Schema](https://github.com/chaoss/grimoirelab-elk/tree/main/schema) directory.\n\n\nHow this info was retrieved\n---------------------------\n\nThese json files were retrieved using [Kidash](https://github.com/chaoss/grimoirelab-kidash).\n\nExample of how to run this:\n\n```\n$ kidash -g -e <elasticsearch-url> --dashboard <dashboard-id>* --export <local-file-path> --split-index-patterns\n\nexample: \n$ kidash -g -e https://admin:admin@localhost:9200 --dashboard overview --export overview.json --split-index-patterns\n```\n\nMore information: [Kidash - Usage](https://github.com/chaoss/grimoirelab-kidash#usage).\n",
    "bugtrack_url": null,
    "license": "GPL-3.0+",
    "summary": "Panels and visualizations for GrimoireLab dashboards",
    "version": "1.1.2",
    "project_urls": {
        "Bug Tracker": "https://github.com/chaoss/grimoirelab-sigils/issues",
        "Homepage": "https://chaoss.github.io/grimoirelab/",
        "Repository": "https://github.com/chaoss/grimoirelab-sigils"
    },
    "split_keywords": [
        "development",
        " grimoirelab"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "f3ff3d1edd25d89c36c3a5e30b3d2c255c7be9e0a83f6cfe1b177d392937e510",
                "md5": "bad18a932ae289e50a99805f9a5f598a",
                "sha256": "6bcbe6c5a4ede687ef9799d8bc89fe472aaf45d6c0c2c282a9e22a919d0852c5"
            },
            "downloads": -1,
            "filename": "grimoirelab_panels-1.1.2-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "bad18a932ae289e50a99805f9a5f598a",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4.0,>=3.9",
            "size": 671106,
            "upload_time": "2025-01-15T11:53:00",
            "upload_time_iso_8601": "2025-01-15T11:53:00.274206Z",
            "url": "https://files.pythonhosted.org/packages/f3/ff/3d1edd25d89c36c3a5e30b3d2c255c7be9e0a83f6cfe1b177d392937e510/grimoirelab_panels-1.1.2-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "0c36afcbb10b8d51b2407b882da93726e81f7548b17beaaae8d9e36c943c968b",
                "md5": "49fb754b4351cbf66492c1cd262050f8",
                "sha256": "8b2205a37de8eb67beb8177650225eac91769617ab3d07a31c3b3494ff326ada"
            },
            "downloads": -1,
            "filename": "grimoirelab_panels-1.1.2.tar.gz",
            "has_sig": false,
            "md5_digest": "49fb754b4351cbf66492c1cd262050f8",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4.0,>=3.9",
            "size": 491350,
            "upload_time": "2025-01-15T11:53:01",
            "upload_time_iso_8601": "2025-01-15T11:53:01.822945Z",
            "url": "https://files.pythonhosted.org/packages/0c/36/afcbb10b8d51b2407b882da93726e81f7548b17beaaae8d9e36c943c968b/grimoirelab_panels-1.1.2.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-15 11:53:01",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "chaoss",
    "github_project": "grimoirelab-sigils",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "grimoirelab-panels"
}
        
Elapsed time: 2.30841s