/* 
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER
 * Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. 
 * 
 * This file is available and licensed under the following license:
 * 
 * Redistribution and use in source and binary forms, with or without 
 * modification, are permitted provided that the following conditions are met:
 *
 *   * Redistributions of source code must retain the above copyright notice, 
 *     this list of conditions and the following disclaimer.
 *
 *   * Redistributions in binary form must reproduce the above copyright notice,
 *     this list of conditions and the following disclaimer in the documentation
 *     and/or other materials provided with the distribution.
 *
 *   * Neither the name of Sun Microsystems nor the names of its contributors 
 *     may be used to endorse or promote products derived from this software 
 *     without specific prior written permission.
 * 
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

package podcastfeedviewer;
import java.io.InputStream;
import javafx.io.http.HttpRequest;
import javafx.data.pull.*;

/**
 * @author Raghu Nair
 *
 */

public class FeedValidator extends HttpRequest {

    //podcastParser uses to parse the location if it is a valid feed.
    public-init var podcastParser:PodcastParser;

    //Error if any while connecting.
    public var connectError:Boolean = false;

    //Will be set to 1 if Atom feed, 2 Rss Feed -1 if not a feed.
    public var type = -1;

    //If the xml starts with <feed> or <rss> it is a valid feed.
    override var onInput = function(input:InputStream){
        var parser = PullParser {input:input;}
        parser.forward(2);
        var e = parser.event;
        Main.log("Event e - {e}");
        if ( e.qname.name == "rss" ) {
            type = PodcastParser.RSS;
        }else if (e.qname.name == "feed" ){
            type = PodcastParser.ATOM;
        }        
        input.close();
        podcastParser.type = type;
    }

    override var onException = function(exception: java.lang.Exception) {
            exception.printStackTrace();
            println("Error - {exception}");
            connectError = true;
    }

    override var onResponseCode = function(responseCode:Integer) {
        if (responseCode != 200) {
            println("failed, response: {responseCode} {responseMessage}");
            connectError = true;
        }
    }


}