|
13 | 13 | */ |
14 | 14 | package io.streamnative.pulsar.handlers.mqtt.mqtt3.fusesource.base; |
15 | 15 |
|
| 16 | +import com.google.common.collect.Lists; |
16 | 17 | import io.streamnative.pulsar.handlers.mqtt.base.AuthorizationConfig; |
| 18 | +import java.net.URLEncoder; |
17 | 19 | import java.util.HashSet; |
18 | 20 | import java.util.Set; |
19 | 21 | import lombok.extern.slf4j.Slf4j; |
| 22 | +import org.apache.pulsar.client.admin.GrantTopicPermissionOptions; |
20 | 23 | import org.apache.pulsar.common.policies.data.AuthAction; |
21 | 24 | import org.awaitility.Awaitility; |
22 | 25 | import org.fusesource.mqtt.client.BlockingConnection; |
|
33 | 36 | public class AuthorizationTest extends AuthorizationConfig { |
34 | 37 |
|
35 | 38 | @Test(timeOut = TIMEOUT) |
36 | | - public void testAuthorized() throws Exception { |
| 39 | + public void testAuthorizedOnNamespace() throws Exception { |
37 | 40 | Set<AuthAction> user1Actions = new HashSet<>(); |
38 | 41 | user1Actions.add(AuthAction.produce); |
39 | 42 | admin.namespaces().grantPermissionOnNamespace("public/default", "user1", user1Actions); |
@@ -65,6 +68,51 @@ public void testAuthorized() throws Exception { |
65 | 68 | consumer.disconnect(); |
66 | 69 | } |
67 | 70 |
|
| 71 | + @Test(timeOut = TIMEOUT) |
| 72 | + public void testAuthorizedOnTopic() throws Exception { |
| 73 | + String topicName = "persistent://public/default/testAuthorizedOnTopic/a"; |
| 74 | + String encodedTopicName = "persistent://public/default/" + URLEncoder.encode("testAuthorizedOnTopic/a"); |
| 75 | + admin.topics().createNonPartitionedTopic(encodedTopicName); |
| 76 | + Set<AuthAction> user1Actions = new HashSet<>(); |
| 77 | + user1Actions.add(AuthAction.produce); |
| 78 | + final GrantTopicPermissionOptions permission1 = GrantTopicPermissionOptions.builder() |
| 79 | + .topic(encodedTopicName) |
| 80 | + .role("user1") |
| 81 | + .actions(user1Actions) |
| 82 | + .build(); |
| 83 | + admin.namespaces().grantPermissionOnTopics(Lists.newArrayList(permission1)); |
| 84 | + |
| 85 | + Set<AuthAction> user2Actions = new HashSet<>(); |
| 86 | + user2Actions.add(AuthAction.consume); |
| 87 | + final GrantTopicPermissionOptions permission2 = GrantTopicPermissionOptions.builder() |
| 88 | + .topic(encodedTopicName) |
| 89 | + .role("user2") |
| 90 | + .actions(user2Actions) |
| 91 | + .build(); |
| 92 | + admin.namespaces().grantPermissionOnTopics(Lists.newArrayList(permission2)); |
| 93 | + |
| 94 | + MQTT mqttConsumer = createMQTTClient(); |
| 95 | + mqttConsumer.setUserName("user2"); |
| 96 | + mqttConsumer.setPassword("pass2"); |
| 97 | + BlockingConnection consumer = mqttConsumer.blockingConnection(); |
| 98 | + consumer.connect(); |
| 99 | + Topic[] topics = {new Topic(topicName, QoS.AT_LEAST_ONCE)}; |
| 100 | + consumer.subscribe(topics); |
| 101 | + |
| 102 | + MQTT mqttProducer = createMQTTClient(); |
| 103 | + mqttProducer.setUserName("user1"); |
| 104 | + mqttProducer.setPassword("pass1"); |
| 105 | + BlockingConnection producer = mqttProducer.blockingConnection(); |
| 106 | + producer.connect(); |
| 107 | + String message = "Hello MQTT"; |
| 108 | + producer.publish(topicName, message.getBytes(), QoS.AT_MOST_ONCE, false); |
| 109 | + |
| 110 | + Message receive = consumer.receive(); |
| 111 | + Assert.assertEquals(new String(receive.getPayload()), message); |
| 112 | + producer.disconnect(); |
| 113 | + consumer.disconnect(); |
| 114 | + } |
| 115 | + |
68 | 116 | @Test |
69 | 117 | public void testNotAuthorized() throws Exception { |
70 | 118 | Set<AuthAction> user3Actions = new HashSet<>(); |
|
0 commit comments