All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.ingogriebsch.spring.hateoas.siren.SirenEntityRelProvider Maven / Gradle / Ivy

Go to download

A library implementing Siren as a custom Spring HATEOAS hypermedia type. Siren is a hypermedia specification for representing entities.

The newest version!
/*-
 * Copyright 2019-2020 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 de.ingogriebsch.spring.hateoas.siren;

import static com.google.common.collect.Lists.newArrayList;
import static org.springframework.hateoas.IanaLinkRelations.ITEM;

import java.util.List;

import lombok.NonNull;
import org.springframework.hateoas.IanaLinkRelations;
import org.springframework.hateoas.LinkRelation;
import org.springframework.hateoas.RepresentationModel;
import org.springframework.lang.Nullable;

/**
 * SPI to provide information about the relationship of a Siren entity to it's parent.
 *
 * @author Ingo Griebsch
 * @since 1.0.0
 * @see Siren Entity Rel
 */
public interface SirenEntityRelProvider {

    /**
     * The default instance that can be used if no specific implementation of this interface is necessary.
     */
    SirenEntityRelProvider DEFAULT_INSTANCE = new SirenEntityRelProvider() {
    };

    /**
     * Returns the {@link IanaLinkRelations relations} explaining the relationship between the model and it's parent.
     * 

* The default implementation returns the {@link IanaLinkRelations#ITEM item} relation if the model is a child object. * * @param model the {@link RepresentationModel} that is transfered into a Siren entity. Is never {@literal null}. * @param parent the parent {@link RepresentationModel} of the {@literal model}. Can be {@literal null}. * @return the {@link IanaLinkRelations relations} explaining the relationship between the model and it's parent. */ default List get(@NonNull RepresentationModel model, @Nullable RepresentationModel parent) { return parent != null ? newArrayList(ITEM) : newArrayList(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy