/** * 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 org.apache.aurora.scheduler.storage.db; import java.util.Objects; import java.util.Set; import com.google.common.base.Optional; import com.google.common.base.Predicate; import com.google.common.collect.Iterables; import com.google.inject.Inject; import org.apache.aurora.scheduler.storage.AttributeStore; import org.apache.aurora.scheduler.storage.entities.IAttribute; import org.apache.aurora.scheduler.storage.entities.IHostAttributes; import static com.google.common.base.Preconditions.checkArgument; import static org.apache.aurora.common.base.MorePreconditions.checkNotBlank; import static org.apache.aurora.common.inject.TimedInterceptor.Timed; /** * Attribute store backed by a relational database. */ class DbAttributeStore implements AttributeStore.Mutable { private final AttributeMapper mapper; @Inject DbAttributeStore(AttributeMapper mapper) { this.mapper = Objects.requireNonNull(mapper); } @Override public void deleteHostAttributes() { mapper.truncate(); } @Timed("attribute_store_save") @Override public boolean saveHostAttributes(IHostAttributes hostAttributes) { checkNotBlank(hostAttributes.getHost()); checkArgument(hostAttributes.isSetMode()); if (Iterables.any(hostAttributes.getAttributes(), EMPTY_VALUES)) { throw new IllegalArgumentException( "Host attributes contains empty values: " + hostAttributes); } Optional<IHostAttributes> existing = getHostAttributes(hostAttributes.getHost()); if (existing.equals(Optional.of(hostAttributes))) { return false; } else if (existing.isPresent()) { mapper.updateHostModeAndSlaveId( hostAttributes.getHost(), hostAttributes.getMode(), hostAttributes.getSlaveId()); } else { mapper.insert(hostAttributes); } mapper.deleteAttributeValues(hostAttributes.getHost()); if (!hostAttributes.getAttributes().isEmpty()) { mapper.insertAttributeValues(hostAttributes); } return true; } private static final Predicate<IAttribute> EMPTY_VALUES = attribute -> attribute.getValues().isEmpty(); @Timed("attribute_store_fetch_one") @Override public Optional<IHostAttributes> getHostAttributes(String host) { return Optional.fromNullable(mapper.select(host)).transform(IHostAttributes::build); } @Timed("attribute_store_fetch_all") @Override public Set<IHostAttributes> getHostAttributes() { return IHostAttributes.setFromBuilders(mapper.selectAll()); } }