| /** |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| package org.apache.fineract.infrastructure.jobs.service; |
| |
| import java.time.LocalDate; |
| import java.util.HashMap; |
| import lombok.RequiredArgsConstructor; |
| import lombok.extern.slf4j.Slf4j; |
| import org.apache.fineract.infrastructure.businessdate.domain.BusinessDateType; |
| import org.apache.fineract.infrastructure.businessdate.service.BusinessDateReadPlatformService; |
| import org.apache.fineract.infrastructure.core.service.ThreadLocalContextUtil; |
| import org.quartz.JobExecutionContext; |
| import org.quartz.JobKey; |
| import org.quartz.Trigger; |
| import org.springframework.stereotype.Component; |
| import org.springframework.transaction.annotation.Isolation; |
| import org.springframework.transaction.annotation.Transactional; |
| |
| @Slf4j |
| @Component |
| @RequiredArgsConstructor |
| public class SchedulerVetoer { |
| |
| private final SchedularWritePlatformService schedularService; |
| private final BusinessDateReadPlatformService businessDateReadPlatformService; |
| |
| @Transactional(isolation = Isolation.READ_COMMITTED) |
| public boolean veto(Trigger trigger, JobExecutionContext context) { |
| String tenantIdentifier = trigger.getJobDataMap().getString(SchedulerServiceConstants.TENANT_IDENTIFIER); |
| HashMap<BusinessDateType, LocalDate> businessDates = businessDateReadPlatformService.getBusinessDates(); |
| ThreadLocalContextUtil.setBusinessDates(businessDates); |
| JobKey key = trigger.getJobKey(); |
| String jobKey = key.getName() + SchedulerServiceConstants.JOB_KEY_SEPERATOR + key.getGroup(); |
| String triggerType = SchedulerServiceConstants.TRIGGER_TYPE_CRON; |
| if (context.getMergedJobDataMap().containsKey(SchedulerServiceConstants.TRIGGER_TYPE_REFERENCE)) { |
| triggerType = context.getMergedJobDataMap().getString(SchedulerServiceConstants.TRIGGER_TYPE_REFERENCE); |
| } |
| boolean vetoJob = schedularService.processJobDetailForExecution(jobKey, triggerType); |
| if (vetoJob) { |
| log.warn( |
| "vetoJobExecution() WILL veto the execution (returning vetoJob == true; the job's execute method will NOT be called); tenant={}, jobKey={}, triggerType={}, trigger={}, context={}", |
| tenantIdentifier, jobKey, triggerType, trigger, context); |
| } |
| return vetoJob; |
| } |
| } |