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

Update readme / better subject validation notes #1047

Merged
merged 1 commit into from
Nov 30, 2023
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
41 changes: 35 additions & 6 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -72,28 +72,57 @@ the INFO protocol from the server. If this option is enabled
but the server is not configured to perform the TLS handshake
first, the connection will fail.

#### Version 2.17.0: Server 2.10 support. Subject and Queue Name Validation
#### Version 2.17.0: Server 2.10 support.
The release has support for Server 2.10 features and client validation improvements including:

* Stream and Consumer info timestamps
* Stream Configuration
* Compression Option
* Subject Transform
* Consumer Limits
* First Sequence
* Multiple Filter Subjects
* Subject and Queue Name Validation

#### Multiple Filter Subjects

A new feature is the ability to have multiple filter subjects for any single JetStream consumer.

With the release of the 2.10 server, the client has been updated to support new features.
The most important new feature is the ability to have multipler filter subjects for any single JetStream consumer.
```java
ConsumerConfiguration cc = ConsumerConfiguration.builder()
...
.filterSubjects("subject1", "subject2")
.build();
```

#### Subject and Queue Name Validation

For subjects, up until now, the client has been very strict when validating subject names for consumer subject filters and subscriptions.
It only allowed printable ascii characters except for `*`, `>`, `.`, `\\` and `/`. This restriction has been changed to the following:
* cannot contain spaces \r \n \t
* cannot start or end with subject token delimiter .
* cannot have empty segments

**This means that UTF characters are now allowed in this client.**

This means that UTF characters are now allowed in subjects in this client.

For queue names, there has been inconsistent validation, if any. Queue names now require the same validation as subjects.
**Important** We realize this may affect existing applications, but need to require consistency across clients
**Important** We realize this may affect existing applications, but need to require consistency across clients.

**Subscribe Subject Validation**

Additionally, for subjects used in subscribe api, applications may start throwing an exception:

```text
90011 Subject does not match consumer configuration filter
```
Let's say you have a stream with subject `foo.>` And you are subscribing to `foo.a`.
When you don't supply a filter subject on a consumer, it becomes `>`, which means all subjects.

So this is a problem, because you think you are subscribing to `foo.a` but in reality, without this check,
you will be getting all messages `foo.>` subjects, not just `foo.a`

Validating the subscribe subject against the filter subject is needed to prevent this.
Unfortunately, this makes existing code throw the `90011` exception.

#### Version 2.16.14: Options properties improvements

Expand Down