/** * Axelor Business Solutions * * Copyright (C) 2016 Axelor (<http://axelor.com>). * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License, version 3, * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package com.axelor.apps.base.service.template; import java.util.List; import java.util.regex.Matcher; import java.util.regex.Pattern; import javax.persistence.TypedQuery; import com.axelor.apps.base.db.TemplateContextLine; import com.axelor.db.JPA; import com.axelor.db.Model; import com.axelor.meta.db.MetaModel; import com.axelor.meta.db.repo.MetaModelRepository; import com.google.common.base.Strings; import com.axelor.inject.Beans; public class TemplateContextLineService { public Object evaluate(TemplateContextLine line, Model bean) { String query = line.getQuery(); if(Strings.isNullOrEmpty(query)) { return null; } return this.evaluate(query, bean); } public Object evaluate(String query, Model bean) { try { Class<?> klass = this.extractClass(query); StringBuilder sb = new StringBuilder(query); int n = 0, i = sb.indexOf("?"); while (i > -1) { sb.replace(i, i + 1, "?" + (++n)); i = sb.indexOf("?", i + 1); } TypedQuery<?> querie = JPA.em().createQuery(sb.toString(), klass); for (int j = 1; j <= n; j++) { querie.setParameter(n, bean); } List<?> list = querie.getResultList(); if(list != null && !list.isEmpty() && list.size() == 1) { return list.get(0); } else { return list; } } catch(Exception ex) { ex.printStackTrace(); } return null; } private Class<?> extractClass(String query) { Pattern pattern = Pattern.compile("(from|FROM)(\\s*)(.+?)(\\s)"); Matcher matcher = pattern.matcher(query); String klassName = ""; if (matcher.find()) { klassName = matcher.group(3).trim(); } MetaModel model = Beans.get(MetaModelRepository.class).findByName(klassName); try { return Class.forName(model.getFullName()); } catch(Exception ex){ } return null; } }