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

io.getlime.push.model.validator.CreateDeviceRequestValidator Maven / Gradle / Ivy

There is a newer version: 1.9.1
Show newest version
/*
 * Copyright 2018 Wultra s.r.o.
 *
 * 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 io.getlime.push.model.validator;

import io.getlime.push.model.request.CreateDeviceForActivationsRequest;
import io.getlime.push.model.request.CreateDeviceRequest;

/**
 * Validator class for create device requests.
 *
 * @author Petr Dvorak, [email protected]
 */
public class CreateDeviceRequestValidator {

    /**
     * Validate {@link CreateDeviceRequest} instance.
     *
     * @param request Instance to be validated.
     * @return Error message in case there was an error, null otherwise.
     */
    public static String validate(CreateDeviceRequest request) {
        if (request == null) {
            return "Request must not be empty.";
        }
        if (request.getAppId() == null) {
            return "App ID must not be null.";
        }
        if (request.getActivationId() == null) {
            return "Activation ID must not be null.";
        }
        if (request.getPlatform() == null) {
            return "Platform must not be null.";
        }
        if (request.getToken() == null || request.getToken().isEmpty()) {
            return "Push token must not be null or empty.";
        }
        return null;
    }

    /**
     * Validate request for device registration with multiple activations.
     * @param request Request connecting device with multiple activations.
     * @return Error message in case there was an error, null otherwise.
     */
    public static String validate(CreateDeviceForActivationsRequest request) {
        if (request == null) {
            return "Request must not be empty.";
        }
        if (request.getAppId() == null) {
            return "App ID must not be null.";
        }
        if (request.getActivationIds() == null) {
            return "Activation ID list must not be null.";
        }
        if (request.getActivationIds().isEmpty()) {
            return "Activation ID list must not empty.";
        }
        if (request.getPlatform() == null) {
            return "Platform must not be null.";
        }
        if (request.getToken() == null || request.getToken().isEmpty()) {
            return "Push token must not be null or empty.";
        }
        return null;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy