gobblin.data.management.copy.replication.WatermarkMetadataUtil.java Source code

Java tutorial

Introduction

Here is the source code for gobblin.data.management.copy.replication.WatermarkMetadataUtil.java

Source

/*
 * 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 gobblin.data.management.copy.replication;

import java.util.List;

import com.google.common.base.Splitter;
import com.google.gson.JsonParser;

import gobblin.source.extractor.Watermark;
import gobblin.source.extractor.WatermarkSerializerHelper;

/**
 * Utility class to serialize and deserialize the {@link Watermark}
 * @author mitu
 *
 */
public class WatermarkMetadataUtil {

    public static final String DELIMITER = "\n";

    public static String serialize(Watermark watermark) {
        return watermark.getClass().getCanonicalName() + DELIMITER + watermark.toJson().toString();
    }

    public static Watermark deserialize(String content) throws WatermarkMetadataMulFormatException {
        List<String> tmp = Splitter.on(DELIMITER).trimResults().omitEmptyStrings().splitToList(content);
        if (tmp.size() < 2) {
            throw new WatermarkMetadataMulFormatException("wrong format " + content);
        }

        String classname = tmp.get(0);
        String jsonStr = tmp.get(1);

        try {
            Class<? extends Watermark> watermarkClass = (Class<? extends Watermark>) Class.forName(classname);

            return WatermarkSerializerHelper.convertJsonToWatermark(new JsonParser().parse(jsonStr),
                    watermarkClass);
        } catch (ClassNotFoundException e) {
            throw new WatermarkMetadataMulFormatException("wrong format " + e.getMessage());
        }
    }

    static class WatermarkMetadataMulFormatException extends Exception {
        private static final long serialVersionUID = 6748785718027224698L;

        public WatermarkMetadataMulFormatException(String s) {
            super(s);
        }

    }
}