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 &amp; 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}