001/*
002 *  Copyright 2018 Anyware Services
003 *
004 *  Licensed under the Apache License, Version 2.0 (the "License");
005 *  you may not use this file except in compliance with the License.
006 *  You may obtain a copy of the License at
007 *
008 *      http://www.apache.org/licenses/LICENSE-2.0
009 *
010 *  Unless required by applicable law or agreed to in writing, software
011 *  distributed under the License is distributed on an "AS IS" BASIS,
012 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 *  See the License for the specific language governing permissions and
014 *  limitations under the License.
015 */
016package org.ametys.odf.catalog;
017
018import java.util.Map;
019
020import org.ametys.cms.repository.Content;
021import org.ametys.odf.course.Course;
022import org.ametys.odf.coursepart.CoursePart;
023import org.ametys.runtime.plugin.component.AbstractLogEnabled;
024
025/**
026 * Copy updater to update the course holder on a {@link CoursePart}.
027 */
028public class CoursePartHolderUpdater extends AbstractLogEnabled implements CopyCatalogUpdater
029{
030    @Override
031    public void updateContents(String initialCatalogName, String newCatalogName, Map<Content, Content> copiedContents, Content targetParentContent)
032    {
033        for (Content copiedContent : copiedContents.values())
034        {
035            if (copiedContent instanceof CoursePart copiedCoursePart)
036            {
037                Course courseHolder = copiedCoursePart.getCourseHolder();
038                if (courseHolder == null)
039                {
040                    getLogger().warn("The course part '{}' of the catalog '{}' haven't any course holder.", copiedCoursePart.getTitle(), copiedCoursePart.getCatalog());
041                }
042                else
043                {
044                    String courseHolderId = courseHolder.getId();
045                    Content copiedCourseHolder = copiedContents.entrySet()
046                                                               .stream()
047                                                               .filter(entry -> courseHolderId.equals(entry.getKey().getId()))
048                                                               .findFirst()
049                                                               .map(Map.Entry::getValue)
050                                                               .orElse(null);
051                    if (copiedCourseHolder == null)
052                    {
053                        getLogger().warn("The course part '{}' of the catalog '{}' can't get the corresponding course holder with the identifier '{}'.", copiedCoursePart.getTitle(), copiedCoursePart.getCatalog(), courseHolder.getId());
054                    }
055                    else
056                    {
057                        copiedCoursePart.setValue(CoursePart.COURSE_HOLDER, copiedCourseHolder);
058                        copiedCoursePart.saveChanges();
059                    }
060                }
061            }
062        }
063    }
064}