/* This file is part of JFLICKS. JFLICKS is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. JFLICKS is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with JFLICKS. If not, see <http://www.gnu.org/licenses/>. */ package org.jflicks.ui.view.vm; import java.io.File; import org.jflicks.job.AbstractJob; import org.jflicks.job.JobEvent; import org.jflicks.nms.NMS; import org.jflicks.nms.NMSConstants; import org.jflicks.nms.Video; import org.jflicks.util.LogUtil; import org.jflicks.util.Util; /** * A job that saves images to an NMS. * * @author Doug Barnum * @version 1.0 */ public class SaveVideoJob extends AbstractJob { private NMS nms; private Video video; /** * Constructor with our required argument. * * @param nms A NMS to access. * @param video The video to save. */ public SaveVideoJob(NMS nms, Video video) { setNMS(nms); setVideo(video); } private NMS getNMS() { return (nms); } private void setNMS(NMS n) { nms = n; } private Video getVideo() { return (video); } private void setVideo(Video v) { video = v; } /** * {@inheritDoc} */ public void start() { setTerminate(false); } /** * {@inheritDoc} */ public void run() { NMS n = getNMS(); Video v = getVideo(); if ((n != null) && (v != null)) { // First save the images... String id = null; if (v.isTV()) { id = v.getSubcategory(); if (id != null) { id = id.replaceAll(" ", "_"); id = id.replaceAll("'", "_"); id = id.replaceAll(",", "_"); } } else { id = v.getId(); } String url = v.getBannerURL(); LogUtil.log(LogUtil.DEBUG, "url: " + url); LogUtil.log(LogUtil.DEBUG, "id: " + id); if ((url != null) && (id != null)) { if (url.indexOf(id) == -1) { LogUtil.log(LogUtil.DEBUG, "url <" + url + ">"); if (url.startsWith("file")) { String path = url.substring(5); File fbuf = new File(path); byte[] b = Util.read(fbuf); if (b != null) { n.save(NMSConstants.BANNER_IMAGE_TYPE, b, id); } } else { n.save(NMSConstants.BANNER_IMAGE_TYPE, url, id); } } else { n.save(NMSConstants.BANNER_IMAGE_TYPE, url, id); } } url = v.getFanartURL(); LogUtil.log(LogUtil.DEBUG, "url: " + url); LogUtil.log(LogUtil.DEBUG, "id: " + id); if ((url != null) && (id != null)) { if (url.indexOf(id) == -1) { LogUtil.log(LogUtil.DEBUG, "url <" + url + ">"); if (url.startsWith("file")) { String path = url.substring(5); File fbuf = new File(path); LogUtil.log(LogUtil.DEBUG, "fbuf: " + fbuf); byte[] b = Util.read(fbuf); LogUtil.log(LogUtil.DEBUG, "b: " + b); if (b != null) { n.save(NMSConstants.FANART_IMAGE_TYPE, b, id); } } else { n.save(NMSConstants.FANART_IMAGE_TYPE, url, id); } } else { n.save(NMSConstants.FANART_IMAGE_TYPE, url, id); } } url = v.getPosterURL(); LogUtil.log(LogUtil.DEBUG, "url: " + url); LogUtil.log(LogUtil.DEBUG, "id: " + id); if ((url != null) && (id != null)) { if (url.indexOf(id) == -1) { LogUtil.log(LogUtil.DEBUG, "url <" + url + ">"); if (url.startsWith("file")) { String path = url.substring(5); File fbuf = new File(path); byte[] b = Util.read(fbuf); LogUtil.log(LogUtil.DEBUG, "b: " + b); if (b != null) { n.save(NMSConstants.POSTER_IMAGE_TYPE, b, id); } } else { n.save(NMSConstants.POSTER_IMAGE_TYPE, url, id); } } else { n.save(NMSConstants.POSTER_IMAGE_TYPE, url, id); } } // Now save the Video... n.save(v); Video updated = n.getVideoById(v.getId()); v.setBannerURL(updated.getBannerURL()); v.setFanartURL(updated.getFanartURL()); v.setPosterURL(updated.getPosterURL()); } fireJobEvent(JobEvent.COMPLETE); } /** * {@inheritDoc} */ public void stop() { setTerminate(true); } }