
com.netbout.rest.TkEmVerify Maven / Gradle / Ivy
/**
* Copyright (c) 2009-2016, netbout.com
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are PROHIBITED without prior written permission from
* the author. This product may NOT be used anywhere and on any computer
* except the server platform of netbout Inc. located at www.netbout.com.
* Federal copyright law prohibits unauthorized reproduction by any means
* and imposes fines up to $25,000 for violation. If you received
* this code accidentally and without intent to use it, please report this
* incident to the author by email.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
package com.netbout.rest;
import com.jcabi.manifests.Manifests;
import com.jcabi.urn.URN;
import com.netbout.spi.Alias;
import com.netbout.spi.Base;
import java.io.IOException;
import java.net.HttpURLConnection;
import java.net.URLDecoder;
import java.util.logging.Level;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.jasypt.encryption.pbe.StandardPBEStringEncryptor;
import org.jasypt.exceptions.EncryptionOperationNotPossibleException;
import org.takes.Response;
import org.takes.facets.flash.RsFlash;
import org.takes.facets.fork.RqRegex;
import org.takes.facets.fork.TkRegex;
import org.takes.facets.forward.RsFailure;
import org.takes.facets.forward.RsForward;
/**
* Verifies email.
*
* @author Dragan Bozanovic ([email protected])
* @version $Id: 93b68bcd3c0778b22c31ef790c52070d35e62320 $
* @since 2.22
*/
public final class TkEmVerify implements TkRegex {
/**
* Encryptor.
*/
private static final StandardPBEStringEncryptor ENC =
new StandardPBEStringEncryptor();
/**
* Verification code pattern.
*/
private static final Pattern PATTERN =
Pattern.compile("(.+):([^:]+):([^:]+)");
/**
* Base.
*/
private final transient Base base;
static {
TkEmVerify.ENC.setPassword(Manifests.read("Netbout-EmailCryptSecret"));
}
/**
* Ctor.
* @param bas Base
*/
public TkEmVerify(final Base bas) {
super();
this.base = bas;
}
@Override
public Response act(final RqRegex req) throws IOException {
String decoded = "";
boolean eonpe = false;
try {
decoded = TkEmVerify.ENC.decrypt(
URLDecoder.decode(
req.matcher().group(1), "UTF-8"
).replaceAll(" ", "+")
);
} catch (final EncryptionOperationNotPossibleException ignore) {
eonpe = true;
}
final String invalid = "verification link not valid.";
if (eonpe) {
throw new RsForward(
new RsFlash(invalid, Level.SEVERE),
HttpURLConnection.HTTP_MOVED_PERM,
"/"
);
}
final Matcher matcher = TkEmVerify.PATTERN.matcher(decoded);
if (!matcher.matches()) {
throw new RsFailure(invalid);
}
final Alias alias = this.getAlias(matcher.group(1), matcher.group(2));
if (alias == null) {
throw new RsFailure(invalid);
}
final String current = alias.email();
final char excl = '!';
if (current.indexOf(excl) < 0) {
throw new RsFailure("no email verification is necessary");
}
final String email = current.substring(current.indexOf(excl) + 1);
// @checkstyle MagicNumber (1 line)
if (!matcher.group(3).equals(email)) {
throw new RsFailure(invalid);
}
alias.email(email);
return new RsForward(new RsFlash("email verified"));
}
/**
* Finds alias for the provided urn and name.
* @param urn Urn
* @param alias Alias name
* @return Alias
* @throws IOException If some problem inside
*/
private Alias getAlias(final String urn, final String alias)
throws IOException {
Alias result = null;
for (final Alias als
: this.base.user(URN.create(urn)).aliases().iterate()) {
if (als.name().equals(alias)) {
result = als;
break;
}
}
return result;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy