diff --git a/smack-core/src/main/java/org/jivesoftware/smack/util/stringencoder/BareJidEncoder.java b/smack-core/src/main/java/org/jivesoftware/smack/util/stringencoder/BareJidEncoder.java new file mode 100644 index 000000000..de0a06177 --- /dev/null +++ b/smack-core/src/main/java/org/jivesoftware/smack/util/stringencoder/BareJidEncoder.java @@ -0,0 +1,59 @@ +/** + * + * Copyright 2018 Paul Schaub + * + * Licensed 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.jivesoftware.smack.util.stringencoder; + +import org.jxmpp.jid.BareJid; +import org.jxmpp.jid.impl.JidCreate; +import org.jxmpp.stringprep.XmppStringprepException; + +public abstract class BareJidEncoder implements StringEncoder { + + @Deprecated + public static class LegacyEncoder extends BareJidEncoder { + + @Override + public String encode(BareJid jid) { + return jid.toString(); + } + + @Override + public BareJid decode(String string) { + try { + return JidCreate.bareFrom(string); + } catch (XmppStringprepException e) { + throw new IllegalArgumentException("BareJid cannot be decoded.", e); + } + } + } + + public static class UrlSafeEncoder extends BareJidEncoder { + + @Override + public String encode(BareJid jid) { + return jid.asUrlEncodedString(); + } + + @Override + public BareJid decode(String string) { + try { + return JidCreate.bareFromUrlEncoded(string); + } catch (XmppStringprepException e) { + throw new IllegalArgumentException("BareJid cannot be decoded.", e); + } + } + } +} diff --git a/smack-omemo/src/main/java/org/jivesoftware/smackx/omemo/FileBasedOmemoStore.java b/smack-omemo/src/main/java/org/jivesoftware/smackx/omemo/FileBasedOmemoStore.java index bab399c35..fb8181174 100644 --- a/smack-omemo/src/main/java/org/jivesoftware/smackx/omemo/FileBasedOmemoStore.java +++ b/smack-omemo/src/main/java/org/jivesoftware/smackx/omemo/FileBasedOmemoStore.java @@ -37,7 +37,7 @@ import java.util.logging.Level; import java.util.logging.Logger; import org.jivesoftware.smack.util.CloseableUtil; - +import org.jivesoftware.smack.util.stringencoder.BareJidEncoder; import org.jivesoftware.smackx.omemo.exceptions.CorruptedOmemoKeyException; import org.jivesoftware.smackx.omemo.internal.OmemoCachedDeviceList; import org.jivesoftware.smackx.omemo.internal.OmemoDevice; @@ -54,6 +54,7 @@ public abstract class FileBasedOmemoStore