Subversion Repositories XServices

Rev

Rev 198 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 198 Rev 199
1
package net.brutex.xservices.ws.rs;
1
package net.brutex.xservices.ws.rs;
2
 
2
 
3
import java.net.URL;
3
import java.net.URL;
4
import java.util.GregorianCalendar;
4
import java.util.GregorianCalendar;
5
import java.util.List;
5
import java.util.List;
6
 
6
 
7
import javax.ws.rs.core.GenericEntity;
7
import javax.ws.rs.core.GenericEntity;
8
import javax.ws.rs.core.HttpHeaders;
8
import javax.ws.rs.core.HttpHeaders;
9
import javax.ws.rs.core.Response;
9
import javax.ws.rs.core.Response;
-
 
10
 
10
 
11
import lombok.extern.slf4j.Slf4j;
11
import org.apache.commons.configuration2.PropertiesConfiguration;
12
import org.apache.commons.configuration2.PropertiesConfiguration;
12
import org.apache.commons.configuration2.builder.fluent.Configurations;
13
import org.apache.commons.configuration2.builder.fluent.Configurations;
13
import org.apache.commons.configuration2.ex.ConfigurationException;
14
import org.apache.commons.configuration2.ex.ConfigurationException;
14
import org.apache.commons.jcs.JCS;
15
import org.apache.commons.jcs.JCS;
15
import org.apache.commons.jcs.access.exception.CacheException;
16
import org.apache.commons.jcs.access.exception.CacheException;
16
import org.apache.logging.log4j.LogManager;
-
 
17
import org.apache.logging.log4j.Logger;
-
 
18
 
17
 
19
import net.brutex.mgmt.api.xml.Customer;
18
import net.brutex.mgmt.api.xml.Customer;
20
import net.brutex.mgmt.api.xml.DateFilter;
19
import net.brutex.mgmt.api.xml.DateFilter;
21
import net.brutex.mgmt.api.xml.Query;
20
import net.brutex.mgmt.api.xml.Query;
22
import net.brutex.mgmt.api.xml.Query.BOOL;
21
import net.brutex.mgmt.api.xml.Query.BOOL;
23
import net.brutex.mgmt.api.xml.StringEntity;
22
import net.brutex.mgmt.api.xml.StringEntity;
24
import net.brutex.mgmt.openair.OpenAirRestConnection;
23
import net.brutex.mgmt.openair.OpenAirRestConnection;
-
 
24
 
25
 
25
@Slf4j
26
public class OpenAirInfoServiceImpl implements OpenAirInfoService {
26
public class OpenAirInfoServiceImpl implements OpenAirInfoService {
27
	
-
 
28
	static final Logger logger = LogManager.getLogger();
27
 
29
 
28
 
30
	@Override
29
	@Override
31
	public Response getCompanies(HttpHeaders paramHttpHeaders, String search) {
30
	public Response getCompanies(HttpHeaders paramHttpHeaders, String search) {
32
		OpenAirRestConnection con = getOpenAirConnection();
31
		OpenAirRestConnection con = getOpenAirConnection();
33
		Query query = new Query(Customer.class);
32
		Query query = new Query(Customer.class);
34
		
33
		
35
		query.addQuery("Address_Country", new StringEntity(search), BOOL.AND);
34
		query.addQuery("Address_Country", new StringEntity(search), BOOL.AND);
36
		query.addQuery("active", new StringEntity("1"), BOOL.AND);
35
		query.addQuery("active", new StringEntity("1"), BOOL.AND);
37
		DateFilter datefilter = new DateFilter("updated");
36
		DateFilter datefilter = new DateFilter("updated");
38
		GregorianCalendar date = new GregorianCalendar();
37
		GregorianCalendar date = new GregorianCalendar();
39
 
38
 
40
		date.add(GregorianCalendar.MINUTE, -5);
39
		date.add(GregorianCalendar.MINUTE, -5);
41
		datefilter.setStartdate(date);
40
		datefilter.setStartdate(date);
42
		
41
		
43
		query.addFilter(datefilter);
42
		query.addFilter(datefilter);
44
		//query.addQuery("CustomerAccountCode", new StringEntity(search), BOOL.OR);
43
		//query.addQuery("CustomerAccountCode", new StringEntity(search), BOOL.OR);
45
		List<Customer> resultlist = (List<Customer>) con.getEntitiesByQuery(query);
44
		List<Customer> resultlist = (List<Customer>) con.getEntitiesByQuery(query);
46
		GenericEntity generic = new GenericEntity<List<Customer>>(resultlist) {};
45
		GenericEntity generic = new GenericEntity<List<Customer>>(resultlist) {};
47
		Response response = Response.ok(generic).build();
46
		Response response = Response.ok(generic).build();
48
		return response;
47
		return response;
49
	}
48
	}
50
	
49
	
51
	
50
	
52
	
51
	
53
	private OpenAirRestConnection getOpenAirConnection() {
52
	private OpenAirRestConnection getOpenAirConnection() {
54
 
53
 
55
		/*
54
		/*
56
		 * get details from configuration file
55
		 * get details from configuration file
57
		 */
56
		 */
58
		Configurations configs = new Configurations();
57
		Configurations configs = new Configurations();
59
		final PropertiesConfiguration props;
58
		final PropertiesConfiguration props;
60
		try {
59
		try {
61
			final String config = "../openair.properties";
60
			final String config = "../openair.properties";
62
			logger.debug("Loading Open Air connection details from " + this.getClass().getClassLoader().getResource("/")
61
			log.debug("Loading Open Air connection details from '{}'.", this.getClass().getClassLoader().getResource("/")
63
					+ config);
62
					+ config);
64
 
63
 
65
			final URL configloc = this.getClass().getClassLoader().getResource(config);
64
			final URL configloc = this.getClass().getClassLoader().getResource(config);
66
 
65
 
67
			props = configs.properties(configloc);
66
			props = configs.properties(configloc);
68
			
67
			
69
			final String user = props.getString("user");
68
			final String user = props.getString("user");
70
			final String password = props.getString("password");
69
			final String password = props.getString("password");
71
			final String company = props.getString("company");
70
			final String company = props.getString("company");
72
			final String apikey = props.getString("apikey", "9x7G49ENkLCJ81i9XZJU");
71
			final String apikey = props.getString("apikey", "9x7G49ENkLCJ81i9XZJU");
73
			final String namespace = props.getString("namespace");
72
			final String namespace = props.getString("namespace");
74
 
73
 
75
			final OpenAirRestConnection con;
74
			final OpenAirRestConnection con;
76
 
75
 
77
			con = new OpenAirRestConnection(JCS.getInstance("FileCache"), company, user, password);
76
			con = new OpenAirRestConnection(JCS.getInstance("FileCache"), company, user, password);
78
			return con;
77
			return con;
79
		} catch (CacheException e) {
-
 
80
			logger.error(e);
-
 
81
			e.printStackTrace();
-
 
82
		} catch (ConfigurationException e) {
78
		} catch (CacheException | ConfigurationException e) {
83
			logger.error(e);
79
			log.error(e.getMessage());
84
			e.printStackTrace();
80
			e.printStackTrace();
85
		} finally {
81
		} finally {
86
 
82
 
87
		}
83
		}
88
		return null;
84
		return null;
89
	}
85
	}
90
 
86
 
91
}
87
}