Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add SASL configs to AIOKafkaProducer #19

Open
wants to merge 214 commits into
base: main
Choose a base branch
from

Conversation

YuWang24
Copy link

About this change - What it does

Add options to AIOKafkaProducer in karapace/kafka_rest_apis/__init__.py to allow SASL configurations. sasl_mechanism, sasl_plain_username, and sasl_plain_password are added.

References: Aiven-Open#299

Why this way

Just adding these parameters in the AIOKafkaProducer's constructor to allow SASL configurations.

libretto and others added 30 commits March 30, 2021 11:58
* Add protobuf skeleton

* Add skeleton files

* remove unfinished tests

* fixup lint errors

* Changed project structure, and added one test and debugged issues for PR #1

* fixup lint issues

* fixup by @hackaugusto suggestions
Protobuf parser library and first part of working tests.
* tests/test_schema.py: splitting test_schema()

Split test_schema() to multiple single-purpose tests
No essential functional changes in the tests

* Added information how to run integration tests against Confluence stack

Instructions in README.rst
Docker Compose file to start the Confluence stack

* Kafka REST fixed version to 6.1.1 to match Schema Registry

* README.rst: clarified compatibility

Changed the claim that Karapace is compatible to that aims to be compatible with 6.1.1 and added a list of known incompabilities.

* Configuration Keys as table

* fixed content table

* Fixed small spelling bugs

* test_schema.py removed assert_schema_versions from test_schema_repost, unrelated

* test_schema.py added -> None to all test method signatures.

* test_schema.py: added annotations to all functions

* test_schema.py duplicate code removal

* test_schema.py moved a comment to a an assert message

* test_schema.py removed unneeded f-string wrappings

* utils.py AVRO name compatible (http://avro.apache.org/docs/current/spec.html#names). Must not have '-'.

* test_schema.py test_schema_version_numbering uses 'name' in the Avro to make the schema unique

* test_schema.py: str format() -> f-strings

* test_schema.py no more JSONs as strings, instead dicts that are dumped as JSON strings

* utils.py add create_schema_name_factory, create safer names

For example in Avro field names '-' is not allowed. Using underscore instead.

* test_schema.py: split test_schema_versions into two tests

New ones: test_schema_versions_multiple_subjects_same_schema and test_schema_versions_deleting

The tests use unique schema names

* test_schema.py: test_schema_remains_constant fixes

Wasn't using a unique schema id.
Added doc

* test_schema.py removed test_enum_schema_compatibility

Essentially a duplicate of test_enum_schema

* test_schema.py: fix test_schema_repost

Compares JSONs now, not strings.

* test_schema.py test_compatibility_endpoint fix

Now uses a dynamic unique schema name. Was clashing before.
Added documentation on what the test does.

* test_schema.py test_record_schema_compatibility_backward split into two

The new ones: test_record_schema_compatibility_backward and test_record_schema_compatibility_forward

* test_schema_version_number_existing_schema takes version ids from response

Now compatible with SR

* test_schema.py: test_schema_subject_version_schema fix

Changed to use a proper Avro schema

* test_schema.py: test_schema_same_subject fix

No longer expects the exact same string schema to be returned.
The str parsed as JSON needs to match.

* Handle gracefully if no node is master eligible

Karapace configuration allows configuring node to not be eligible for
master.  Handle gracefully ie. read-only mode if all nodes are
configured non-eligible for master.

* schema_registry: breaking change in an error message

The error message in POST to /subject/<subject> when schema is not specified in the request changed.

Fixes test_schema_subject_post_invalid to run in Karapace and against Schema Registry

* schema_registry: breaking change in subjects/{}/versions/{}

Fixed the error message in subjects/{}/versions/{} to match Schema Registry

Now test_schema_subject_invalid_id works against SR

* test_schema.py test_version_number_validation fix

Error message check matches the error from SR (was breaking the test)
Dynamically fetches the version number
Added description for the test

* Add some typing, rename eligible master flag for clarification

* schema_registry: breaking change in POST subjects/{subject}/versions

In the case the endpoint is submitted without body, changed
the HTTP status code, error_code and message match the ones in Schema Registry.
Made the necessary changes so that Karapace also returns correct values.

test_schema.py: test_schema_missing_body fixed accordingly.

* schema_registry: breaking changes in some HTTP error messages

Now HTTP error messages match with the ones coming from Schema Registry.
Adjusted test_http_headers in test_schema.py to correctly check the messages.

* schema_registry: breaking change in /schemas/ids/<>/versions

/schemas/ids/<schema_id:path>/versions now returns empty list in case nothing is found.
This is the behaviour of SR. Karapace used to fail in this case before this change.

The tests test_schema_lifecycle and test_schema_versions_deleting now works against Schema Registry (in addition to Karapace)

* test_schema.py: test_schema_versions_deleting: No unique field

Unique field name not needed, schema name is enough. Using a fixed one.

* readme: clarified and separated readme

moved documentation about development to the CONTRIBUTING.md file, and
tried to make the README.rst a bit more concise.

* Remove explicit master eligibility flag and utilize optional master_url

* CONTRIBUTING.md small fixes

Only minor changes, no essential content change:

Changed some rst formattings to md
Some typos fixed such as karapace -> Karapace
A few small tweaks

* doc: fixed grammar

* KarapaceAll: startup fix

When started from KarapaceAll, the __init__ of KarapaceSchemaRegistry is not called.
schema_lock is initialized in __init__. Thus it's not called when using KarapaceAll.

Fix is to move schema_lock init to _init() which gets called also when using KarapaceAll.

* docs: locahost -> localhost

Co-authored-by: Juha Mynttinen <[email protected]>
Co-authored-by: Francesco <[email protected]>
Co-authored-by: Tommi Vainikainen <[email protected]>
Co-authored-by: Augusto Hack <[email protected]>
libretto and others added 26 commits January 21, 2022 13:03
Co-authored-by: Augusto Hack <[email protected]>
…asl-configs-to-AIOKafkaProducer

Merge the changes from upstream/master to keep in sync.
@amrutha-shanbhag
Copy link

guess we could update readme also to describe the new config params

@amrutha-shanbhag amrutha-shanbhag self-requested a review February 4, 2022 01:04
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants