All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sakaiproject.tool.assessment.services.AutoSubmitAssessmentsJob Maven / Gradle / Ivy

/**
 * Copyright (c) 2005-2017 The Apereo Foundation
 *
 * Licensed under the Educational Community 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://opensource.org/licenses/ecl2
 *
 * 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.sakaiproject.tool.assessment.services;

import java.util.Date;

import lombok.Setter;
import lombok.extern.slf4j.Slf4j;

import org.apache.commons.lang3.StringUtils;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.quartz.StatefulJob;

import org.sakaiproject.authz.api.AuthzGroupService;
import org.sakaiproject.component.api.ServerConfigurationService;
import org.sakaiproject.event.api.EventTrackingService;
import org.sakaiproject.event.api.UsageSession;
import org.sakaiproject.event.api.UsageSessionService;
import org.sakaiproject.samigo.api.SamigoETSProvider;
import org.sakaiproject.samigo.util.SamigoConstants;
import org.sakaiproject.tool.api.Session;
import org.sakaiproject.tool.api.SessionManager;

@Slf4j
public class AutoSubmitAssessmentsJob implements StatefulJob {

	@Setter private AuthzGroupService authzGroupService;
	@Setter private EventTrackingService eventTrackingService;
	@Setter private SamigoETSProvider samigoETSProvider;
	@Setter private ServerConfigurationService serverConfigurationService;
	@Setter private SessionManager sessionManager;
	@Setter private UsageSessionService usageSessionService;

	/*
	 * Quartz job to check for assessment attempts that should be autosubmitted
	 * 
	 * @see org.quartz.Job#execute(org.quartz.JobExecutionContext)
	 */
	public void execute(JobExecutionContext jobInfo) throws JobExecutionException {
		loginToSakai("admin");

		String jobName = jobInfo.getJobDetail().getKey().getName();
		String triggerName = jobInfo.getTrigger().getKey().getName();
 		Date requestedFire = jobInfo.getScheduledFireTime();
		Date actualfire = jobInfo.getFireTime();

		StringBuffer whoAmI = new StringBuffer("AutoSubmitAssessmentsJob $");
		whoAmI.append(" Job: ");
		whoAmI.append(jobName);
		whoAmI.append(" Trigger: ");
		whoAmI.append(triggerName);
		
		if (requestedFire != null) {
			whoAmI.append(" Fire scheduled: ");
			whoAmI.append(requestedFire.toString());
		}
		
		if (actualfire != null) {
			whoAmI.append(" Fire actual: ");
			whoAmI.append(actualfire.toString());
		}
		
		eventTrackingService.post(eventTrackingService.newEvent(SamigoConstants.EVENT_AUTO_SUBMIT_JOB, safeEventLength(whoAmI.toString()), true));

		log.info("Start Job: {}", whoAmI);
		
		GradingService gradingService = new GradingService();
		int failures = gradingService.autoSubmitAssessments();
		
		if (failures > 0)
		{
			samigoETSProvider.notifyAutoSubmitFailures(failures);
		}
		
		log.info("End Job: {} ({} failures)", whoAmI, failures);
		
		logoutFromSakai();
	}
	
	/**
	 * 

Login to sakai and start a user session. This users is intended * to be one of the 'hard wired' users; admin, postmaster, or synchrobot.

*

( this list of users can be extended; add the user via UI, update * the sakai_users table so their EID matches ID, add them to the * admin realm, restart )

* @param whoAs - who to log in as */ protected void loginToSakai(String whoAs) { String serverName = serverConfigurationService.getServerName(); log.debug("AutoSubmitAssessmentsJob Logging into Sakai on {} as {}", serverName, whoAs); UsageSession session = usageSessionService.startSession(whoAs, serverName, "AutoSubmitAssessmentsJob"); if (session == null) { eventTrackingService.post(eventTrackingService.newEvent(SamigoConstants.EVENT_AUTO_SUBMIT_JOB_ERROR, whoAs + " unable to log into " + serverName, true)); return; } Session sakaiSession = sessionManager.getCurrentSession(); sakaiSession.setUserId(whoAs); sakaiSession.setUserEid(whoAs); // update the user's externally provided realm definitions authzGroupService.refreshUser(whoAs); // post the login events eventTrackingService.post(eventTrackingService.newEvent(UsageSessionService.EVENT_LOGIN, whoAs + " running " + serverName, true)); } protected void logoutFromSakai() { log.debug("Logging out of Sakai on {}", serverConfigurationService.getServerName()); eventTrackingService.post(eventTrackingService.newEvent(UsageSessionService.EVENT_LOGOUT, null, true)); usageSessionService.logout(); // safe to logout? what if other jobs are running? } /** * Sometimes when logging to the sakai_events table it's possible to be logging * with a string you don't know the size of. (An exception message is a good * example) * * This method is supplied to keep the lengh of logged messages w/in the limits * of the sakai_event.ref column size. * * The sakai_event.ref column size is currently 256 * * @param target * @return */ static final public String safeEventLength(final String target) { return StringUtils.abbreviate(target, 255); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy