001/* 002 * SPDX-License-Identifier: Apache-2.0 003 * 004 * Copyright 2024-2026 The Enola <https://enola.dev> Authors 005 * 006 * Licensed under the Apache License, Version 2.0 (the "License"); 007 * you may not use this file except in compliance with the License. 008 * You may obtain a copy of the License at 009 * 010 * https://www.apache.org/licenses/LICENSE-2.0 011 * 012 * Unless required by applicable law or agreed to in writing, software 013 * distributed under the License is distributed on an "AS IS" BASIS, 014 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 015 * See the License for the specific language governing permissions and 016 * limitations under the License. 017 */ 018package dev.enola.thing.repo; 019 020import com.google.common.collect.ImmutableList; 021import com.google.errorprone.annotations.ThreadSafe; 022 023import dev.enola.data.MemoryRepositoryRW; 024import dev.enola.data.Repository; 025import dev.enola.data.Store; 026import dev.enola.data.Trigger; 027import dev.enola.thing.Thing; 028 029/** 030 * ThingMemoryRepositoryRW is an in-memory read & write (i.e. both a {@link Store} and a {@link 031 * Repository} of {@link Thing}s. 032 * 033 * <p>{@link ThingMemoryRepositoryROBuilder} is one of possibly several other alternatives for this. 034 */ 035@ThreadSafe 036public class ThingMemoryRepositoryRW extends MemoryRepositoryRW<Thing> 037 implements ThingRepositoryStore { 038 039 public ThingMemoryRepositoryRW(ImmutableList<Trigger<? extends Thing>> triggers) { 040 super(triggers); 041 } 042 043 public ThingMemoryRepositoryRW() { 044 this(ImmutableList.of()); 045 } 046 047 @Override 048 protected String getIRI(Thing value) { 049 return value.iri(); 050 } 051}