Skip to content

Commit 358e9e5

Browse files
committed
#80 extract collection callback, improve implementation
1 parent 4529aa7 commit 358e9e5

File tree

3 files changed

+69
-10
lines changed

3 files changed

+69
-10
lines changed

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

Lines changed: 8 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -36,6 +36,8 @@
3636
import com.arangodb.springframework.core.util.ArangoExceptionTranslator;
3737
import com.arangodb.springframework.core.util.MetadataUtils;
3838
import com.fasterxml.jackson.databind.node.JsonNodeFactory;
39+
import org.slf4j.Logger;
40+
import org.slf4j.LoggerFactory;
3941
import org.springframework.beans.BeansException;
4042
import org.springframework.context.ApplicationContext;
4143
import org.springframework.context.ApplicationContextAware;
@@ -74,6 +76,7 @@ public class ArangoTemplate implements ArangoOperations, CollectionCallback, App
7476
private static final String REPSERT_QUERY = "LET doc = @doc " + REPSERT_QUERY_BODY;
7577
private static final String REPSERT_MANY_QUERY = "FOR doc IN @docs " + REPSERT_QUERY_BODY;
7678

79+
private static final Logger LOGGER = LoggerFactory.getLogger(ArangoTemplate.class);
7780
private static final SpelExpressionParser PARSER = new SpelExpressionParser();
7881

7982
private volatile ArangoDBVersion version;
@@ -163,9 +166,11 @@ private ArangoCollection _collection(final String name, final ArangoPersistentEn
163166
final ArangoCollection collection = value.getCollection();
164167
if (persistentEntity != null && !entities.contains(entityClass)) {
165168
value.addEntityClass(entityClass);
166-
if (!transactional) {
167-
ensureCollectionIndexes(collection(collection), persistentEntity);
168-
}
169+
if (transactional) {
170+
LOGGER.debug("Not ensuring any indexes of collection {} for {} during transaction", collection.name(), entityClass);
171+
} else {
172+
ensureCollectionIndexes(collection(collection), persistentEntity);
173+
}
169174
}
170175
return collection;
171176
}
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
@@ -30,7 +30,6 @@
3030
import com.arangodb.entity.UserEntity;
3131
import com.arangodb.model.UserCreateOptions;
3232
import com.arangodb.model.UserUpdateOptions;
33-
import com.arangodb.springframework.core.CollectionOperations;
3433
import com.arangodb.springframework.core.UserOperations;
3534

3635
/**
@@ -39,12 +38,6 @@
3938
*/
4039
public class DefaultUserOperation implements UserOperations {
4140

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

0 commit comments

Comments
 (0)