org.kaaproject.kaa.sandbox.web.client.mvp.activity.ChangeKaaHostActivity.java Source code

Java tutorial

Introduction

Here is the source code for org.kaaproject.kaa.sandbox.web.client.mvp.activity.ChangeKaaHostActivity.java

Source

/**
 *  Copyright 2014-2016 CyberVision, Inc.
 *
 *  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.kaaproject.kaa.sandbox.web.client.mvp.activity;

import java.util.ArrayList;
import java.util.List;

import org.kaaproject.avro.ui.gwt.client.util.BusyAsyncCallback;
import org.kaaproject.kaa.sandbox.web.client.Sandbox;
import org.kaaproject.kaa.sandbox.web.client.mvp.ClientFactory;
import org.kaaproject.kaa.sandbox.web.client.mvp.place.ChangeKaaHostPlace;
import org.kaaproject.kaa.sandbox.web.client.mvp.view.ChangeKaaHostView;
import org.kaaproject.kaa.sandbox.web.client.mvp.view.dialog.ConsoleDialog;
import org.kaaproject.kaa.sandbox.web.client.mvp.view.dialog.ConsoleDialog.ConsoleDialogListener;
import org.kaaproject.kaa.sandbox.web.client.util.Analytics;
import org.kaaproject.kaa.sandbox.web.client.util.LogLevel;
import org.kaaproject.kaa.sandbox.web.client.util.Utils;

import com.google.gwt.activity.shared.AbstractActivity;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.event.shared.EventBus;
import com.google.gwt.event.shared.HandlerRegistration;
import com.google.gwt.user.client.rpc.AsyncCallback;
import com.google.gwt.user.client.ui.AcceptsOneWidget;

public class ChangeKaaHostActivity extends AbstractActivity {

    private static final String LOGS_SERVLET_URL = "sandbox/sandbox/servlet/logsServlet";

    private final ChangeKaaHostPlace place;
    private final ClientFactory clientFactory;
    private ChangeKaaHostView view;

    private List<HandlerRegistration> registrations = new ArrayList<HandlerRegistration>();

    public ChangeKaaHostActivity(ChangeKaaHostPlace place, ClientFactory clientFactory) {
        this.place = place;
        this.clientFactory = clientFactory;
    }

    @Override
    public void start(AcceptsOneWidget containerWidget, EventBus eventBus) {
        Analytics.switchScreen(Analytics.CHANGE_KAA_HOST_SCREEN);
        view = clientFactory.getChangeKaaHostView();
        bind(eventBus);
        containerWidget.setWidget(view.asWidget());
    }

    @Override
    public void onStop() {
        for (HandlerRegistration registration : registrations) {
            registration.removeHandler();
        }
        registrations.clear();
    }

    private void bind(final EventBus eventBus) {
        view.reset();

        registrations.add(view.getBackButton().addClickHandler(new ClickHandler() {
            @Override
            public void onClick(ClickEvent event) {
                clientFactory.getPlaceController().goTo(place.getPreviousPlace());
            }
        }));

        fillView();
    }

    private void fillView() {

        Sandbox.getSandboxService().changeKaaHostEnabled(new BusyAsyncCallback<Boolean>() {
            @Override
            public void onFailureImpl(Throwable caught) {
                String message = Utils.getErrorMessage(caught);
                view.setErrorMessage(message);
                Analytics.sendException(message);
            }

            @Override
            public void onSuccessImpl(Boolean enabled) {
                view.setChangeKaaHostEnabled(enabled);
                if (enabled) {
                    registrations.add(view.getChangeKaaHostButton().addClickHandler(new ClickHandler() {
                        @Override
                        public void onClick(ClickEvent event) {
                            changeKaaHost();
                        }
                    }));
                }
            }
        });

        Sandbox.getSandboxService().getLogsEnabled(new BusyAsyncCallback<Boolean>() {
            @Override
            public void onFailureImpl(Throwable throwable) {
                String message = Utils.getErrorMessage(throwable);
                view.setErrorMessage(message);
                Analytics.sendException(message);
            }

            @Override
            public void onSuccessImpl(Boolean enabled) {
                view.setGetLogsEnabled(enabled);
                if (enabled) {
                    registrations.add(view.getGetLogsButton().addClickHandler(new ClickHandler() {
                        @Override
                        public void onClick(ClickEvent clickEvent) {
                            getLogs();
                        }
                    }));

                    registrations.add(view.getChangeLogLevelButton().addClickHandler(new ClickHandler() {
                        @Override
                        public void onClick(ClickEvent clickEvent) {
                            changeLogLevel(view.getLevelListBox().getValue().toString(),
                                    view.getOldLogsCheckBox().getValue());
                        }
                    }));
                }
            }
        });

        Sandbox.getSandboxService().getKaaCurrentHost(new AsyncCallback<String>() {
            @Override
            public void onFailure(Throwable throwable) {
            }

            @Override
            public void onSuccess(String s) {
                view.getIpSpan().setInnerText(s);
            }
        });

        Sandbox.getSandboxService().getKaaCurrentLogLevel(new AsyncCallback<LogLevel>() {
            @Override
            public void onFailure(Throwable throwable) {
            }

            @Override
            public void onSuccess(LogLevel level) {
                view.getLevelListBox().setValue(level);
            }
        });
    }

    private void changeKaaHost() {
        final String host = view.getKaaHost().getValue();
        Analytics.sendEvent(Analytics.CHANGE_KAA_HOST_ACTION, host);
        Sandbox.getSandboxService().validateKaaHost(host, new AsyncCallback<Void>() {
            @Override
            public void onFailure(Throwable caught) {
                String message = Utils.getErrorMessage(caught);
                view.setErrorMessage(message);
            }

            @Override
            public void onSuccess(Void result) {
                view.clearError();
                ConsoleDialog.startConsoleDialog("Going to change kaa host to '" + host + "'...\n",
                        new ConsoleDialogListener() {

                            @Override
                            public void onOk(boolean success) {
                            }

                            @Override
                            public void onStart(String uuid, final ConsoleDialog dialog,
                                    final AsyncCallback<Void> callback) {
                                Sandbox.getSandboxService().changeKaaHost(uuid, host, new AsyncCallback<Void>() {
                                    @Override
                                    public void onFailure(Throwable caught) {
                                        callback.onFailure(caught);
                                    }

                                    @Override
                                    public void onSuccess(Void result) {
                                        dialog.appendToConsoleAtFinish(
                                                "Successfully changed kaa host to '" + host + "'\n");
                                        callback.onSuccess(result);
                                    }
                                });
                            }
                        });
            }
        });
    }

    private void getLogs() {
        Analytics.sendEvent(Analytics.GET_LOGS_ACTION, "getting logs");

        Sandbox.getSandboxService().getLogsArchive(new AsyncCallback<Void>() {
            @Override
            public void onFailure(Throwable throwable) {
                String message = Utils.getErrorMessage(throwable);
                view.setErrorMessage(message);
            }

            @Override
            public void onSuccess(Void result) {
                Sandbox.redirectToModule(LOGS_SERVLET_URL);
            }
        });
    }

    private void changeLogLevel(final String logLevel, final boolean removeOldLogs) {
        ConsoleDialog.startConsoleDialog("Going to change kaa log level to '" + logLevel + "'",
                new ConsoleDialog.ConsoleDialogListener() {
                    @Override
                    public void onOk(boolean success) {
                    }

                    @Override
                    public void onStart(String uuid, final ConsoleDialog dialog,
                            final AsyncCallback<Void> callback) {
                        Sandbox.getSandboxService().changeKaaLogLevel(uuid, logLevel, removeOldLogs,
                                new AsyncCallback<Void>() {
                                    @Override
                                    public void onFailure(Throwable throwable) {
                                        callback.onFailure(throwable);
                                    }

                                    @Override
                                    public void onSuccess(Void result) {
                                        dialog.appendToConsoleAtFinish(
                                                "Successfully changed kaa log level to '" + logLevel + "'\n");
                                        callback.onSuccess(result);
                                    }
                                });
                    }
                });
    }

}