-
Notifications
You must be signed in to change notification settings - Fork 24
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
17 changed files
with
193 additions
and
369 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
name: docs | ||
on: | ||
push: | ||
branches: | ||
- main | ||
jobs: | ||
deploy: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v2 | ||
- uses: actions/setup-python@v2 | ||
with: | ||
python-version: 3.7 | ||
- run: pip install mkdocs mkdocs-material | ||
- run: mkdocs gh-deploy --force |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,87 +1,17 @@ | ||
# SPDX-FileCopyrightText: 2020 Splunk Inc. | ||
|
||
# splunk-add-on-ucc-framework | ||
|
||
data:image/s3,"s3://crabby-images/6ab50/6ab50289fff6c5137b60e82d580767f8d67509f3" alt="PyPI" | ||
data:image/s3,"s3://crabby-images/ffde9/ffde9cc95b5a23aed5cb7ca79bb2cb91c0d5bfa3" alt="Python" | ||
|
||
A framework to generate UI based Splunk Add-ons. It includes UI, Rest handler, Modular input, Oauth, Alert action templates. | ||
|
||
> Note: after UCC 5.2 Python 2 specific libraries are not supported anymore. | ||
> This means if the add-on has `package/lib/py2/requirements.txt` they will | ||
> not be installed while running `ucc-gen` command. Therefore modular inputs | ||
> that are supposed to run on Python 2 will not be supported by UCC. | ||
Available as a Github action here: https://github.com/splunk/addonfactory-ucc-generator-action | ||
|
||
## What is UCC? | ||
|
||
UCC stands for Universal Configuration Console. It is a service for generating Splunk Add-ons which is easily customizable and flexible. | ||
UCC provides basic UI template for creating Addon's UI. It is helpful to control the activity by using hooks and other functionalities. | ||
|
||
## Usage | ||
|
||
## Features | ||
|
||
- Generate UCC based addons for your Splunk Technology Add-ons | ||
|
||
## UCC 5 | ||
|
||
UCC 5 has potentially breaking changes to add-ons using hook extension in the UX. Previously such hooks were limited to un-optimized js files placed in the package. | ||
Add-ons may now package such extensions with webpack. | ||
|
||
## Requirements | ||
|
||
- Addon package and globalConfig.json file | ||
|
||
> Note: You may refer the globalConfig.json file [here](https://github.com/splunk/addonfactory-ucc-generator/blob/main/tests/data/package_global_config_configuration/globalConfig.json) | ||
|
||
## Installation | ||
|
||
"splunk-add-on-ucc-framework" can be installed via `pip` from `PyPI`: | ||
|
||
```bash | ||
$ pip3 install splunk-add-on-ucc-framework | ||
``` | ||
For full usage instructions, please visit the Splunk Connect for Syslog [documentation](https://splunk.github.io/addonfactory-ucc-generator/). | ||
|
||
## pre-commit | ||
|
||
Please visit `pre-commit` quick start [section](https://pre-commit.com/#quick-start). | ||
|
||
## How to use | ||
|
||
To build the UCC based addon follow the below steps: | ||
|
||
1. Install the `splunk-add-on-ucc-framework` via `pip3`. | ||
2. Run the `ucc-gen` command. | ||
3. Make sure that `package` folder and `globalConfig.json` file are present in the addon folder. | ||
4. The final addon package will be generated, in the `output` folder. | ||
|
||
|
||
## Workflow | ||
|
||
By the running the `ucc-gen` command, the following steps are executed: | ||
1. Cleaning out the `output` folder. | ||
2. Retrieve the package ID of addon. | ||
3. Copy UCC template directory under `output/<package_ID>` directory. | ||
4. Copy `globalConfig.json` file to `output/<package_ID>/appserver/static/js/build` directory. | ||
5. Collect and install Addon's requirements into `output/<package_ID>/lib` directory of addon's package. | ||
6. For the addon's requirements, packages are installed according to following table: | ||
|
||
| File Name | Description | Output directory in UCC build | | ||
|----------------------|-------------------------------------|-------------------------------| | ||
| lib/requirements.txt | Python3 compatible packages | output/<package_ID>/lib | | ||
|
||
7. Replace tokens in views. | ||
8. Copy addon's `package/*` to `output/<package_ID>/*` directory. | ||
9. If an addon requires some additional configurations in packaging than implement the steps in additional_packaging.py | ||
|
||
## Params | ||
|
||
splunk-add-on-ucc-framework supports the following params: | ||
|
||
| Name | Description | | ||
|------------|----------------------------------------------------------------------------------------------------------| | ||
| source | Folder containing the app.manifest and app source | | ||
| config | Path to the configuration file, Defaults to GlobalConfig.json in the parent directory of source provided | | ||
| ta-version | Optional override Current version of TA, Default version is version specified in globalConfig.json a Splunkbase compatible version of SEMVER will be used by default | |
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
How To Use | ||
========== | ||
|
||
Prerequisites | ||
------------- | ||
|
||
- `globalConfig.json` | ||
- `package` folder | ||
- `git` for automatic versioning (when no `ta-version` argument is | ||
specified) | ||
|
||
Example of globalConfig.json and package folder can be found at | ||
<https://github.com/splunk/splunk-add-on-for-ucc-example>. | ||
|
||
Steps | ||
----- | ||
|
||
- Install `splunk-add-on-ucc-framework` if it is not installed. | ||
- Run the `ucc-gen` command. | ||
- The final addon package will be generated, in the `output` folder. | ||
|
||
ucc-gen supports the following params: | ||
|
||
- source - [optional] folder containing the `app.manifest` and app | ||
source. | ||
- config - [optional] path to the configuration file, defaults to | ||
`globalConfig.json` in the parent directory of source provided. | ||
- ta-version - [optional] override current version of TA, default | ||
version is version specified in `globalConfig.json`. Splunkbase | ||
compatible version of SEMVER will be used by default. | ||
|
||
``` | ||
pip install splunk-packaging-toolkit | ||
slim package output/<package_ID> | ||
``` | ||
|
||
After completing the packaging slim should also output path to the | ||
package for distribution. | ||
|
||
What ucc-gen does | ||
----------------- | ||
|
||
- Cleans the output folder. | ||
- Retrieve the package ID of addon. | ||
- Copy UCC template directory under `output/<package_ID>` directory. | ||
- Copy globalConfig.json file to | ||
`output/<package_ID>/appserver/static/js/build` directory. | ||
- Collect and install Addon's requirements into | ||
`output/<package_ID>/lib` directory of addon's package. | ||
- For the addon's requirements, packages are installed according to | ||
following table: | ||
- `lib/requirements.txt` - install Python3 compatible packages into | ||
`output/<package_ID>/lib` | ||
- Replace tokens in views. | ||
- Copy addon's `package/*` to `output/<package_ID>/*` directory. | ||
- If an addon requires some additional configurations in packaging | ||
than implement the steps in `additional_packaging.py` | ||
|
Oops, something went wrong.