org.apilytic.currency.mvc.controller.HomeController.java Source code

Java tutorial

Introduction

Here is the source code for org.apilytic.currency.mvc.controller.HomeController.java

Source

/*
 * Copyright 2002-2013 the original author or authors
 *
 *     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.apilytic.currency.mvc.controller;

import java.util.SortedSet;

import org.apache.log4j.Logger;
import org.apilytic.currency.model.TwitterAdapterStatus;
import org.apilytic.currency.model.TwitterMessage;
import org.apilytic.currency.model.TwitterMessages;
import org.apilytic.currency.service.CurrencyRateIngestionService;
import org.apilytic.currency.service.TwitterService;
import org.apilytic.currency.support.SortOrder;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;

/**
 * Handles requests for the application home page.
 * 
 * @author Georgi Lambov
 * @since 1.0
 * 
 */
@Controller
@RequestMapping
public class HomeController {

    private static final Logger LOGGER = Logger.getLogger(HomeController.class);

    @Autowired
    private TwitterService twitterService;

    @Autowired
    private CurrencyRateIngestionService rateIngestionService;

    /**
     * Simply selects the home view to render by returning its name.
     */
    @RequestMapping(value = { "/", "/tweets" })
    public String home(Model model, @RequestParam(required = false) Long latestTweetId,
            @RequestParam(defaultValue = "DESCENDING", required = false) SortOrder sortOrder) {

        if (latestTweetId == null) {
            latestTweetId = 0L;
        }

        try {
            rateIngestionService.syncCountryCurrenciesAndRates();
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        final SortedSet<TwitterMessage> twitterMessages = twitterService.getTwitterMessages(latestTweetId,
                sortOrder);

        TwitterMessages twitterMessagesWrapper = new TwitterMessages();

        if (twitterMessages == null || twitterMessages.isEmpty()) {
            twitterMessagesWrapper.setLatestTweetId(latestTweetId);
        } else {
            twitterMessagesWrapper.setTwitterMessages(twitterMessages);
        }

        twitterMessagesWrapper.setAdapterRunning(twitterService.isTwitterAdapterRunning());

        if (LOGGER.isDebugEnabled()) {
            LOGGER.debug(String.format("Latest Tweet ID: '%s'; Adapter running: %s",
                    twitterMessagesWrapper.getLatestTweetId(), twitterMessagesWrapper.isAdapterRunning()));
        }

        model.addAttribute("tweets", twitterMessagesWrapper);

        return "home";
    }

    @ResponseBody
    @RequestMapping(value = { "/adapter/{state}" })
    public void state(@PathVariable String state) {

        if ("start".equalsIgnoreCase(state)) {
            twitterService.startTwitterAdapter();
        } else if ("stop".equalsIgnoreCase(state)) {
            twitterService.stopTwitterAdapter();
        }

    }

    @ResponseBody
    @RequestMapping(value = { "/adapter-running" })
    public TwitterAdapterStatus isRunning() {
        TwitterAdapterStatus status = new TwitterAdapterStatus(twitterService.isTwitterAdapterRunning());
        return status;
    }
}