diff options
| author | Jesse Morgan <jesse@jesterpm.net> | 2014-02-01 11:03:52 -0800 | 
|---|---|---|
| committer | Jesse Morgan <jesse@jesterpm.net> | 2014-02-01 11:03:52 -0800 | 
| commit | 331f4939eb8f983b5b85663d7549e604ef485b9a (patch) | |
| tree | cd42a240496d134fb125a08c4bc6735728984f8f /src/com/p4square/grow/backend | |
| parent | b9c4dd721747c48f557f05f342a62cdfaec360f1 (diff) | |
Fixing regression computing required videos.
After refactoring users were required to watch all videos regardless of
their assessment score.
Also enabling strict video ordering and adding the option magicskip to
watch out of order.
Diffstat (limited to 'src/com/p4square/grow/backend')
| -rw-r--r-- | src/com/p4square/grow/backend/resources/TrainingRecordResource.java | 49 | 
1 files changed, 48 insertions, 1 deletions
| diff --git a/src/com/p4square/grow/backend/resources/TrainingRecordResource.java b/src/com/p4square/grow/backend/resources/TrainingRecordResource.java index 388f2fa..2a0d3f0 100644 --- a/src/com/p4square/grow/backend/resources/TrainingRecordResource.java +++ b/src/com/p4square/grow/backend/resources/TrainingRecordResource.java @@ -29,6 +29,7 @@ import org.apache.log4j.Logger;  import com.p4square.grow.backend.GrowBackend;  import com.p4square.grow.backend.db.CassandraDatabase; +import com.p4square.grow.model.Chapter;  import com.p4square.grow.model.Playlist;  import com.p4square.grow.model.VideoRecord;  import com.p4square.grow.model.TrainingRecord; @@ -45,7 +46,7 @@ import com.p4square.grow.model.Score;   */  public class TrainingRecordResource extends ServerResource {      private static final Logger LOG = Logger.getLogger(TrainingRecordResource.class); -    private static final ObjectMapper MAPPER = new ObjectMapper(); +    private static final ObjectMapper MAPPER = JsonEncodedProvider.MAPPER;      static enum RequestType {          SUMMARY, VIDEO @@ -76,6 +77,7 @@ public class TrainingRecordResource extends ServerResource {              if (mRecord == null) {                  mRecord = new TrainingRecord();                  mRecord.setPlaylist(defaultPlaylist); +                skipAssessedChapters(mUserId, mRecord);              } else {                  // Merge the playlist with the most recent version.                  mRecord.getPlaylist().merge(defaultPlaylist); @@ -174,4 +176,49 @@ public class TrainingRecordResource extends ServerResource {          return null;      } +    /** +     * Mark the chapters which the user assessed through as not required. +     */ +    private void skipAssessedChapters(String userId, TrainingRecord record) { +        // Get the user's score. +        double assessedScore; + +        try { +            String summaryString = mDb.getKey("assessments", userId, "summary"); +            if (summaryString == null) { +                LOG.warn("Asked to create training record for unassessed user " + userId); +                return; +            } +            Map<?,?> summary = MAPPER.readValue(summaryString, Map.class); +            assessedScore = (Double) summary.get("score"); + +        } catch (IOException e) { +            LOG.error("IOException fetching assessment record for " + userId, e); +            return; +        } + +        // Mark the correct videos as not required. +        Playlist playlist = record.getPlaylist(); + +        for (Map.Entry<String, Chapter> entry : playlist.getChaptersMap().entrySet()) { +            String chapterId = entry.getKey(); +            Chapter chapter = entry.getValue(); +            boolean required; + +            if ("introduction".equals(chapter)) { +                // Introduction chapter is always required +                required = true; + +            } else { +                // Chapter required if the floor of the score is <= the chapter's numeric value. +                required = Math.floor(assessedScore) <= Score.numericScore(chapterId); +            } + +            if (!required) { +                for (VideoRecord video : chapter.getVideos().values()) { +                    video.setRequired(required); +                } +            } +        } +    }  } | 
