$mbox_errcount = 0;
logs('Conectado como '.@$mconf['user']." a $mailbox", DEBUG);
if (imap_num_msg($mbox) and $hdr = imap_headerinfo($mbox, 1)) {
- logs(sprintf("Nuevo mail '%s' de %s", decode_header($hdr->subject), decode_header($hdr->subject)));
+ logs(sprintf("Nuevo mail '%s' de %s", decode_header($hdr->subject), decode_header($hdr->from)));
@list($padron, $ej, $ent, $codigo) = validar_cabecera($hdr);
if ($padron) {
logs('Cabecera válida', DEBUG);
function validar_cabecera($hdr) {
// Subject: padron nro_ej nro_entrega clave_alumno
$subject = decode_header($hdr->subject);
- if (preg_match('/^\s*(\d{5})\s+([1-4])\.([12])\s+(.*)$/', $subject, $m)) {
+ if (preg_match('/^\s*(\d{5})\s+(\d)\.(\d)\s+(.*)$/', $subject, $m)) {
return array_slice($m, 1, 5);
}
return false;
$fname = part_filename($part);
if ($fname) {
logs("Escribiendo archivo '$fname' [enc={$part->encoding}]", DEBUG);
- $body = imap_fetchbody($mbox, $msgid, $id + 1);
- if (!file_put_contents("$path/$fname", decode_body($body, $part->encoding))) return "Error al guardar el archivo $fname";
+ $body = decode_body(imap_fetchbody($mbox, $msgid, $id + 1), $part->encoding);
+ if (!$body) return "El archivo '$fname' está vacío";
+ if (!file_put_contents("$path/$fname", $body)) return "Error al guardar el archivo $fname";
}
//if (part_is_source($part) $has_sources = true;
//elseif (part_mime_type($part) == 'application/zip') $has_sources = true;