Package com.google.api.ads.adwords.awreporting.model.util

Source Code of com.google.api.ads.adwords.awreporting.model.util.DateUtil

// Copyright 2012 Google Inc. 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.
// 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 com.google.api.ads.adwords.awreporting.model.util;

import org.joda.time.DateTime;
import org.joda.time.DateTimeZone;
import org.joda.time.LocalDateTime;
import org.joda.time.format.DateTimeFormat;
import org.joda.time.format.DateTimeFormatter;

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

/**
* Utility class for Dates.
*
* This class handles the basic formats that the AdWords API provide.
*
* @author jtoledo@google.com (Julian Toledo)
* @author gustavomoreira (Gustavo Moreira)
*/
public final class DateUtil {

  protected static final String DATE_FORMAT_REPORT = "yyyyMMdd";
  private static final DateTimeFormatter dfYearMonthDayNoDash =
      DateTimeFormat.forPattern(DATE_FORMAT_REPORT);

  private static final String DATE_FORMAT_SHORT = "yyyy-MM-dd";
  private static final DateTimeFormatter dfYearMonthDay =
      DateTimeFormat.forPattern(DATE_FORMAT_SHORT);

  private static final String DATE_FORMAT_SHORT_WITHOUTDAY = "yyyy-MM";
  private static final DateTimeFormatter dfYearMonth =
      DateTimeFormat.forPattern(DATE_FORMAT_SHORT_WITHOUTDAY);

  private static final List<DateTimeFormatter> formatters = new ArrayList<DateTimeFormatter>();
  static {
    formatters.add(dfYearMonthDay);
    formatters.add(dfYearMonth);
    formatters.add(dfYearMonthDayNoDash);
  }

  /**
   * Private constructor.
   */
  private DateUtil() {}

  /**
   * Formats the date to the format: yyyyMMdd
   *
   * @param date the date as a {@code java.util.Date}
   * @return the {@code String} that represents the date as yyyyMMdd
   */
  public static String formatYearMonthDayNoDash(Date date) {
    return DateUtil.formatYearMonthDayNoDash(new DateTime(date));
  }

  /**
   * Formats the date to the format: yyyyMMdd
   *
   * @param date the date as a {@code org.jodatime.DateTime}
   * @return the {@code String} that represents the date as yyyyMMdd
   */
  public static String formatYearMonthDayNoDash(DateTime date) {
    return DateUtil.dfYearMonthDayNoDash.print(date);
  }

  /**
   * Formats the date to the ISO format without the time zone information: yyyy-MM-dd
   *
   * @param date the date as a {@code java.util.Date}
   * @return the {@code String} that represents the date in ISO format
   */
  public static String formatYearMonthDay(Date date) {
    return DateUtil.formatYearMonthDay(new DateTime(date));
  }

  /**
   * Formats the date to the ISO format without the time zone information: yyyy-MM-dd
   *
   * @param date the date as a {@code org.jodatime.DateTime}
   * @return the {@code String} that represents the date in ISO format
   */
  public static String formatYearMonthDay(DateTime date) {
    return DateUtil.dfYearMonthDay.print(date);
  }

  /**
   * Formats the date to the ISO format without the time zone and day information: yyyy-MM
   *
   * @param date the date as a {@code java.util.Date}
   * @return the {@code String} that represents the date in ISO format
   */
  public static String formatYearMonth(Date date) {
    return DateUtil.formatYearMonth(new DateTime(date));
  }

  /**
   * Formats the date to the ISO format without the time zone and day information: yyyy-MM
   *
   * @param date the date as a {@code org.jodatime.DateTime}
   * @return the {@code String} that represents the date in ISO format
   */
  public static String formatYearMonth(DateTime date) {
    return DateUtil.dfYearMonth.print(date);
  }

  /**
   * Attempts to parse the given {@code String} to a {@code DateTime} using one of the known
   * formatters.
   *
   * The attempt falls back to all the formatters, and if the format is unknown, {@code null} is
   * returned.
   *
   * @param timestamp the time stamp in {@code String} format.
   * @return the parsed {@code DateTime}, or {@code null} in case that the format is unknown.
   */
  public static DateTime parseDateTime(String timestamp) {

    if (timestamp != null) {

      for (DateTimeFormatter formatter : DateUtil.formatters) {
        try {
          LocalDateTime localDateTime = formatter.parseLocalDateTime(timestamp);
          return localDateTime.plusHours(12).toDateTime(DateTimeZone.UTC);

        } catch (IllegalArgumentException e) {
          // silently skips to the next formatter
        }
      }
    }
    return null;
  }

  /**
   * Create a {@code DateTime} that represents the last month, and formats it to the yyyy-MM format.
   *
   * @return the date formatted
   */
  public static String lastMonthInYearMonthFormat() {

    DateTime lastMonth = new DateTime().minusMonths(1);
    return DateUtil.dfYearMonth.print(lastMonth);
  }
}
TOP

Related Classes of com.google.api.ads.adwords.awreporting.model.util.DateUtil

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.