+ /* First, figure out the boundary string. We do this even when we generated the
+ * boundary string in the above code, just to be safe and consistent.
+ */
+ strcpy(boundary, "");
+
+ ptr = history_msg->cm_fields['M'];
+ do {
+ ptr = memreadline(ptr, buf, sizeof buf);
+ if (*ptr != 0) {
+ striplt(buf);
+ if (!IsEmptyStr(buf) && (!strncasecmp(buf, "Content-type:", 13))) {
+ if (
+ (bmstrcasestr(buf, "multipart") != NULL)
+ && (bmstrcasestr(buf, "boundary=") != NULL)
+ ) {
+ safestrncpy(boundary, bmstrcasestr(buf, "\""), sizeof boundary);
+ char *qu;
+ qu = strchr(boundary, '\"');
+ if (qu) {
+ strcpy(boundary, ++qu);
+ }
+ qu = strchr(boundary, '\"');
+ if (qu) {
+ *qu = 0;
+ }
+ }
+ }
+ }
+ } while ( (IsEmptyStr(boundary)) && (*ptr != 0) );
+
+ if (!IsEmptyStr(boundary)) {
+ snprintf(endary, sizeof endary, "--%s--", boundary);
+ history_msg->cm_fields['M'] = realloc(history_msg->cm_fields['M'],
+ strlen(history_msg->cm_fields['M']) + strlen(diffbuf) + 512
+ );
+ ptr = bmstrcasestr(history_msg->cm_fields['M'], endary);
+ if (ptr != NULL) {
+ sprintf(ptr, "--%s\n"
+ "Content-type: text/plain\n"
+ "From: %s <%s>\n"
+ "\n"
+ "%s\n"
+ "--%s--\n"
+ ,
+ boundary,
+ CCC->user.fullname,
+ CCC->cs_inet_email,
+ diffbuf,
+ boundary
+ );
+ }
+
+ history_msg->cm_fields['T'] = realloc(history_msg->cm_fields['T'], 32);
+ snprintf(history_msg->cm_fields['T'], 32, "%ld", time(NULL));
+
+ CtdlLogPrintf(CTDL_DEBUG, "\033[31m%s\033[0m", history_msg->cm_fields['M']);
+ /* FIXME now do something with it */
+ }
+
+ free(diffbuf);