This is the Symphony BDK for Python to help develop bots and interact with the Symphony REST APIs.
The reference documentation includes detailed installation instructions as well as a comprehensive getting started guide.
The Symphony BDK uses and requires Python 3.8 or higher. Be sure you have it installed before going further.
We use poetry in order to manage dependencies, build, run tests and publish. To install poetry, follow instructions here.
On the first time, run poetry install
. Then run poetry build
to build the sdist and wheel packages.
To run the tests, use poetry run pytest
.
It is possible to run pylint scan locally (on a specific file or package) executing the following command:
poetry run pylint <module_name>
.
To generate locally the Sphinx documentation, run: cd docsrc && make html
.
Our next milestone is the 2.5.x one. It will only consist in delivering the next improvements and bug fixes of the BDK.
In order to get in touch with the project team, please open a GitHub Issue. Alternatively, you can email/subscribe to symphony@finos.org.
- Fork it
- Create your feature branch (
git checkout -b feature/fooBar
) - Read our contribution guidelines and Community Code of Conduct
- Commit your changes (
git commit -am 'Add some fooBar'
) - Push to the branch (
git push origin feature/fooBar
) - Create a new Pull Request
NOTE: Commits and pull requests to FINOS repositories will only be accepted from those contributors with an active, executed Individual Contributor License Agreement (ICLA) with FINOS OR who are covered under an existing and active Corporate Contribution License Agreement (CCLA) executed with FINOS. Commits from individuals not covered under an ICLA or CCLA will be flagged and blocked by the FINOS Clabot tool. Please note that some CCLAs require individuals/employees to be explicitly named on the CCLA.
Need an ICLA? Unsure if you are covered under an existing CCLA? Email help@finos.org
While contributing to the project, you might need to update the generated code.
Python BDK uses OpenAPITools/openapi-generator to generate code. In order to customise the templates, a fork has been created in https://github.com/SymphonyPlatformSolutions/openapi-generator/tree/sym-python-5.5.0.
Here are the steps to follow:
- Checkout the latest branch of the fork (currently sym-python-5.5.0)
- Update the fork source code, review and merge it
- Generate a jar file in
openapi-generatormodules/openapi-generator-cli/target/openapi-generator-cli.jar
:- Using maven:
mvn clean install -Dmaven.test.skip=true && mvn clean package -Dmaven.test.skip=true
. You can also use IntelliJ's build button to build the project and generate the jar
- Using maven:
- Copy the jar in Python BDK repository
symphony-api-client-python/api_client_generation/openapi-generator-cli.jar
- Execute the generation script
./generate.sh
and commit and push you new code along with the new jar file.
Copyright 2021 Symphony LLC
Distributed under the Apache License, Version 2.0.
SPDX-License-Identifier: Apache-2.0