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

com.amazonaws.services.databasemigrationservice.model.transform.ReplicationStatsMarshaller Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS Database Migration Service module holds the client classes that are used for communicating with AWS Database Migration Service.

The newest version!
/*
 * Copyright 2019-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file 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 com.amazonaws.services.databasemigrationservice.model.transform;

import javax.annotation.Generated;

import com.amazonaws.SdkClientException;
import com.amazonaws.services.databasemigrationservice.model.*;

import com.amazonaws.protocol.*;
import com.amazonaws.annotation.SdkInternalApi;

/**
 * ReplicationStatsMarshaller
 */
@Generated("com.amazonaws:aws-java-sdk-code-generator")
@SdkInternalApi
public class ReplicationStatsMarshaller {

    private static final MarshallingInfo FULLLOADPROGRESSPERCENT_BINDING = MarshallingInfo.builder(MarshallingType.INTEGER)
            .marshallLocation(MarshallLocation.PAYLOAD).marshallLocationName("FullLoadProgressPercent").build();
    private static final MarshallingInfo ELAPSEDTIMEMILLIS_BINDING = MarshallingInfo.builder(MarshallingType.LONG)
            .marshallLocation(MarshallLocation.PAYLOAD).marshallLocationName("ElapsedTimeMillis").build();
    private static final MarshallingInfo TABLESLOADED_BINDING = MarshallingInfo.builder(MarshallingType.INTEGER)
            .marshallLocation(MarshallLocation.PAYLOAD).marshallLocationName("TablesLoaded").build();
    private static final MarshallingInfo TABLESLOADING_BINDING = MarshallingInfo.builder(MarshallingType.INTEGER)
            .marshallLocation(MarshallLocation.PAYLOAD).marshallLocationName("TablesLoading").build();
    private static final MarshallingInfo TABLESQUEUED_BINDING = MarshallingInfo.builder(MarshallingType.INTEGER)
            .marshallLocation(MarshallLocation.PAYLOAD).marshallLocationName("TablesQueued").build();
    private static final MarshallingInfo TABLESERRORED_BINDING = MarshallingInfo.builder(MarshallingType.INTEGER)
            .marshallLocation(MarshallLocation.PAYLOAD).marshallLocationName("TablesErrored").build();
    private static final MarshallingInfo FRESHSTARTDATE_BINDING = MarshallingInfo.builder(MarshallingType.DATE)
            .marshallLocation(MarshallLocation.PAYLOAD).marshallLocationName("FreshStartDate").timestampFormat("unixTimestamp").build();
    private static final MarshallingInfo STARTDATE_BINDING = MarshallingInfo.builder(MarshallingType.DATE)
            .marshallLocation(MarshallLocation.PAYLOAD).marshallLocationName("StartDate").timestampFormat("unixTimestamp").build();
    private static final MarshallingInfo STOPDATE_BINDING = MarshallingInfo.builder(MarshallingType.DATE)
            .marshallLocation(MarshallLocation.PAYLOAD).marshallLocationName("StopDate").timestampFormat("unixTimestamp").build();
    private static final MarshallingInfo FULLLOADSTARTDATE_BINDING = MarshallingInfo.builder(MarshallingType.DATE)
            .marshallLocation(MarshallLocation.PAYLOAD).marshallLocationName("FullLoadStartDate").timestampFormat("unixTimestamp").build();
    private static final MarshallingInfo FULLLOADFINISHDATE_BINDING = MarshallingInfo.builder(MarshallingType.DATE)
            .marshallLocation(MarshallLocation.PAYLOAD).marshallLocationName("FullLoadFinishDate").timestampFormat("unixTimestamp").build();

    private static final ReplicationStatsMarshaller instance = new ReplicationStatsMarshaller();

    public static ReplicationStatsMarshaller getInstance() {
        return instance;
    }

    /**
     * Marshall the given parameter object.
     */
    public void marshall(ReplicationStats replicationStats, ProtocolMarshaller protocolMarshaller) {

        if (replicationStats == null) {
            throw new SdkClientException("Invalid argument passed to marshall(...)");
        }

        try {
            protocolMarshaller.marshall(replicationStats.getFullLoadProgressPercent(), FULLLOADPROGRESSPERCENT_BINDING);
            protocolMarshaller.marshall(replicationStats.getElapsedTimeMillis(), ELAPSEDTIMEMILLIS_BINDING);
            protocolMarshaller.marshall(replicationStats.getTablesLoaded(), TABLESLOADED_BINDING);
            protocolMarshaller.marshall(replicationStats.getTablesLoading(), TABLESLOADING_BINDING);
            protocolMarshaller.marshall(replicationStats.getTablesQueued(), TABLESQUEUED_BINDING);
            protocolMarshaller.marshall(replicationStats.getTablesErrored(), TABLESERRORED_BINDING);
            protocolMarshaller.marshall(replicationStats.getFreshStartDate(), FRESHSTARTDATE_BINDING);
            protocolMarshaller.marshall(replicationStats.getStartDate(), STARTDATE_BINDING);
            protocolMarshaller.marshall(replicationStats.getStopDate(), STOPDATE_BINDING);
            protocolMarshaller.marshall(replicationStats.getFullLoadStartDate(), FULLLOADSTARTDATE_BINDING);
            protocolMarshaller.marshall(replicationStats.getFullLoadFinishDate(), FULLLOADFINISHDATE_BINDING);
        } catch (Exception e) {
            throw new SdkClientException("Unable to marshall request to JSON: " + e.getMessage(), e);
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy