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

com.foreach.across.modules.entity.autosuggest.AutoSuggestDataEndpoint Maven / Gradle / Ivy

There is a newer version: 6.0.0
Show newest version
/*
 * Copyright 2014 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
 *
 * 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 com.foreach.across.modules.entity.autosuggest;

import lombok.*;
import org.springframework.web.util.UriComponentsBuilder;

import java.util.Map;
import java.util.Optional;
import java.util.UUID;
import java.util.concurrent.ConcurrentHashMap;

/**
 * Registry for attaching a {@link AutoSuggestDataSet} to a particular endpoint.
 * This usually makes the dataset callable over a remote API.
 *
 * @author Arne Vandamme
 * @see AutoSuggestDataController
 * @since 3.0.0
 */
public final class AutoSuggestDataEndpoint
{
//	private final String baseUrl;// = "@adminWeb:/api/entityModule/auto-suggest?dataset={{dataset}}&query={{query}}&controlName={{controlName}}";

	private final UriComponentsBuilder urlBuilder;
	private final Map dataSetMap = new ConcurrentHashMap<>();

	public AutoSuggestDataEndpoint( String baseUrl ) {
		urlBuilder = UriComponentsBuilder.fromUriString( baseUrl )
		                                 .queryParam( "query", "{{query}}" )
		                                 .queryParam( "controlName", "{{controlName}}" );
	}

	/**
	 * Attach a dataset to this endpoint. This will assign a random unique name to this dataset,
	 * and make it available on the controller attached to this endpoint.
	 *
	 * @param dataSet to attach
	 * @return attached dataset context
	 */
	public MappedDataSet registerDataSet( AutoSuggestDataSet dataSet ) {
		return registerDataSet( UUID.randomUUID().toString(), dataSet );
	}

	/**
	 * Attach a dataset with a specific id to this endpoint. Will replace any previously registered
	 * dataset for that endpoint.
	 *
	 * @param id      of the dataset
	 * @param dataSet to attach
	 * @return attached dataset context
	 */
	public MappedDataSet registerDataSet( @NonNull String id, @NonNull AutoSuggestDataSet dataSet ) {
		val mapped = new MappedDataSet( id, dataSet );
		dataSetMap.put( mapped.getId(), mapped );
		return mapped;
	}

	/**
	 * Remove the dataset with that id.
	 *
	 * @param id of the dataset
	 * @return the underlying dataset that has been removed
	 */
	public AutoSuggestDataSet removeDataSet( String id ) {
		return Optional.ofNullable( dataSetMap.remove( id ) ).map( MappedDataSet::getDataSet ).orElse( null );
	}

	/**
	 * Get the dataset with that id.
	 *
	 * @param dataSetId id of the dataset
	 * @return dataset of {@code null} if not found
	 */
	public MappedDataSet getDataSet( String dataSetId ) {
		return dataSetMap.get( dataSetId );
	}

	/**
	 * Create the suggestions url components for a named dataset.
	 * Usually the resulting url should not be encoded as it contains {@code {{XX}}} parameters.
	 *
	 * @param dataSetId id of the dataset
	 * @return url
	 */
	public UriComponentsBuilder suggestionsUriComponents( String dataSetId ) {
		return urlBuilder.cloneBuilder().path( "/query" ).queryParam( "dataset", dataSetId );
	}

	/**
	 * Create the prefetch url components for a named dataset.
	 * Usually the resulting url should not be encoded as it contains {@code {{XX}}} parameters.
	 *
	 * @param dataSetId id of the dataset
	 * @return url
	 */
	public UriComponentsBuilder prefetchUriComponents( String dataSetId ) {
		return urlBuilder.cloneBuilder().path( "/prefetch" ).queryParam( "dataset", dataSetId );
	}

	/**
	 * Wraps a regular {@link AutoSuggestDataSet} with endpoint identification data.
	 */
	@Getter
	@EqualsAndHashCode
	@RequiredArgsConstructor(access = AccessLevel.PRIVATE)
	public class MappedDataSet
	{
		private final String id;
		private final AutoSuggestDataSet dataSet;

		public String suggestionsUrl() {
			return suggestionsUriComponents().build( false ).toUriString();
		}

		public UriComponentsBuilder suggestionsUriComponents() {
			return AutoSuggestDataEndpoint.this.suggestionsUriComponents( id );
		}

		public String prefetchUrl() {
			return prefetchUriComponents().build( false ).toUriString();
		}

		public UriComponentsBuilder prefetchUriComponents() {
			return AutoSuggestDataEndpoint.this.prefetchUriComponents( id );
		}
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy