Skip to content

Commit f0df045

Browse files
committed
#250 extract collection callback, improve implementation
1 parent 25b8270 commit f0df045

File tree

3 files changed

+47
-10
lines changed

3 files changed

+47
-10
lines changed

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

Lines changed: 6 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -45,7 +45,6 @@
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;
@@ -761,8 +760,12 @@ public CollectionOperations collection(final Class<?> entityClass) throws DataAc
761760
}
762761

763762
@Override
764-
public CollectionOperations collection(String name) {
765-
return ArangoOperations.super.collection(name);
763+
public CollectionOperations collection(String name) throws DataAccessException {
764+
ArangoPersistentEntity<?> persistentEntity = converter.getMappingContext().getPersistentEntities().stream()
765+
.filter(e -> name.equals(e.getCollection()))
766+
.findAny()
767+
.orElse(null);
768+
return collection(_collection(name, persistentEntity, persistentEntity == null ? new CollectionCreateOptions() : persistentEntity.getCollectionOptions(), false));
766769
}
767770

768771
@Override
Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,41 @@
1+
package com.arangodb.springframework.core.template;
2+
3+
import com.arangodb.springframework.core.ArangoOperations;
4+
import com.arangodb.springframework.core.CollectionOperations;
5+
import org.springframework.dao.DataAccessException;
6+
7+
/**
8+
* Internal interface to handle collection operations.
9+
* Typically implemented by same class as {@link com.arangodb.springframework.core.ArangoOperations}.
10+
*/
11+
public interface CollectionCallback {
12+
13+
/**
14+
* @see com.arangodb.springframework.core.ArangoOperations#collection(Class)
15+
*/
16+
CollectionOperations collection(Class<?> type) throws DataAccessException;
17+
18+
/**
19+
* @see com.arangodb.springframework.core.ArangoOperations#collection(String)
20+
*/
21+
CollectionOperations collection(String name) throws DataAccessException;
22+
23+
24+
static CollectionCallback fromOperations(ArangoOperations operations) {
25+
if (operations instanceof CollectionCallback) {
26+
return (CollectionCallback) operations;
27+
}
28+
return new CollectionCallback() {
29+
@Override
30+
public CollectionOperations collection(Class<?> type) {
31+
return operations.collection(type);
32+
}
33+
34+
@Override
35+
public CollectionOperations collection(String name) {
36+
return operations.collection(name);
37+
}
38+
};
39+
}
40+
41+
}

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)