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

com.fleetpin.graphql.database.manager.dynamo.DynamoDbManager Maven / Gradle / Ivy

/*
 * 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.fleetpin.graphql.database.manager.dynamo;

import com.fasterxml.jackson.databind.ObjectMapper;
import com.fleetpin.graphql.database.manager.DatabaseDriver;
import com.fleetpin.graphql.database.manager.DatabaseManager;
import com.google.common.base.Preconditions;
import com.google.common.base.Strings;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.UUID;
import java.util.function.Supplier;
import software.amazon.awssdk.services.dynamodb.DynamoDbAsyncClient;
import software.amazon.awssdk.services.dynamodb.model.AttributeValue;

public final class DynamoDbManager extends DatabaseManager {

	private final ObjectMapper mapper;
	private final Supplier idGenerator;
	private final DynamoDbAsyncClient client;

	private DynamoDbManager(ObjectMapper mapper, Supplier idGenerator, DynamoDbAsyncClient client, DatabaseDriver dynamoDb) {
		super(dynamoDb);
		this.mapper = mapper;
		this.idGenerator = idGenerator;
		this.client = client;
	}

	public static DyanmoDbManagerBuilder builder() {
		return new DyanmoDbManagerBuilder();
	}

	public static class DyanmoDbManagerBuilder {

		private DynamoDbAsyncClient client;
		private ObjectMapper mapper;
		private List tables;
		private Supplier idGenerator;
		private DatabaseDriver database;
		private String historyTable;
		private int batchWriteSize = 25;
		private int maxRetry = 10;
		private boolean globalEnabled = true;
		private boolean hash = false;
		private String classPath = null;

		private String parallelIndex = null;

		public DyanmoDbManagerBuilder dynamoDbAsyncClient(DynamoDbAsyncClient client) {
			this.client = client;
			return this;
		}

		public DyanmoDbManagerBuilder objectMapper(ObjectMapper mapper) {
			this.mapper = mapper;
			return this;
		}

		public DyanmoDbManagerBuilder tables(List tables) {
			this.tables = tables;
			return this;
		}

		public DyanmoDbManagerBuilder tables(String... tables) {
			this.tables = Arrays.asList(tables);
			return this;
		}

		public DyanmoDbManagerBuilder historyTable(String historyTable) {
			this.historyTable = historyTable;
			return this;
		}

		public DyanmoDbManagerBuilder idGenerator(Supplier idGenerator) {
			this.idGenerator = idGenerator;
			return this;
		}

		public DyanmoDbManagerBuilder dynamoDb(final DatabaseDriver database) {
			this.database = database;
			return this;
		}

		public DyanmoDbManagerBuilder batchWriteSize(int batchWriteSize) {
			if (batchWriteSize < 0 || batchWriteSize > 25) {
				throw new RuntimeException("Batch write size must be between 0-25");
			}
			this.batchWriteSize = batchWriteSize;
			return this;
		}

		public DyanmoDbManagerBuilder maxRetry(int maxRetry) {
			this.maxRetry = maxRetry;
			return this;
		}

		public DyanmoDbManagerBuilder global(boolean global) {
			this.globalEnabled = global;
			return this;
		}

		public DyanmoDbManagerBuilder hash(boolean hash) {
			this.hash = hash;
			return this;
		}

		public DyanmoDbManagerBuilder classPath(String classPath) {
			if (!Strings.isNullOrEmpty(classPath)) {
				this.classPath = classPath;
			}
			return this;
		}

		public DyanmoDbManagerBuilder parallelIndex(String parallelIndex) {
			this.parallelIndex = parallelIndex;
			return this;
		}

		public DynamoDbManager build() {
			Preconditions.checkNotNull(tables, "Tables must be set");
			Preconditions.checkArgument(!tables.isEmpty(), "Empty table array");
			Preconditions.checkNotNull(mapper, "Mapper is null");

			if (client == null) {
				client = DynamoDbAsyncClient.create();
			}
			if (idGenerator == null) {
				idGenerator = () -> UUID.randomUUID().toString();
			}

			database =
				Objects.requireNonNullElse(
					database,
					new DynamoDb(mapper, tables, historyTable, client, idGenerator, batchWriteSize, maxRetry, globalEnabled, hash, classPath, parallelIndex)
				);

			return new DynamoDbManager(mapper, idGenerator, client, database);
		}
	}

	public ObjectMapper getMapper() {
		return mapper;
	}

	public String newId() {
		return idGenerator.get();
	}

	public  T convertTo(Map item, Class type) {
		return TableUtil.convertTo(mapper, item, type);
	}

	public  T convertTo(AttributeValue item, Class type) {
		return TableUtil.convertTo(mapper, item, type);
	}

	public AttributeValue toAttributes(Object entity) {
		var entries = TableUtil.toAttributes(mapper, entity);
		return AttributeValue.builder().m(entries).build();
	}

	public DynamoDbAsyncClient getDynamoDbAsyncClient() {
		return client;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy