/* * This file is part of Bitsquare. * * Bitsquare is free software: you can redistribute it and/or modify it * under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or (at * your option) any later version. * * Bitsquare is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public * License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Bitsquare. If not, see <http://www.gnu.org/licenses/>. */ package io.bitsquare.trade.protocol.availability.tasks; import io.bitsquare.common.taskrunner.Task; import io.bitsquare.common.taskrunner.TaskRunner; import io.bitsquare.trade.offer.Offer; import io.bitsquare.trade.protocol.availability.AvailabilityResult; import io.bitsquare.trade.protocol.availability.OfferAvailabilityModel; import io.bitsquare.trade.protocol.availability.messages.OfferAvailabilityResponse; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class ProcessOfferAvailabilityResponse extends Task<OfferAvailabilityModel> { private static final Logger log = LoggerFactory.getLogger(ProcessOfferAvailabilityResponse.class); public ProcessOfferAvailabilityResponse(TaskRunner taskHandler, OfferAvailabilityModel model) { super(taskHandler, model); } @Override protected void run() { try { runInterceptHook(); OfferAvailabilityResponse offerAvailabilityResponse = model.getMessage(); if (model.offer.getState() != Offer.State.REMOVED) { // TODO: isAvailable is kept for backward compatibility. Can be removed once everyone is on v0.4.9 if (offerAvailabilityResponse.isAvailable || offerAvailabilityResponse.availabilityResult == AvailabilityResult.AVAILABLE) { model.offer.setState(Offer.State.AVAILABLE); } else { model.offer.setState(Offer.State.NOT_AVAILABLE); failed("Take offer attempt rejected because of: " + offerAvailabilityResponse.availabilityResult); } } complete(); } catch (Throwable t) { model.offer.setErrorMessage("An error occurred.\n" + "Error message:\n" + t.getMessage()); failed(t); } } }