001/*
002 * Copyright (c) 2010-2024 Mark Allen, Norbert Bartels.
003 *
004 * Permission is hereby granted, free of charge, to any person obtaining a copy
005 * of this software and associated documentation files (the "Software"), to deal
006 * in the Software without restriction, including without limitation the rights
007 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
008 * copies of the Software, and to permit persons to whom the Software is
009 * furnished to do so, subject to the following conditions:
010 *
011 * The above copyright notice and this permission notice shall be included in
012 * all copies or substantial portions of the Software.
013 *
014 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
015 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
016 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
017 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
018 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
019 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
020 * THE SOFTWARE.
021 */
022package com.restfb.batch;
023
024import com.restfb.Facebook;
025import com.restfb.util.ReflectionUtils;
026
027/**
028 * Represents an HTTP header name/value pair used by {@link BatchRequest} and {@link BatchResponse}.
029 * 
030 * @author <a href="http://restfb.com">Mark Allen</a>
031 * @since 1.6.5
032 */
033public class BatchHeader {
034  @Facebook
035  private String name;
036
037  @Facebook
038  private String value;
039
040  /**
041   * "Magic" no-argument constructor so we can reflectively make instances of this class with DefaultJsonMapper, but
042   * normal client code cannot.
043   */
044  protected BatchHeader() {
045    // nothing here
046  }
047
048  /**
049   * Creates a {@code BatchHeader} with the given name/value pair.
050   * 
051   * @param name
052   *          The name of the header.
053   * @param value
054   *          The value of the header.
055   */
056  public BatchHeader(String name, String value) {
057    this.name = name;
058    this.value = value;
059  }
060
061  @Override
062  public int hashCode() {
063    return ReflectionUtils.hashCode(this);
064  }
065
066  @Override
067  public boolean equals(Object that) {
068    return ReflectionUtils.equals(this, that);
069  }
070
071  @Override
072  public String toString() {
073    return ReflectionUtils.toString(this);
074  }
075
076  /**
077   * The name of the HTTP header.
078   * 
079   * @return The name of the HTTP header.
080   */
081  public String getName() {
082    return name;
083  }
084
085  /**
086   * The value of the HTTP header.
087   * 
088   * @return The value of the HTTP header.
089   */
090  public String getValue() {
091    return value;
092  }
093}