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 static java.util.Collections.unmodifiableList; 025 026import java.util.ArrayList; 027import java.util.List; 028 029import com.restfb.Facebook; 030import com.restfb.util.ReflectionUtils; 031 032/** 033 * Encapsulates a discrete part of an entire 034 * <a href="https://developers.facebook.com/docs/reference/api/batch/" target="_blank">Facebook Batch API</a> response. 035 * 036 * @author <a href="http://restfb.com">Mark Allen</a> 037 * @since 1.6.5 038 */ 039public class BatchResponse { 040 @Facebook 041 private Integer code; 042 043 @Facebook 044 private String body; 045 046 @Facebook 047 private List<BatchHeader> headers = new ArrayList<>(); 048 049 /** 050 * "Magic" no-argument constructor so we can reflectively make instances of this class with DefaultJsonMapper, but 051 * normal client code cannot. 052 */ 053 protected BatchResponse() {} 054 055 /** 056 * Creates a batch response with the given HTTP response status code, headers, and JSON body. 057 * 058 * @param code 059 * HTTP status code. 060 * @param headers 061 * HTTP headers. 062 * @param body 063 * JSON body. 064 */ 065 public BatchResponse(Integer code, List<BatchHeader> headers, String body) { 066 this.code = code; 067 this.body = body; 068 069 if (headers != null) { 070 this.headers.addAll(headers); 071 } 072 } 073 074 @Override 075 public int hashCode() { 076 return ReflectionUtils.hashCode(this); 077 } 078 079 @Override 080 public boolean equals(Object that) { 081 return ReflectionUtils.equals(this, that); 082 } 083 084 @Override 085 public String toString() { 086 return ReflectionUtils.toString(this); 087 } 088 089 /** 090 * The HTTP status code for this response. 091 * 092 * @return The HTTP status code for this response. 093 */ 094 public Integer getCode() { 095 return code; 096 } 097 098 /** 099 * The HTTP response body JSON. 100 * 101 * @return The HTTP response body JSON. 102 */ 103 public String getBody() { 104 return body; 105 } 106 107 /** 108 * The HTTP response headers. 109 * 110 * @return The HTTP response headers. 111 */ 112 public List<BatchHeader> getHeaders() { 113 return unmodifiableList(headers); 114 } 115}