org.tinymediamanager.scraper.kodi.KodiMovieMetadataProvider Maven / Gradle / Ivy
/*
* Copyright 2012 - 2015 Manuel Laggner
*
* Licensed under the Apache 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://www.apache.org/licenses/LICENSE-2.0
*
* 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.tinymediamanager.scraper.kodi;
import java.util.List;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.tinymediamanager.scraper.mediaprovider.IMovieMetadataProvider;
import org.tinymediamanager.scraper.MediaMetadata;
import org.tinymediamanager.scraper.MediaScrapeOptions;
import org.tinymediamanager.scraper.MediaSearchOptions;
import org.tinymediamanager.scraper.MediaSearchResult;
import org.w3c.dom.Document;
/**
* This is the real Kodi meta data provider for movies
*
* @author Manuel Laggner
*/
public class KodiMovieMetadataProvider extends AbstractKodiMetadataProvider implements IMovieMetadataProvider {
private static final Logger LOGGER = LoggerFactory.getLogger(KodiMovieMetadataProvider.class);
public KodiMovieMetadataProvider(KodiScraper scraper) {
super(scraper);
}
@Override
public MediaMetadata getMetadata(MediaScrapeOptions options) throws Exception {
LOGGER.debug("Kodi: getMetadata(): " + options);
if (options.getResult() == null || !providerInfo.getId().equals(options.getResult().getProviderId())) {
throw new Exception("scraping with Kodi scrapers only with a prior result possible");
}
return _getMetadata(options);
}
@Override
public List search(MediaSearchOptions options) throws Exception {
return _search(options);
}
@Override
protected void processXmlContent(String xmlDetails, MediaMetadata md, MediaSearchResult result) throws Exception {
if (xmlDetails == null || StringUtils.isEmpty(xmlDetails)) {
LOGGER.warn("Cannot process empty Xml Contents.");
return;
}
LOGGER.trace("******* BEGIN XML ***********");
LOGGER.trace(xmlDetails);
LOGGER.trace("******* END XML ***********");
Document xml = parseXmlString(xmlDetails);
addMetadata(md, xml.getDocumentElement());
}
}