+ withValues.put("creator","Anonym");
+
+ // inserting content into database
+ String cid = contentModule.add(withValues);
+ theLog.printDebugInfo("id: "+cid);
+ //insert was not successfull
+ if(cid==null){
+ //How do we know that it was not succesful cause of a
+ //dupe, what if it failed cause of "No space left on device"?
+ //Or is there something I am missing? Wouldn't it be better
+ //to have an explicit dupe check and then insert? I have no
+ //idea what I am talking about. this comment is in case
+ //I forget to explicitely ask. -mh
+ deliver(req, res, mergeData, postingFormDupeTemplate);
+ }
+
+ String[] to_topicsArr = mp.getParameterValues("to_topic");
+
+ if (to_topicsArr != null && to_topicsArr.length > 0) {
+ try{
+ DatabaseContentToTopics.getInstance().setTopics(cid,to_topicsArr);
+ setTopic = true;
+ theLog.printError("setting content_x_topic success");
+ } catch (Exception e) {
+ theLog.printError("setting content_x_topic failed");
+ contentModule.deleteById(cid);
+ throw new ServletModuleException("smod - openindy :: insposting: setting content_x_topic failed: "+e.toString());
+ } //end try
+ } //end if
+
+ // if op contains uploaddata
+ String mediaId=null;
+ int i=1;
+ for(Iterator it = mp.requestList.iterator(); it.hasNext();){
+ MpRequest mpReq = (MpRequest)it.next();
+ String fileName = mpReq.getFilename();
+
+ //get the content-type from what the client browser
+ //sends us. (the "Oreilly method")
+ String contentType = mpReq.getContentType();
+
+ theLog.printError("FROM BROWSER: "+contentType);
+
+ //if the client browser sent us unknown (text/plain is default)
+ //or if we got application/octet-stream, it's possible that
+ //the browser is in error, better check against the file extension
+ if (contentType.equals("text/plain") ||
+ contentType.equals("application/octet-stream")) {
+ /**
+ * This is just a temporary way to get the content-type via
+ * the .extension , we could maybe use a magic method, by looking
+ * at the header (first few bytes) of the file. (like the file(1)
+ * command).
+ * The Oreilly method relies on the content-type that the client
+ * browser sends and that sometimes is application-octet stream with
+ * broken/mis-configured browsers.
+ *
+ * The map file should be Mir/content-types.properties, it's the
+ * default Sun Java file with some additional entries that it did
+ * not have. So if you support a new media type you have to make
+ * sure that it is in this file -mh
+ */
+ contentType = FileUtil.guessContentTypeFromName(fileName);
+ theLog.printError("tYPE: "+contentType);
+ if (contentType==null)
+ contentType = "text/plain"; // rfc1867 says this is the default
+ }
+ HashMap mediaValues = new HashMap();
+
+ theLog.printError("CONTENT TYPE IS: "+contentType);
+
+ if (contentType.equals("text/plain") ||
+ contentType.equals("application/octet-stream")) {
+ System.err.println("IN HERE");
+ throw new ServletModuleUserException("One or more files of unrecognized types");
+ }
+
+ String mediaTitle=(String)withValues.get("media_title"+i);
+ i++;
+
+ if (mediaTitle==null)
+ mediaTitle = (String)withValues.get("title");
+
+ mediaValues.put("title", mediaTitle);
+ mediaValues.put("date", StringUtil.date2webdbDate(new GregorianCalendar()));
+ mediaValues.put("to_publisher", "1"); // op user
+ mediaValues.put("to_media_folder", "7"); // op media_folder
+ mediaValues.put("is_produced", "0");
+ mediaValues.put("is_published","0");
+
+ //the where clause to find the media_type entry
+ //from the content-type.
+ //we use the media type entry to lookup the
+ //media Handler/Storage classes
+ String wc = " mime_type='"+contentType+"'";
+
+ DatabaseMediaType mediaTypeStor = DatabaseMediaType.getInstance();
+ EntityList mediaTypesList = mediaTypeStor.selectByWhereClause(wc);
+
+ String mediaTypeId = null;
+ MirMedia mediaHandler;
+ Database mediaStorage;
+
+ //if we found an entry matching the
+ //content-type int the table.
+ if (mediaTypesList.size() > 0) {
+ //get the class names from the media_type table.
+ mediaTypeId = mediaTypesList.elementAt(0).getId();
+ try {
+ // ############### TODO: merge these and the getURL call into one
+ // getURL helper call that just takes the Entity as a parameter
+ // along with media_type
+ mediaHandler = MediaHelper.getHandler(mediaTypesList.elementAt(0));
+ mediaStorage = MediaHelper.getStorage(mediaTypesList.elementAt(0),
+ "mircoders.storage.Database");
+ } catch (MirMediaException e) {
+ throw new ServletModuleException("getting media handler failed: "
+ +e.toString());
+ }
+
+ mediaValues.put("to_media_type",mediaTypeId);
+
+ //load the classes via reflection
+ String MediaId;
+ Entity mediaEnt = null;
+ try {
+ mediaEnt = (Entity)mediaStorage.getEntityClass().newInstance();
+ mediaEnt.setStorage(mediaStorage);
+ mediaEnt.setValues(mediaValues);
+ mediaId = mediaEnt.insert();
+
+ //save and store the media data/metadata
+ mediaHandler.set(mpReq.getMedia(), mediaEnt,
+ mediaTypesList.elementAt(0));
+
+ //were done with mpReq at this point, dereference it.
+ //as it contains mucho mem. -mh 01.10.2001
+ mpReq=null;
+
+ //we got this far, associate the media to the article
+ theLog.printError("ID"+mediaId);
+ mediaEnt.setValueForProperty("is_published","1");
+ mediaEnt.update();
+ new ProducerMedia().handle(null,null,false,false,mediaId);
+ DatabaseContentToMedia.getInstance().addMedia(cid,mediaId);
+ } catch (Exception e) {
+ theLog.printError("setting media failed: "+e.toString());
+ contentModule.deleteById(cid);
+ throw new ServletModuleException("setting media failed: "+e.toString());
+ }
+
+ } else {
+ contentModule.deleteById(cid);
+ theLog.printDebugInfo("Wrong file type uploaded!: " + fileName);
+ throw new ServletModuleUserException("One or more files of unrecognized types");
+ } // end if-else mediaTypesList.size() > 0
+
+ } //end for Iterator...
+
+ //if we're here all is ok...
+ EntityContent contentEnt = (EntityContent)contentModule.getById(cid);
+ contentEnt.setValueForProperty("is_published","1");
+ contentEnt.update();
+
+ //dereference mp. -mh
+ mp=null;
+
+ // producing openpostinglist
+ new ProducerOpenPosting().handle(null,null,false,false);
+ // producing new page
+ new ProducerContent().handle(null, null, false, false,cid);
+ //if direct op producing startpage
+ if (directOp.equals("yes")) new ProducerStartPage().handle(null,null);
+
+ //produce the topicPages if set
+ //should be more intelligent
+ //if(setTopic==true) new ProducerTopics().handle(null,null);
+
+ // sync the server
+ //should be configureable
+ int exitValue = Helper.rsync();
+ theLog.printDebugInfo("rsync: "+exitValue);
+
+ }
+ catch (IOException e) { throw new ServletModuleException("IOException: "+ e.toString());}
+ catch (StorageObjectException e) { throw new ServletModuleException("StorageObjectException" + e.toString());}
+ catch (ModuleException e) { throw new ServletModuleException("ModuleException"+e.toString());}
+
+ deliver(req, res, mergeData, postingFormDoneTemplate);
+ }