Skip to content

Commit 5baea19

Browse files
committed
#80 extract collection callback, improve implementation
1 parent 7ce1ca7 commit 5baea19

File tree

3 files changed

+75
-11
lines changed

3 files changed

+75
-11
lines changed

src/main/java/com/arangodb/springframework/core/template/ArangoTemplate.java

Lines changed: 14 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -45,11 +45,12 @@
4545
import com.arangodb.springframework.core.mapping.event.ArangoMappingEvent;
4646
import com.arangodb.springframework.core.mapping.event.BeforeDeleteEvent;
4747
import com.arangodb.springframework.core.mapping.event.BeforeSaveEvent;
48-
import com.arangodb.springframework.core.template.DefaultUserOperation.CollectionCallback;
4948
import com.arangodb.springframework.core.util.ArangoExceptionTranslator;
5049
import com.arangodb.springframework.core.util.MetadataUtils;
5150
import com.arangodb.util.MapBuilder;
5251
import com.arangodb.velocypack.VPackSlice;
52+
import org.slf4j.Logger;
53+
import org.slf4j.LoggerFactory;
5354
import org.springframework.beans.BeansException;
5455
import org.springframework.context.ApplicationContext;
5556
import org.springframework.context.ApplicationContextAware;
@@ -73,6 +74,7 @@
7374
import java.util.Collections;
7475
import java.util.HashMap;
7576
import java.util.Iterator;
77+
import java.util.List;
7678
import java.util.Map;
7779
import java.util.Map.Entry;
7880
import java.util.Optional;
@@ -98,6 +100,7 @@ public class ArangoTemplate implements ArangoOperations, CollectionCallback, App
98100
private static final String REPSERT_QUERY = "LET doc = @doc " + REPSERT_QUERY_BODY;
99101
private static final String REPSERT_MANY_QUERY = "FOR doc IN @docs " + REPSERT_QUERY_BODY;
100102

103+
private static final Logger LOGGER = LoggerFactory.getLogger(ArangoTemplate.class);
101104
private static final SpelExpressionParser PARSER = new SpelExpressionParser();
102105

103106
private volatile ArangoDBVersion version;
@@ -191,7 +194,9 @@ private ArangoCollection _collection(final String name, final ArangoPersistentEn
191194
final ArangoCollection collection = value.getCollection();
192195
if (persistentEntity != null && !entities.contains(entityClass)) {
193196
value.addEntityClass(entityClass);
194-
if (!transactional) {
197+
if (transactional) {
198+
LOGGER.debug("Not ensuring any indexes of collection {} for {} during transaction", collection.name(), entityClass);
199+
} else {
195200
ensureCollectionIndexes(collection(collection), persistentEntity);
196201
}
197202
}
@@ -761,8 +766,13 @@ public CollectionOperations collection(final Class<?> entityClass) throws DataAc
761766
}
762767

763768
@Override
764-
public CollectionOperations collection(String name) {
765-
return ArangoOperations.super.collection(name);
769+
public CollectionOperations collection(String name) throws DataAccessException {
770+
List<ArangoCollection> collections = converter.getMappingContext().getPersistentEntities().stream()
771+
.filter(persistentEntity -> name.equals(persistentEntity.getCollection()))
772+
.map(persistentEntity -> _collection(name, persistentEntity, persistentEntity.getCollectionOptions(), false))
773+
.collect(Collectors.toList());
774+
ArangoCollection result = collections.isEmpty() ? _collection(name, null, null, false) : collections.get(0);
775+
return collection(result);
766776
}
767777

768778
@Override
Lines changed: 61 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,61 @@
1+
/*
2+
* DISCLAIMER
3+
*
4+
* Copyright 2017 ArangoDB GmbH, Cologne, Germany
5+
*
6+
* Licensed under the Apache License, Version 2.0 (the "License");
7+
* you may not use this file except in compliance with the License.
8+
* You may obtain a copy of the License at
9+
*
10+
* http://www.apache.org/licenses/LICENSE-2.0
11+
*
12+
* Unless required by applicable law or agreed to in writing, software
13+
* distributed under the License is distributed on an "AS IS" BASIS,
14+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15+
* See the License for the specific language governing permissions and
16+
* limitations under the License.
17+
*
18+
* Copyright holder is ArangoDB GmbH, Cologne, Germany
19+
*/
20+
21+
package com.arangodb.springframework.core.template;
22+
23+
import com.arangodb.springframework.core.ArangoOperations;
24+
import com.arangodb.springframework.core.CollectionOperations;
25+
import org.springframework.dao.DataAccessException;
26+
27+
/**
28+
* Internal interface to handle collection operations.
29+
* Typically implemented by same class as {@link com.arangodb.springframework.core.ArangoOperations}.
30+
*/
31+
public interface CollectionCallback {
32+
33+
/**
34+
* @see com.arangodb.springframework.core.ArangoOperations#collection(Class)
35+
*/
36+
CollectionOperations collection(Class<?> type) throws DataAccessException;
37+
38+
/**
39+
* @see com.arangodb.springframework.core.ArangoOperations#collection(String)
40+
*/
41+
CollectionOperations collection(String name) throws DataAccessException;
42+
43+
44+
static CollectionCallback fromOperations(ArangoOperations operations) {
45+
if (operations instanceof CollectionCallback) {
46+
return (CollectionCallback) operations;
47+
}
48+
return new CollectionCallback() {
49+
@Override
50+
public CollectionOperations collection(Class<?> type) {
51+
return operations.collection(type);
52+
}
53+
54+
@Override
55+
public CollectionOperations collection(String name) {
56+
return operations.collection(name);
57+
}
58+
};
59+
}
60+
61+
}

src/main/java/com/arangodb/springframework/core/template/DefaultUserOperation.java

Lines changed: 0 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -29,7 +29,6 @@
2929
import com.arangodb.entity.UserEntity;
3030
import com.arangodb.model.UserCreateOptions;
3131
import com.arangodb.model.UserUpdateOptions;
32-
import com.arangodb.springframework.core.CollectionOperations;
3332
import com.arangodb.springframework.core.UserOperations;
3433

3534
/**
@@ -38,12 +37,6 @@
3837
*/
3938
public class DefaultUserOperation implements UserOperations {
4039

41-
public interface CollectionCallback {
42-
CollectionOperations collection(Class<?> type);
43-
44-
CollectionOperations collection(String name);
45-
}
46-
4740
private final ArangoDatabase db;
4841
private final String username;
4942
private final PersistenceExceptionTranslator exceptionTranslator;

0 commit comments

Comments
 (0)