com.github.triceo.robozonky.api.remote.entities.BaseEntity Maven / Gradle / Ivy
/*
* Copyright 2017 Lukáš Petrovický
*
* 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.github.triceo.robozonky.api.remote.entities;
import com.fasterxml.jackson.annotation.JsonAnyGetter;
import com.fasterxml.jackson.annotation.JsonAnySetter;
import com.github.triceo.robozonky.internal.api.ToStringBuilder;
import org.slf4j.LoggerFactory;
/**
* All JAX-RS entity classes in this package should extend this class in order to be able to gracefully handle
* missing JSON properties. This happens occasionally when Zonky deploys a new version of the API and the app was not
* yet updated with the changes.
*/
abstract class BaseEntity {
@JsonAnyGetter
void handleUnknownGetter(final String key) {
LoggerFactory.getLogger(this.getClass()).debug("Trying to get value of unknown property '{}'."
+ " Indicates an unexpected API change, RoboZonky may misbehave.", key);
}
@JsonAnySetter
void handleUnknownSetter(final String key, final Object value) {
LoggerFactory.getLogger(this.getClass()).debug("Trying to set value '{}' to an unknown property '{}'."
+ " Indicates an unexpected API change, RoboZonky may misbehave.", value, key);
}
@Override
public final String toString() {
return new ToStringBuilder(this).toString();
}
}