X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=citadel%2Fmodules%2Fblog%2Fserv_blog.c;h=98bc938d3c6113b53e2e13ff9035daee10e9ce74;hb=882ff5a53c3b4e440520a073cf07dc60b2671876;hp=6997a057e48548fd2597b7691900ce616318d4dd;hpb=27b40a8300ed2bedb2d10765eeea9616a3968345;p=citadel.git diff --git a/citadel/modules/blog/serv_blog.c b/citadel/modules/blog/serv_blog.c index 6997a057e..98bc938d3 100644 --- a/citadel/modules/blog/serv_blog.c +++ b/citadel/modules/blog/serv_blog.c @@ -1,11 +1,11 @@ /* * Support for blog rooms * - * Copyright (c) 1999-2010 by the citadel.org team + * Copyright (c) 1999-2011 by the citadel.org team * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 3 of the License, or + * This program is open source software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as published + * by the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, @@ -15,7 +15,7 @@ * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include "sysdep.h" @@ -28,18 +28,7 @@ #include #include #include - -#if TIME_WITH_SYS_TIME -# include -# include -#else -# if HAVE_SYS_TIME_H -# include -# else -# include -# endif -#endif - +#include #include #include #include @@ -59,10 +48,10 @@ #include "ctdl_module.h" /* - * sd sdhfksdjhkjsdfhk jsdhfkjsdfhkjsd hkfjhsdkjfhsdkjfhksdjfhsd + * Pre-save hook for saving a message in a blog room. + * (Do we want to only do this for top-level messages?) */ -int blog_upload_beforesave(struct CtdlMessage *msg) { - char buf[SIZ]; +int blog_upload_beforesave(struct CtdlMessage *msg, struct recptypes *recp) { /* Only run this hook for blog rooms */ if (CC->room.QRdefaultview != VIEW_BLOG) { @@ -72,12 +61,18 @@ int blog_upload_beforesave(struct CtdlMessage *msg) { /* * If the message doesn't have an EUID, give it one. */ - if (msg->cm_fields['E'] != NULL) + if (CM_IsEmpty(msg, eExclusiveID)) { - generate_uuid(buf); - msg->cm_fields['E'] = strdup(buf); + char uuid[SIZ]; + generate_uuid(uuid); + CM_SetField(msg, eExclusiveID, uuid, strlen(uuid)); } + /* + * We also want to define a maximum length, whether we generated it or not. + */ + CM_CutFieldAt(msg, eExclusiveID, BLOG_EUIDBUF_SIZE - 1); + /* Now allow the save to complete. */ return(0); }