All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.kafka.common.security.auth.KafkaPrincipal Maven / Gradle / Ivy

There is a newer version: 3.8.0
Show newest version
/**
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 * 

* http://www.apache.org/licenses/LICENSE-2.0 *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.apache.kafka.common.security.auth; import java.security.Principal; public class KafkaPrincipal implements Principal { public static final String SEPARATOR = ":"; public static final String USER_TYPE = "User"; public final static KafkaPrincipal ANONYMOUS = new KafkaPrincipal(KafkaPrincipal.USER_TYPE, "ANONYMOUS"); private String principalType; private String name; public KafkaPrincipal(String principalType, String name) { if (principalType == null || name == null) { throw new IllegalArgumentException("principalType and name can not be null"); } this.principalType = principalType; this.name = name; } public static KafkaPrincipal fromString(String str) { if (str == null || str.isEmpty()) { throw new IllegalArgumentException("expected a string in format principalType:principalName but got " + str); } String[] split = str.split(SEPARATOR, 2); if (split == null || split.length != 2) { throw new IllegalArgumentException("expected a string in format principalType:principalName but got " + str); } return new KafkaPrincipal(split[0], split[1]); } @Override public String toString() { return principalType + SEPARATOR + name; } @Override public boolean equals(Object o) { if (this == o) return true; if (!(o instanceof KafkaPrincipal)) return false; KafkaPrincipal that = (KafkaPrincipal) o; if (!principalType.equals(that.principalType)) return false; return name.equals(that.name); } @Override public int hashCode() { int result = principalType.hashCode(); result = 31 * result + name.hashCode(); return result; } @Override public String getName() { return name; } public String getPrincipalType() { return principalType; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy