SASLError.java

  1. /**
  2.  *
  3.  * Copyright 2014 Florian Schmaus
  4.  *
  5.  * Licensed under the Apache License, Version 2.0 (the "License");
  6.  * you may not use this file except in compliance with the License.
  7.  * You may obtain a copy of the License at
  8.  *
  9.  *     http://www.apache.org/licenses/LICENSE-2.0
  10.  *
  11.  * Unless required by applicable law or agreed to in writing, software
  12.  * distributed under the License is distributed on an "AS IS" BASIS,
  13.  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14.  * See the License for the specific language governing permissions and
  15.  * limitations under the License.
  16.  */
  17. package org.jivesoftware.smack.sasl;

  18. import java.util.logging.Level;
  19. import java.util.logging.Logger;

  20. public enum SASLError {

  21.     aborted,
  22.     account_disabled,
  23.     credentials_expired,
  24.     encryption_required,
  25.     incorrect_encoding,
  26.     invalid_authzid,
  27.     invalid_mechanism,
  28.     malformed_request,
  29.     mechanism_too_weak,
  30.     not_authorized,
  31.     temporary_auth_failure;

  32.     private static final Logger LOGGER = Logger.getLogger(SASLError.class.getName());
  33.     @Override
  34.     public String toString() {
  35.         return this.name().replace('_', '-');
  36.     }

  37.     public static SASLError fromString(String string) {
  38.         string = string.replace('-', '_');
  39.         SASLError saslError = null;
  40.         try {
  41.             saslError = SASLError.valueOf(string);
  42.         } catch (Exception e) {
  43.             LOGGER.log(Level.WARNING, "Could not transform string '" + string + "' to SASLError", e);
  44.         }
  45.         return saslError;
  46.     }
  47. }