org.dcm4chee.wizard.page.DicomEchoPage.java Source code

Java tutorial

Introduction

Here is the source code for org.dcm4chee.wizard.page.DicomEchoPage.java

Source

/* ***** BEGIN LICENSE BLOCK *****
 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
 *
 * The contents of this file are subject to the Mozilla Public License Version
 * 1.1 (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.mozilla.org/MPL/
 *
 * Software distributed under the License is distributed on an "AS IS" basis,
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
 * for the specific language governing rights and limitations under the
 * License.
 *
 * The Original Code is part of dcm4che, an implementation of DICOM(TM) in
 * Java(TM), hosted at https://github.com/dcm4che.
 *
 * The Initial Developer of the Original Code is
 * Agfa Healthcare.
 * Portions created by the Initial Developer are Copyright (C) 2012
 * the Initial Developer. All Rights Reserved.
 *
 * Contributor(s):
 * See @authors listed below
 *
 * Alternatively, the contents of this file may be used under the terms of
 * either the GNU General Public License Version 2 or later (the "GPL"), or
 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
 * in which case the provisions of the GPL or the LGPL are applicable instead
 * of those above. If you wish to allow use of your version of this file only
 * under the terms of either the GPL or the LGPL, and not to allow others to
 * use your version of this file under the terms of the MPL, indicate your
 * decision by deleting the provisions above and replace them with the notice
 * and other provisions required by the GPL or the LGPL. If you do not delete
 * the provisions above, a recipient may use your version of this file under
 * the terms of any one of the MPL, the GPL or the LGPL.
 *
 * ***** END LICENSE BLOCK ***** */

package org.dcm4chee.wizard.page;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

import org.apache.wicket.AttributeModifier;
import org.apache.wicket.ajax.AjaxRequestTarget;
import org.apache.wicket.ajax.markup.html.form.AjaxFallbackButton;
import org.apache.wicket.extensions.ajax.markup.html.IndicatingAjaxButton;
import org.apache.wicket.extensions.ajax.markup.html.modal.ModalWindow;
import org.apache.wicket.markup.head.CssHeaderItem;
import org.apache.wicket.markup.head.IHeaderResponse;
import org.apache.wicket.markup.html.basic.Label;
import org.apache.wicket.markup.html.form.Form;
import org.apache.wicket.markup.html.form.TextArea;
import org.apache.wicket.model.Model;
import org.apache.wicket.model.ResourceModel;
import org.apache.wicket.request.resource.CssResourceReference;
import org.apache.wicket.request.resource.ResourceReference;
import org.dcm4che3.data.Tag;
import org.dcm4che3.data.UID;
import org.dcm4che3.net.ApplicationEntity;
import org.dcm4che3.net.Association;
import org.dcm4che3.net.DimseRSP;
import org.dcm4che3.net.pdu.AAssociateRQ;
import org.dcm4che3.net.pdu.PresentationContext;
import org.dcm4chee.wizard.common.component.ExtendedForm;
import org.dcm4chee.wizard.common.component.MainWebPage;
import org.dcm4chee.wizard.common.component.secure.SecureSessionCheckPage;
import org.dcm4chee.wizard.tree.ConfigTreeProvider;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * @author Robert David <robert.david@agfa.com>
 */
public class DicomEchoPage extends SecureSessionCheckPage {

    private static final long serialVersionUID = 1L;

    private static Logger log = LoggerFactory.getLogger(DicomEchoPage.class);

    private static final ResourceReference baseCSS = new CssResourceReference(MainWebPage.class, "base-style.css");

    private transient ApplicationEntity sourceAE;
    private transient ApplicationEntity destinationAE;

    private boolean error;
    private Model<String> resultModel;

    final String sourceAET = System.getProperty("org.dcm4chee.wizard.config.aeTitle");

    public DicomEchoPage(final ModalWindow window, ApplicationEntity destinationAE) {
        super();

        this.destinationAE = destinationAE;

        setOutputMarkupId(true);
        final ExtendedForm form = new ExtendedForm("form");
        form.setResourceIdPrefix("dicom.list.applicationEntity.echo.");
        add(form);

        form.add(new Label("sourceAET.label",
                new ResourceModel("dicom.list.applicationEntity.echo.sourceAET.label")));
        form.add(new Label("sourceAET", sourceAET));

        form.add(new Label("destinationAET.label",
                new ResourceModel("dicom.list.applicationEntity.echo.destinationAET.label")));
        form.add(new Label("destinationAET", destinationAE.getAETitle()));

        form.add(new Label("result.label", new ResourceModel("dicom.list.applicationEntity.echo.result.label")));
        form.add(new TextArea<String>("result", (resultModel = new Model<String>())).setEscapeModelStrings(false)
                .add(new AttributeModifier("class", new Model<String>() {

                    private static final long serialVersionUID = 1L;

                    @Override
                    public String getObject() {
                        return error ? "error" : "text";
                    }
                })));

        form.add(new IndicatingAjaxButton("echo",
                new ResourceModel("dicom.list.applicationEntity.echo.echoBtn.text"), form) {

            private static final long serialVersionUID = 1L;

            @Override
            protected void onSubmit(AjaxRequestTarget target, Form<?> form) {
                doEcho();
                target.add(form);
            }

            @Override
            protected void onError(AjaxRequestTarget target, Form<?> form) {
                if (target != null)
                    target.add(form);
            }
        });
        form.add(new AjaxFallbackButton("cancel",
                new ResourceModel("dicom.list.applicationEntity.echo.cancelBtn.text"), form) {

            private static final long serialVersionUID = 1L;

            @Override
            protected void onSubmit(AjaxRequestTarget target, Form<?> form) {
                window.close(target);
            }

            @Override
            protected void onError(AjaxRequestTarget arg0, Form<?> arg1) {
            }
        }.setDefaultFormProcessing(false));

        doEcho();
    }

    @Override
    public void renderHead(IHeaderResponse response) {
        if (DicomEchoPage.baseCSS != null)
            response.render(CssHeaderItem.forReference(DicomEchoPage.baseCSS));
    }

    private void doEcho() {
        ExecutorService executorService = Executors.newSingleThreadExecutor();
        try {
            resultModel.setObject("Fetching Source AE from configuration ...");
            sourceAE = ConfigTreeProvider.get().getApplicationEntity(sourceAET);
            resultModel.setObject(resultModel.getObject() + " OK\n");
            if (sourceAE == null)
                throw new Exception("Could not fetch source AE");
            else {
                resultModel.setObject(resultModel.getObject() + "Connecting to Destination AE ...");
                sourceAE.getDevice().setExecutor(executorService);
                AAssociateRQ request = new AAssociateRQ();
                request.addPresentationContext(new PresentationContext(1, UID.VerificationSOPClass,
                        new String[] { UID.ImplicitVRLittleEndian }));
                Association association = sourceAE.connect(DicomEchoPage.this.destinationAE, request);
                resultModel.setObject(resultModel.getObject() + " OK\nProcessing CECHO request ...");
                DimseRSP response = association.cecho();
                response.next();
                resultModel.setObject(resultModel.getObject() + " OK\nResult is: "
                        + response.getCommand().getInt(Tag.Status, -1) + "\nEcho completed successfully.\n");
                association.release();
            }
        } catch (Exception e) {
            log.error("Error processing echo request", e);
            error = true;
            resultModel.setObject(resultModel.getObject() + "\nERROR: \n" + e.getMessage() + "\n");
        } finally {
            executorService.shutdownNow();
        }
    }
}