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

PIP-30: interface and mutual change authentication #3677

Merged
merged 13 commits into from
Mar 13, 2019

Conversation

jiazhai
Copy link
Member

@jiazhai jiazhai commented Feb 23, 2019

Motivation

This is to implement the mutual auth api discussed in PIP-30: change authentication provider API to support mutual authentication

Modifications

Describe the modifications you've done.

Verifying this change

@jiazhai jiazhai requested review from merlimat and sijie February 23, 2019 13:09
@jiazhai
Copy link
Member Author

jiazhai commented Feb 23, 2019

@eolivelli would you please also help look at this. Thanks.

@eolivelli
Copy link
Contributor

Sure

Copy link
Contributor

@eolivelli eolivelli left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good work.
I left a couple of suggestions

Copy link
Member

@sijie sijie left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

overall looks good. left a few comments around the interface. I think there are still improvements to make the interface cleaner.

@jiazhai jiazhai changed the title [WIP]PIP-30: interface and mutual change authentication PIP-30: interface and mutual change authentication Feb 27, 2019
Copy link
Contributor

@eolivelli eolivelli left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I will take another look tomorrow.
What about the http API ?

Copy link
Contributor

@ivankelly ivankelly left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good in general. Requested a few changes.

@jiazhai
Copy link
Member Author

jiazhai commented Mar 1, 2019

run integration tests

@jiazhai
Copy link
Member Author

jiazhai commented Mar 1, 2019

@eolivelli @ivankelly updated, Would you please help review again.

Copy link
Contributor

@eolivelli eolivelli left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We are close to be ready.
I left a couple of comments.

@jiazhai
Copy link
Member Author

jiazhai commented Mar 1, 2019

@eolivelli Thanks for the comments, updated again.

Copy link
Contributor

@ivankelly ivankelly left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I haven't reviewed fully, but one thing I saw quickly was that the challenge goes from the client to the broker. It should be the other way around. The client initiates the connection, the server challenges the client and the client responds to the server's challenge.

@jiazhai
Copy link
Member Author

jiazhai commented Mar 2, 2019

@ivankelly Thanks, updated.

@jiazhai
Copy link
Member Author

jiazhai commented Mar 2, 2019

run java8 tests

@ivankelly ivankelly requested a review from jerrypeng March 4, 2019 11:07
@ivankelly
Copy link
Contributor

@jiazhai added @jerrypeng as he's been making some other auth changes lately.

@jiazhai
Copy link
Member Author

jiazhai commented Mar 4, 2019

Thanks @ivankelly , updated it again.

@jiazhai
Copy link
Member Author

jiazhai commented Mar 5, 2019

run java8 tests

@jiazhai
Copy link
Member Author

jiazhai commented Mar 5, 2019

run java8 tests

for error:
org.apache.pulsar.client.api.BrokerServiceLookupTest.testWebserviceServiceTls

Copy link
Contributor

@ivankelly ivankelly left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This change is missing unit tests. It should be fairly easy to mock up a AuthProvider to do multi stage auth.

private void doingAuthentication(AuthData clientData,
int clientProtocolVersion,
String clientVersion) throws Exception {
AuthData brokerData = authState.authenticate(clientData);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yes, what I find strange is that we make a call to mutate authState, and then immediately query authState to see what that mutation resulted in. It feels like this would be better done in a single call, especially if multiple threads come into play at a later date.

pulsar-common/src/main/proto/PulsarApi.proto Outdated Show resolved Hide resolved
pulsar-common/src/main/proto/PulsarApi.proto Outdated Show resolved Hide resolved
@jiazhai
Copy link
Member Author

jiazhai commented Mar 6, 2019

@ivankelly updated again. would you please help review it again

Copy link
Contributor

@ivankelly ivankelly left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

On the client side, where does it get the initial data to sent in the ConnectCommand?

@jiazhai
Copy link
Member Author

jiazhai commented Mar 6, 2019

@ivankelly Thanks for the comments. update it again.
as you mentioned, "init" is set when newConnectCommand in client side. in Kerberos, it is null. Here it just indicate that this is the start.

@jiazhai
Copy link
Member Author

jiazhai commented Mar 7, 2019

rerun java8 tests

1 similar comment
@jiazhai
Copy link
Member Author

jiazhai commented Mar 7, 2019

rerun java8 tests

@sijie
Copy link
Member

sijie commented Mar 8, 2019

@ivankelly @eolivelli can you guys please review this again? we have to push this forward to unblock subsequent changes.

@jiazhai
Copy link
Member Author

jiazhai commented Mar 12, 2019

@ivankelly Thanks for the comments, updated

@jiazhai
Copy link
Member Author

jiazhai commented Mar 12, 2019

run integration tests
run java8 tests

org.apache.pulsar.broker.admin.PersistentTopicsTest.cleanup


org.apache.pulsar.tests.integration.functions.PulsarFunctionsThreadTest.pulsar-test-suite

Copy link
Contributor

@ivankelly ivankelly left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

One small comment. Otherwise it's ready to go.

Copy link
Contributor

@ivankelly ivankelly left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

lgtm. good work Jia!

@sijie sijie added area/client type/feature The PR added a new feature or issue requested a new feature area/broker area/security labels Mar 12, 2019
@sijie sijie added this to the 2.4.0 milestone Mar 12, 2019
@jiazhai jiazhai merged commit 09e3ed8 into apache:master Mar 13, 2019
sijie pushed a commit that referenced this pull request Mar 19, 2019
Fixes #3652

**Motivation**
Currently both Zookeeper and BookKeeper could be secured by using Kerberos, It would be good to support Kerberos in Pulsar Broker and Client.
This is the sub-task for issue in #3491 to support Kerberos in Pulsar Broker and Client.
Will add proxy and web resource support in following prs.
The Kerberos authentication is similar to that in Zookeeper and BookKeeper, which leverage SASL and GSSAPI, so reused some of the code there.
PR #3658 is the first version of PR before #3677 .

**Changes**
provide both client and broker side support for authentication api;
add unit test.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area/broker area/client area/security type/feature The PR added a new feature or issue requested a new feature
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants