示例#1
0
 public void Write(IDimse dimse)
 {
     lock (this) {
         pcid = dimse.PresentationContextId();
         String tsUID = fsm.GetAcceptedTransferSyntaxUID(pcid);
         if (tsUID == null) {
             throw new SystemException();
         }
         (dimse).TransferSyntaxUniqueId = tsUID;
         fsm.FireWrite(dimse);
         if (pDataTF == null) {
             pDataTF = new PDataTF(fsm.WriteMaxLength);
         }
         pDataTF.OpenPDV(pcid, cmd = true);
         Stream outs = new PDataTFOutputStream(this);
         IDicomCommand c = dimse.DicomCommand;
         try {
             c.Write(outs);
         }
         finally {
             outs.Close();
         }
         if (c.HasDataset()) {
             pDataTF.OpenPDV(pcid, cmd = false);
             outs = new PDataTFOutputStream(this);
             try {
                 dimse.WriteTo(outs, tsUID);
             }
             finally {
                 outs.Close();
             }
         }
         FlushPDataTF();
     }
 }
示例#2
0
 public void Write(IDimse dimse)
 {
     NDC.Push(name);
     try {
         msgID = Math.Max(dimse.DicomCommand.MessageID, msgID);
         writer.Write(dimse);
     }
     finally {
         NDC.Pop();
     }
 }
示例#3
0
 public virtual void Received(Association src, IDimse dimse)
 {
     a.Received(src, dimse);
     b.Received(src, dimse);
 }
示例#4
0
 public virtual void Write(Association src, IDimse dimse)
 {
     a.Write(src, dimse);
     b.Write(src, dimse);
 }
 protected override void DoCEcho(ActiveAssociation assoc, IDimse request, IDicomCommand rspCmd)
 {
     rspCmd.PutUS(Tags.Status, Success);
 }
 // Private -------------------------------------------------------
 private void DoMultiRsp(ActiveAssociation assoc, IDimse request, IDicomCommand rspCmd, IMultiDimseRsp mdr)
 {
     try {
         assoc.AddCancelListener(rspCmd.MessageIDToBeingRespondedTo, mdr.CancelListener);
         do {
             DataSet rspData = mdr.Next(assoc, request, rspCmd);
             IDimse rsp = _associationFactory.NewDimse(request.PresentationContextId(), rspCmd, rspData);
             assoc.Association.Write(rsp);
             DoAfterRsp(assoc, rsp);
         } while (rspCmd.IsPending());
     }
     finally {
         mdr.Release();
     }
 }
 protected virtual DataSet DoNSet(ActiveAssociation assoc, IDimse request, IDicomCommand rspCmd)
 {
     request.ReadDataset(); // read out DataSet, if any
     throw defEx;
 }
 protected virtual void DoCStore(ActiveAssociation activeAssociation, IDimse request, IDicomCommand responseCommand)
 {
     request.ReadDataset(); // read out DataSet, if any
     throw defEx;
 }
 protected virtual void DoCEcho(ActiveAssociation assoc, IDimse request, IDicomCommand rspCmd)
 {
     //      request.getDataset(); // read out DataSet
     throw defEx;
 }
示例#10
0
 protected virtual void DoAfterRsp(ActiveAssociation assoc, IDimse rsp)
 {
 }
示例#11
0
 public virtual void NSet(ActiveAssociation assoc, IDimse request)
 {
     IDicomCommand requestCmd = request.DicomCommand;
     IDicomCommand rspCmd = _dcmObjectFactory.NewCommand();
     rspCmd.InitNSetRSP(requestCmd.MessageID, requestCmd.RequestedSOPClassUniqueId, requestCmd.RequestedSOPInstanceUniqueId, Success);
     DataSet rspData = null;
     try {
         rspData = DoNSet(assoc, request, rspCmd);
     }
     catch (DcmServiceException e) {
         e.WriteTo(rspCmd);
     }
     IDimse rsp = _associationFactory.NewDimse(request.PresentationContextId(), rspCmd, rspData);
     assoc.Association.Write(rsp);
     DoAfterRsp(assoc, rsp);
 }
示例#12
0
 public virtual void CMove(ActiveAssociation assoc, IDimse request)
 {
     IDicomCommand requestCmd = request.DicomCommand;
     IDicomCommand rspCmd = _dcmObjectFactory.NewCommand();
     rspCmd.InitCMoveRSP(requestCmd.MessageID, requestCmd.AffectedSOPClassUniqueId, Pending);
     try {
         DoMultiRsp(assoc, request, rspCmd, DoCMove(assoc, request, rspCmd));
     }
     catch (DcmServiceException e) {
         e.WriteTo(rspCmd);
         IDimse rsp = _associationFactory.NewDimse(request.PresentationContextId(), rspCmd);
         assoc.Association.Write(rsp);
         DoAfterRsp(assoc, rsp);
     }
 }
示例#13
0
 public virtual void CEcho(ActiveAssociation assoc, IDimse request)
 {
     IDicomCommand requestCmd = request.DicomCommand;
     IDicomCommand rspCmd = _dcmObjectFactory.NewCommand();
     rspCmd.InitCEchoRSP(requestCmd.MessageID, requestCmd.AffectedSOPClassUniqueId, Success);
     try {
         DoCEcho(assoc, request, rspCmd);
     }
     catch (DcmServiceException e) {
         Logger.Error(e);
         e.WriteTo(rspCmd);
     }
     IDimse rsp = _associationFactory.NewDimse(request.PresentationContextId(), rspCmd);
     assoc.Association.Write(rsp);
     DoAfterRsp(assoc, rsp);
 }
示例#14
0
 internal void FireWrite(IDimse dimse)
 {
     if (Logger.IsInfoEnabled) {
         Logger.Info("sending " + dimse);
     }
     if (assocListener != null) {
         assocListener.Write(assoc, dimse);
     }
 }
示例#15
0
 protected override void DoCStore(ActiveAssociation activeAssociation, IDimse request, IDicomCommand responseCommand)
 {
     IDicomCommand requestCommand = request.DicomCommand;
     Stream inputStream = request.DataAsStream;
     try {
         String instanceUniqueId = requestCommand.AffectedSOPInstanceUniqueId;
         String classUniqueId = requestCommand.AffectedSOPClassUniqueId;
         DcmDecodeParam decParam = DcmDecodeParam.ValueOf(request.TransferSyntaxUniqueId);
         DataSet dataSet = _dcmObjectFactory.NewDataset();
         DcmParser parser = parserFactory.NewDcmParser(inputStream);
         parser.DcmHandler = dataSet.DcmHandler;
         parser.ParseDataset(decParam, Tags.PixelData);
         dataSet.FileMetaInfo = _dcmObjectFactory.NewFileMetaInfo(classUniqueId, instanceUniqueId, request.TransferSyntaxUniqueId);
         FileInfo file = ToFile(dataSet);
         StoreToFile(parser, dataSet, file, (DcmEncodeParam) decParam);
         responseCommand.PutUS(Tags.Status, SUCCESS);
     }
     catch (Exception e) {
         Logger.Error(e.Message, e);
         throw new DcmServiceException(PROCESSING_FAILURE, e);
     }
     finally {
         inputStream.Close();
     }
 }
示例#16
0
 public override void CFind(ActiveAssociation assoc, IDimse request)
 {
     base.CFind(assoc, request);
 }