blob: 8aa0e892abc3f4a4103708948ea6382e3e5a49df (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
package org.onap.vid.utils;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.onap.vid.exceptions.GenericUncheckedException;
import org.onap.portalsdk.core.domain.FusionObject;
import java.util.HashMap;
import java.util.function.Function;
public class DaoUtils {
//all credit for this wonderful method go to is9613
public static<T> T tryWithSessionAndTransaction(SessionFactory sessionFactory, Function<Session, T> update) {
// opens a session and transactions, executes the input query.
// gracefully close session and transaction once error occurres.
Session session = null;
Transaction tx = null;
try {
session = sessionFactory.openSession();
tx = session.beginTransaction();
T res = update.apply(session);
tx.commit();
return res;
} catch (RuntimeException e) {
try {
if (tx != null) {
tx.rollback();
}
} catch (RuntimeException e2) {
// e2 is ingnored; we would like to know the
// original failure reason, not only the reason
// for rollback's failure
throw new GenericUncheckedException("Failed rolling back transaction", e);
}
throw new GenericUncheckedException("Rolled back transaction", e);
} finally {
if (session != null) {
session.close();
}
}
}
public static HashMap<String, Object> getPropsMap() {
HashMap<String, Object> props = new HashMap<>();
props.put(FusionObject.Parameters.PARAM_USERID, 0);
return props;
}
}
|