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.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
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 Job {
@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