Skip to main content

Symphony Bot Development Kit for Python

Project description

FINOS - Incubating License Python Pypi GitHub Workflow Status (branch)

Symphony BDK for Python

This is the Symphony BDK for Python to help develop bots and interact with the Symphony REST APIs.

Installation and getting started

The reference documentation includes detailed installation instructions as well as a comprehensive getting started guide.

Build from source

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.

Roadmap

Our next milestone is the 2.5.x one. It will only consist in delivering the next improvements and bug fixes of the BDK.

Contributing

In order to get in touch with the project team, please open a GitHub Issue. Alternatively, you can email/subscribe to symphony@finos.org.

  1. Fork it
  2. Create your feature branch (git checkout -b feature/fooBar)
  3. Read our contribution guidelines and Community Code of Conduct
  4. Commit your changes (git commit -am 'Add some fooBar')
  5. Push to the branch (git push origin feature/fooBar)
  6. 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

Update generated code

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
  • 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.

License

Copyright 2021 Symphony LLC

Distributed under the Apache License, Version 2.0.

SPDX-License-Identifier: Apache-2.0

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

symphony_bdk_python-2.5.0.tar.gz (331.0 kB view details)

Uploaded Source

Built Distribution

symphony_bdk_python-2.5.0-py3-none-any.whl (1.4 MB view details)

Uploaded Python 3

File details

Details for the file symphony_bdk_python-2.5.0.tar.gz.

File metadata

  • Download URL: symphony_bdk_python-2.5.0.tar.gz
  • Upload date:
  • Size: 331.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.8.14 Linux/5.15.0-1023-azure

File hashes

Hashes for symphony_bdk_python-2.5.0.tar.gz
Algorithm Hash digest
SHA256 ec9cd1acb5eee2929f7fd0da3fbf8dc28f3a718c77762f612710f22399e38836
MD5 c025575bcbc84428d210f36809a876fe
BLAKE2b-256 be444f83e98cc910133138b8a33c8c387ccf876820313138b7d2f1bbfc0e2ee5

See more details on using hashes here.

File details

Details for the file symphony_bdk_python-2.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for symphony_bdk_python-2.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 61c1e5cc739cbf4d5857701d5fe2aa374e8f91712b0f14a6639133f33d20e768
MD5 93a265e7af017a3a4ae591f3260eba6d
BLAKE2b-256 6422dc82f084d6f5d28b37fb6f82c933368ab9437df8b3ce6231f9b127c8c9fa

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page