/*
 * Copyright 2002-2018 the original author or authors.
 *
 * 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
 *
 *      https://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 org.springframework.cache.interceptor;

import org.springframework.lang.Nullable;

Class describing a cache 'cacheable' operation.
Author:Costin Leau, Phillip Webb, Marcin Kamionowski
Since:3.1
/** * Class describing a cache 'cacheable' operation. * * @author Costin Leau * @author Phillip Webb * @author Marcin Kamionowski * @since 3.1 */
public class CacheableOperation extends CacheOperation { @Nullable private final String unless; private final boolean sync;
Create a new CacheableOperation instance from the given builder.
Since:4.3
/** * Create a new {@link CacheableOperation} instance from the given builder. * @since 4.3 */
public CacheableOperation(CacheableOperation.Builder b) { super(b); this.unless = b.unless; this.sync = b.sync; } @Nullable public String getUnless() { return this.unless; } public boolean isSync() { return this.sync; }
A builder that can be used to create a CacheableOperation.
Since:4.3
/** * A builder that can be used to create a {@link CacheableOperation}. * @since 4.3 */
public static class Builder extends CacheOperation.Builder { @Nullable private String unless; private boolean sync; public void setUnless(String unless) { this.unless = unless; } public void setSync(boolean sync) { this.sync = sync; } @Override protected StringBuilder getOperationDescription() { StringBuilder sb = super.getOperationDescription(); sb.append(" | unless='"); sb.append(this.unless); sb.append("'"); sb.append(" | sync='"); sb.append(this.sync); sb.append("'"); return sb; } @Override public CacheableOperation build() { return new CacheableOperation(this); } } }