def on_mModelLookupButton_clicked(self): imd = None try: loader = ModelLoader(self.ui.mDataLineEdit.text()) ili = loader.gen_lookup_ili() qDebug(ili) wpsreq = self._create_wps_request(ili) req = urllib2.Request(url="http://wps.sourcepole.ch/wps?", data=wpsreq, headers={'Content-Type': 'application/xml'}) #TODO: proxy support response = urllib2.urlopen(req) # timeout=int(TIMEOUT) result = response.read() imd = self._parse_wps_response(result) except urllib2.HTTPError, err: qDebug("HTTPError %d" % err.code)
def on_mModelLookupButton_clicked(self): imd = None try: loader = ModelLoader(self.ui.mDataLineEdit.text()) models = loader.detect_models() model_names = map(lambda m: m.name, models) self._log_output("Looking up models: " + ', '.join(model_names)) ili = loader.gen_lookup_ili() qDebug(ili) wpsreq = self._create_wps_request(ili) req = urllib2.Request(url="http://wps.sourcepole.ch/wps?", data=wpsreq, headers={'Content-Type': 'application/xml'}) # TODO: proxy support response = urllib2.urlopen(req) # timeout=int(TIMEOUT) result = response.read() imd = self._parse_wps_response(result) except urllib2.HTTPError, err: qDebug("HTTPError %d" % err.code)
def loadModel(self): imd = None try: loader = ModelLoader(self.ui.mDataLineEdit.text()) models = loader.detect_models() model_names = map(lambda m: m.name, models) self._log_output("Looking up models: " + ', '.join(model_names)) ili = loader.gen_lookup_ili() qDebug(ili) wpsreq = self._create_wps_request(ili) url = self.ui.mIlisMetaUrlLineEdit.text() req = QNetworkRequest(QtCore.QUrl(url)) req.setHeader(QNetworkRequest.ContentTypeHeader, 'application/xml') reply = QgsNetworkAccessManager.instance().post(req, wpsreq) # Wait for reply or timeout loop = QEventLoop() reply.finished.connect(loop.quit) QTimer.singleShot(15000, reply.abort) loop.exec_() if reply.isFinished() and reply.error() == QNetworkReply.NoError: result = reply.readAll() imd = self._parse_wps_response(result) except: qDebug("Exception during IlisModel download") if imd is None: self._show_log_window() QgsMessageLog.logMessage( "Couldn't download Ilismeta model", "Interlis", QgsMessageLog.WARNING) self.ui.mModelLineEdit.setText("") else: fh, imdfn = tempfile.mkstemp(suffix='.imd') os.close(fh) with codecs.open(imdfn, "w", encoding='utf-8') as file: file.write(imd) self.ui.mModelLineEdit.setText(imdfn)
def test_lookup_ili(): loader = ModelLoader("./tests/data/ili/roads23.xtf") assert "IMPORTS RoadsExdm2ben" in loader.gen_lookup_ili()