|  | 
| Demo
Discussion | 
| Forum
Config Examples
Contributions
Vulnerabilities | 
| 
| Contributions to ELOG | Not logged in |  |  | 
|
|
| 
| ID | Date | Author  | Author Email | Category | Subject | Status | Last Revision |  | 28 | Fri Mar 28 10:23:50 2008 | svrmarty | svrmarty@gmx.net | Other | ELOG V2.7.3-2080 debian amd64 package | Stable | Fri Mar 28 10:23:55 2008 by svrmarty |  |  |  | Attachment 1: elog_2.7.3+r2080-1_amd64.deb |  | 154 | Thu Mar  3 12:01:55 2022 | rami khrais | rami.khrais@sesame.org.jo | Other | Fixing repeating first inline_image in email | Stable | Thu Mar 10 11:30:20 2022 by rami khrais |  | Fixing repeating first image in email (email notification) when the user submit a new log with in_line images. |  | Attachment 1: elogd.c |  | /********************************************************************
   Name:         elogd.c
   Created by:   Stefan Ritt
   Copyright 2000 + Stefan Ritt
   ELOG 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
   (at your option) any later version.
   ELOG is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.
   In addition, as a special exception, the copyright holders give
   permission to link the code of portions of this program with the
   OpenSSL library under certain conditions as described in each
   individual source file, and distribute linked combinations
   including the two.
   You must obey the GNU General Public License in all respects
   for all of the code used other than OpenSSL.  If you modify
   file(s) with this exception, you may extend this exception to your
   version of the file(s), but you are not obligated to do so.  If you
   do not wish to do so, delete this exception statement from your
   version.  If you delete this exception statement from all source
   files in the program, then also delete it here.
   You should have received a copy of the GNU General Public License
   along with ELOG.  If not, see <http://www.gnu.org/licenses/>.
   Contents:     Web server program for Electronic Logbook ELOG
\********************************************************************/
#include "elogd.h"
#include "git-revision.h"
const char *_git_revision = GIT_REVISION;
BOOL running_as_daemon;         /* Running as a daemon/service? */
int elog_tcp_port;              /* Server's TCP port            */
static void (*printf_handler)(const char *);   /* Handler to printf for logging */
static void (*fputs_handler)(const char *);    /* Handler to fputs for logging  */
static FILE *current_output_stream = NULL;      /* Currently used output stream  */
char *return_buffer;
int return_buffer_size;
int strlen_retbuf;
int keep_alive;
char header_buffer[20000];
int return_length;
char host_name[256];
char referer[256];
char browser[256];
char config_file[256];
char resource_dir[256];
char logbook_dir[256];
char listen_interface[256];
char theme_name[80];
char http_host[256];
char http_user[256];
char _param[MAX_PARAM][NAME_LENGTH];
char _value[MAX_PARAM][NAME_LENGTH];
char _mtext[TEXT_SIZE];
char _cmdline[CMD_SIZE];
char *_attachment_buffer;
int _attachment_size;
int _max_content_length = MAX_CONTENT_LENGTH;
struct in_addr rem_addr;
char rem_host[256];
char rem_host_ip[256];
int _sock;
BOOL use_keepalive, enable_execute = FALSE;
BOOL ckedit_exist, image_magick_exist;
int _verbose_level, _current_message_id;
int _logging_level, _ssl_flag;
LOGBOOK *lb_list = NULL;
#define VERBOSE_URL     1
#define VERBOSE_INFO    2
#define VERBOSE_DEBUG   3
#ifdef HAVE_SSL
SSL *_ssl_con;
#endif
char *mname[] = {"January", "February", "March", "April", "May", "June", "July", "August", "September",
                 "October", "November", "December"
};
char attr_list[MAX_N_ATTR][NAME_LENGTH];
char attr_options[MAX_N_ATTR][MAX_N_LIST][NAME_LENGTH];
int attr_flags[MAX_N_ATTR];
char attr_list_default[][NAME_LENGTH] = {"Author", "Type", "Category", "Subject", ""};
char attr_options_default[][MAX_N_LIST][NAME_LENGTH] = {{""},
                                                        {"Routine", "Other"},
                                                        {"General", "Other"},
                                                        {""}
};
int attr_flags_default[] = {AF_REQUIRED, 0, 0, 0};
struct {
   char ext[32];
   char type[80];
} filetype[] = {
        {
                ".AI",   "application/postscript"},
        {
                ".ASC",  "text/plain"},
        {
                ".BZ2",  "application/x-bzip2"},
        {
                ".CFG",  "text/plain"},
        {
                ".CHRT", "application/x-kchart"},
        {
                ".CONF", "text/plain"},
        {
                ".CSH",  "application/x-csh"},
        {
                ".CSS",  "text/css"},
        {
                ".DOC",  "application/msword"},
        {
                ".DVI",  "application/x-dvi"},
        {
                ".EPS",  "application/postscript"},
        {
                ".GIF",  "image/gif"},
        {
                ".GZ",   "application/x-gzip"},
        {
                ".HTM",  "text/html"},
        {
                ".HTML", "text/html"},
        {
                ".ICO",  "image/x-icon"},
        {
                ".JPEG", "image/jpeg"},
        {
                ".JPG",  "image/jpeg"},
        {
                ".JS",   "application/x-javascript"},
        {
                ".KPR",  "application/x-kpresenter"},
        {
                ".KSP",  "application/x-kspread"},
        {
                ".KWD",  "application/x-kword"},
        {
                ".MP3",  "audio/mpeg"},
        {
                ".OGG",  "application/x-ogg"},
        {
                ".PDF",  "application/pdf"},
        {
                ".PNG",  "image/png"},
        {
                ".PS",   "application/postscript"},
        {
                ".RAM",  "audio/x-pn-realaudio"},
        {
                ".RM",   "audio/x-pn-realaudio"},
        {
                ".RM",   "audio/x-pn-realaudio"},
        {
                ".RM",   "audio/x-pn-realaudio"},
        {
                ".RPM",  "application/x-rpm"},
        {
                ".RTF",  "application/rtf"},
        {
                ".SH",   "application/x-sh"},
        {
                ".SVG",  "image/svg+xml"},
        {
                ".TAR",  "application/x-tar"},
        {
                ".TCL",  "application/x-tcl"},
        {
                ".TEX",  "application/x-tex"},
        {
                ".TGZ",  "application/x-gzip"},
        {
                ".TIF",  "image/tiff"},
        {
                ".TIFF", "image/tiff"},
        {
                ".TXT",  "text/plain"},
        {
                ".WAV",  "audio/x-wav"},
        {
                ".XLS",  "application/x-msexcel"},
        {
                ".XML",  "text/xml"},
        {
                ".XSL",  "text/xml"},
        {
                ".ZIP",  "application/x-zip-compressed"},
        {
                /* Open XML file types */
                ".DOCM", "application/vnd.ms-word.document.macroEnabled.12"},
        {
                ".DOCX", "application/vnd.openxmlformats-officedocument.wordprocessingml.document"},
        {
                ".DOTM", "application/vnd.ms-word.template.macroEnabled.12"},
        {
                ".DOTX", "application/vnd.openxmlformats-officedocument.wordprocessingml.template"},
        {
                ".PPSM", "application/vnd.ms-powerpoint.slideshow.macroEnabled.12"},
        {
                ".PPSX", "application/vnd.openxmlformats-officedocument.presentationml.slideshow"},
        {
                ".PPTM", "application/vnd.ms-powerpoint.presentation.macroEnabled.12"},
        {
                ".PPTX", "application/vnd.openxmlformats-officedocument.presentationml.presentation"},
        {
                ".XLSB", "application/vnd.ms-excel.sheet.binary.macroEnabled.12"},
        {
                ".XLSM", "application/vnd.ms-excel.sheet.macroEnabled.12"},
        {
                ".XLSX", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"},
        {
                ".XPS",  "application/vnd.ms-xpsdocument"},
        {
                "",      ""},};
struct {
   char language[32];
   char abbrev[32];
} lang_table[] = {
        {"brazilian",    "br"},
        {"bulgarian",    "bg"},
        {"czech",        "cz"},
        {"danish",       "dk"},
        {"dutch",        "nl"},
        {"french",       "fr"},
        {"german",       "de"},
        {"indonesia",    "id"},
        {"italian",      "it"},
        {"japanese",     "jp"},
        {"polish",       "pl"},
        {"ru_CP1251",    "ru"},
        {"slowak",       "sk"},
        {"spanish",      "es"},
        {"swedish",      "se"},
        {"turkish",      "tr"},
        {"zh_CN-GB2314", "zh"},
        {"zh_CN-UTF8",   "zh"},
        {"",             ""}
};
char _convert_cmd[256];
char _identify_cmd[256];
#ifdef OS_WINNT
int run_service(void);
#endif
#ifdef OS_UNIX
gid_t orig_gid;                 /* Original effective GID before dropping privilege */
uid_t orig_uid;                 /* Original effective UID before dropping privilege */
char pidfile[256];              /* Pidfile name                                     */
#endif
#ifdef __CYGWIN__               /* bug in cygwin, 'timezone' not linked automatically */
long _timezone;
#endif
/*---- Funcions from the MIDAS library -----------------------------*/
#define my_toupper(_c)    ( ((_c)>='a' && (_c)<='z') ? ((_c)-'a'+'A') : (_c) )
#define my_tolower(_c)    ( ((_c)>='A' && (_c)<='Z') ? ((_c)-'A'+'a') : (_c) )
BOOL strieq(const char *str1, const char *str2) {
   char c1, c2;
   if (str1 == NULL && str2 == NULL)
      return TRUE;
   if (str1 == NULL || str2 == NULL)
      return FALSE;
   if (strlen(str1) != strlen(str2))
      return FALSE;
   while (*str1) {
      c1 = *str1++;
      c2 = *str2++;
... 30972 more lines ... |  | 11 | Wed Nov 24 23:45:19 2004 | damon nettles | nettles@phgrav.phys.lsu.edu | Other | Steps for securing Elog using SSL and Apache | Stable |  |  | Everything in this guide was done on a full install of Fedora Core 3 running
Apache 2.0. If you are using an older version of Apache some of this may not
work, so I recommend upgrading. Also, on different Linux distributions, some
of the paths may be different.
The goal here is to get Elog set up under Secure Socket Layers, so that
communication both ways is encrypted.  This will cover any password
transactions so nothing gets sent over the web in the clear.
The previous method of securing the Elog, which involved using stunnel, is
out of date. A better way to go is to use the Elog in conjunction with
Apache. The Apache method leverages all the research and development that's
gone into providing secure sockets for Apache, and removes the need for any
serious reinventing of the wheel.
We begin with a web server running on port 80 and an Elog server running on
port 8080.
Making Certificates:
It's necessary to generate some secure certificates to be issued to anyone
who attempts to access the securesite.
A guide to making the certificates can be found at:
http://slacksite.com/apache/certificate.html
So, following the steps in the article:
   openssl genrsa -des3 -rand file1:file2:file3:file4:file5 -out\
   server.key 1024 
where the \ is merely an indicator that the command wouldn't fit on a line
here.  The fileN references are sources of random information to help the
random number seed be more random.  I merely used some personal text files
that were zipped up, as suggested in the page.
   openssl rsa -in server.key -out server.pem
Removes the RSA encryption from the key, to make it easier for the Apache
server to deal with it.
   openssl req -new -key server.key -out server.csr
Starts a line of questioning about us as a certificate issuing entity.
Answer with reasonable values.
  openssl x509 -req -days 60 -in server.csr -signkey server.key -  
  out\ 
  server.crt
After this move the server.pem, server.crt, and server.csr to the
appropriate directories under /etc/httpd/conf/ .  The extensions explain
which directory to put them in, with the exception that server.pem ended up
in etc/httpd/conf/ssl.key/ .
In the elogd.cfg file, change the port to 8079, and set the URL to
"https://your.host.name/" .  Restarting the Elog daemon now leaves us with
Elog listening to port 8079 instead of port 8080.
The rest of the story is in the "elogredirect.conf" file attached to this
post, but here are the highlights.
Create a virtual host dealing with SSL that listens to port 443 (the ssl
port), and acts as a proxy for port 8079 (where Elog is listening).  This
allows Apache to act as an SSL handler for Elog by handing off any access at
https://your.host.name/ to the Elog server.  The firewall then can keep out
any direct attempts to access port 8079, so that the only thing that can
reach the Elog server is stuff talking to 8079 on the local side of the
firewall (which pretty much means just the Apache proxy).  I recommend
Firestarter for the firewall config by the way, it's a real lifesaver.
http://firestarter.sourceforge.net/
This covers the SSL portion of the story, and by doing the redirection
inside the port 443 virtual host, instead of from the port 80 webpage as
before, you can avoid any path overlap.
As was the case for us, you may have links in older Elog posts, e-mails, or
web pages that point to specific Elog posts. If you have been using Elog for
some time and never bothered with the SSL stuff, the links most likely look
something like
http://your.host.name:8080/yourlogbook/postnumber. 
To cover legacy support for calls on port 8080, you can  create another
virtual host listening to port 8080.  This host's job is to take any
incoming URL calls on "http://your.host.name:8080/a_directory" and
translate them into calls on "https://your.host.name/the_same_directory" .
This means that any attempt to contact the Elog on port 8080 will get
answered by an Apache virtual host that redirects the client through the
Apache SSL virtual host described above. See the conf file for the details.
So in the end, the firewall is set to only allow through ports 80, 443, and
8080.  Port 80 handles the normal webpage access stuff.  Port 443
exclusively handles the SSL port for the Elog daemon, and port 8080
exclusively handles the redirect for the legacy Elog calls.
Implementation of this setup on another system should be pretty
straightforward.  Apache's config file is at /etc/httpd/conf/httpd.conf ,
and it also loads any *.conf files in /etc/httpd/conf.d/ .  So its a pretty
simple case of just dropping elogredirect.conf into /etc/httpd/conf.d/ and
restarting the Apache server.  Of course the necessary changes to elogd.cfg
have to be made and that server restarted as well.  The firewall, too, needs
to be setup to secure the whole deal. Note that the elogredirect.conf file
needs to be edited for your specific setup (changing the instances of 
"your.host.name" to whatever your server is, and also putting in the
administrator e-mail address where it is noted).
This work was done by Jonathan Hanson and Damon Nettles in the Gravity Lab
at Louisiana State University. You can see our Elog at
https://sam.phys.lsu.edu/elog .
If you have any questions or comments send them to
nettles@phgrav.phys.lsu.edu . |  | Attachment 1: elogredirect.conf |  | ### Here be things to make the elogd daemon invisibly secure under an
### Apache SSL proxy virtual host.  Arrrrrr!
### ----This config file be mostly written by Jonathan Hanson, 11/23/04
### ----With some help from a few old salts on the net.
### This be the first instance of SSL in our setup, so the SSL module
### Must be called.  This can be commented out if it don't put wind in
### your sails.
LoadModule ssl_module modules/mod_ssl.so
### Ahoy, ye scurvy land dogs! Listen to the SSL port (443) or may the
### sea beasts take ye!
Listen 443
### Make a virtual host at the default server name, and assign it port 443.
<VirtualHost _default_:443>
	### Here be standard configuration for the Virtual Host
	ServerAdmin your_e-mail_address
	ServerName _default_:443
	RequestHeader set Front-End-Https "On"
	
	### This be the path to the elog directory 
	### (This didn't seem to make any difference, but it be a good
	###  idea nonetheless)
	DocumentRoot /usr/local/elog
	
	### Here be the setup for the SSL component of the Virtual Host
	SSLEngine On
	SSLCertificateFile /etc/httpd/conf/ssl.crt/server.crt
	SSLCertificateKeyFile /etc/httpd/conf/ssl.key/server.pem
	
	### Here be the setup options for the Proxy module
	ProxyRequests Off
	ProxyPreserveHost On
	
	### This be the root of the new Virtual Host, and it should be
	### redirected to the port the elogd server is listening to 
	### (8079 on our poop deck).
	<Location />
		ProxyPass http://your.host.name:8079/
		ProxyPassReverse http://your.host.name:8079/
		SSLRequireSSL
	</Location>
	### Shiver me timbers!  A firewall can be laid across the elog
	### port to hinder direct access from the outside world to the elog
	### daemon.  This'll make the scurvy wretches come in through the apache
	### proxy virtual host, and batten down the hatches on the elog in general.
</VirtualHost>
### Our previous elog configuration was at http://your.host.name:8080 and some of our
### users made static HTML links to other posts in their posts and email.  They be sleeping 
### in Davy Jones's locker in the briney deep now, but we be needing to make these posts 
### backward-compatible.  We be changing the port Elogd listens to (as above) to 8079, and
### then we be using another new virtual host at port 8080 to redirect to the new SSL URL.
### So it appears to the landlubbers outside as if a normal elog server is listening to port
### 8080, but in reality it be a Virtual Host redirecting through the other SSL virtual host
### which then be passing it on to the port the elog server really be listening to.
### If ye not be needing this backwards compatability, the following section can be made
### to walk the plank.
### I won't be telling ye twice, ye slimy bilge rat!  Pay attention to what 
### used to be the old elog port(8080).
Listen 8080
<VirtualHost _default_:8080>
	### Here be standard configuration for the Virtual Host
	ServerAdmin your_e-mail_address
	ServerName _default_:8080
		
	### This be the path to the html directory 
	### (This didn't seem to make any difference, but it be a good
	###  idea nonetheless)
	DocumentRoot /httpd/html
	
	### Here be the dark magic of mod_rewrite.  Quake in your boots ye dogs!
	<IfModule mod_rewrite.c>
		RewriteEngine On
		RewriteRule ^/(.*) https://your.host.name/$1 [NC,R=301,L]
	</IfModule>
	
</VirtualHost>
### In the end, elog be reachable through either https://your.host.name/ 
### or http://your.host.name:8080/ , though the latter will be rewritten
### to the former as soon as the request be made.  This be satisfying our 
### needs for backwards compatbility with old URLs, while ensuring modern 
### secure SSL support.  Beware matey, recognize that we also had to change
### the port that elog listens to, and then add a URL line in the elogd.cfg
### file:
###      port = 8079
###      URL = https://your.host.name/
### Also a firewall was brought up and told to allow through only ports 
### 80(html), 443(SSL), and 8080(the elog stand-in) and of course any other 
### ports ye may need for other applications.
 |  | 18 | Mon Sep 25 11:24:05 2006 | Yoshio Imai |  | Documentation | securing of elog with stunnel v4 under Linux | Beta |  |  | The following instructions should work in securing the elog using stunnel version 4 under Linux. The specific paths may have to be adapted to your distribution. A sample configuration file is attached. |  | Attachment 1: elog-stunnel4.howto |  | 1. Prepare a certificate
------------------------
either: request a certificate for your elog URL from your web administrator
- the private key must not be password-protected
- the 'common name' must be the URL of your elog server
or: create a self-signed certificate yourself with the OpenSSL package
- as root user, create a self-signed certificate with the command
root@localhost:# openssl req -new -x509 -config /etc/ssl/openssl.cnf -keyout stunnel.pem -out stunnel.pem -days 365 -nodes
- this creates a self-signed certificate (-x509) whith one year validity (-days 365)
  and no password protection for the private key (-nodes)
- private key and certificate are written to the same file, "stunnel.pem"
Answer all questions, making sure that the 'common name' is the URL under which users
are to reach your elog server.
For more information on how to create and/or manage SSL certificates, see e.g.
http://www.ibiblio.org/pub/Linux/docs/HOWTO/SSL-Certificates-HOWTO
Notice: Unless your web administrator can procure a certificate signed by an established
        CA, your elog users will be asked if they want to accept your (unverifiable) certificate
        when connecting to your elog server. This is no problem at all but can lead to
        questions if your users are unsure about this.
2. Adapt the certificate file to stunnel4 conventions
-----------------------------------------------------
The certificate filename must be the MD5 checksum:
- Retrieve the MD5 checksum of your certificate with
root@localhost:# openssl x509 -hash -noout -in stunnel.pem 
abcdefgh
- Rename the certificate file accordingly
root@localhost:# mv stunnel.pem abcdefgh.0
- Move the certificate file to the standard location, e.g. /etc/ssl/certs
- change the permissions of the file to -rw-------
- make sure there is a blank line between
  -----END RSA PRIVATE KEY----- and -----BEGIN CERTIFICATE-----
  and a blank line after
  -----END CERTIFICATE-----
  in your certificate file.
3. Configure stunnel4
---------------------
Install the stunnel4 package (if not already done).
Modify the configuration file (e.g. /etc/stunnel/stunnel.conf, depending on your
distribution):
- general options:
  cert = /etc/ssl/certs/abcdefgh.0    ; put the name of your certificate file here
  debug = 4                           ; otherwise ALL connection attempts will be logged to your syslog
  pid = /var/run/stunnel4/stunnel.pid ; check where the other services write their pid-files, depends 
                                      ; somewhat on the distribution
- comment out all lines containing chroot options
- comment out all CA lines
- comment out all service sections except the HTTPS section, which should look as follows
[https]
accept  = 443       ; i.e. stunnel listens on port 443, the standard https port
connect = 8080      ; and forwards all connections to port 8080 (use the port under which
                    ; your elogd is running here!)
TIMEOUTclose = 0    ; for buggy MS Internet Explorers, see the stunnel4 manpage
Some Linux distributions require that in the file /etc/defaults/stunnel4 the option ENABLED be set
to ENABLED=1. If not, the stunnel will not be started at system bootup.
4. Start the stunnel4 server
----------------------------
root@localhost# stunnel4 /etc/stunnel/stunnel.conf
Your elog should now be accessible via
https://your.elog.server
 |  | Attachment 2: stunnel.conf |  | cert = /etc/ssl/certs/abcdefgh.0
pid = /var/run/stunnel4/stunnel.pid
; Some performance tunings
socket = l:TCP_NODELAY=1
socket = r:TCP_NODELAY=1
; Some debugging stuff useful for troubleshooting
debug = 4
; Service-level configuration
[https]
accept  = 443
connect = 8080
TIMEOUTclose = 0
 |  | 21 | Tue Feb 20 18:20:40 2007 | Val Schmidt | vschmidt@ldeo.columbia.edu | Documentation | Secure elog with SSL under Apache2 on Ubuntu | Stable |  |  | The steps for configuration under Apache2 are a bit different. Below I've included a quick list of instructions for Ubuntu. One nice thing about this method, is that only https requests to https://your.url/elog are redirected (not all https connections to your url) so you can have other services running under ssl: 
 My Setup:
 Ubuntu 6.10 (Edgy):
 Linux tide1 2.6.17-11-generic #2 SMP Thu Feb 1 19:52:28 UTC 2007 i686 GNU/Linux
 
 Packages:
 ii  apache2                                    2.0.55-4ubuntu4                      next generation, scalable, extendable web se
ii  apache2-common                             2.0.55-4ubuntu4                      next generation, scalable, extendable web se
ii  apache2-mpm-worker                         2.0.55-4ubuntu4                      high speed threaded model for Apache2
ii  apache2-utils                              2.0.55-4ubuntu4                      utility programs for webservers 
ii  elog                                       2.6.1+r1642-1                        Logbook system to manage notes through a Web--- 
 To setup ssl in apache2 for elog I started here:
 This min-howto was kindly provided in a forum. I reproduced it here without permission.
 
 A Mini-Howto for apache2: 
apt-get install apache2
apache2-ssl-certificate
(and answer the questions)
Now, enable ssl:
a2enmod ssl
configure ssl:
cp /etc/apache2/sites-available/default /etc/apache2/sites-available/ssl
ln -s /etc/apache2/sites-available/ssl /etc/apache2/sites-enabled/ssl 
"/etc/apache2/sites-enabled/ssl" should look like this:
NameVirtualHost *:443
<VirtualHost *:443>
(... configure the directories too...)
and "/etc/apache2/sites-enabled/default" should look like this:
NameVirtualHost *:80
<VirtualHost *:80>
(... configure the directories too...)
In /etc/apache2/ports.conf, add Listen 443
In the middle of /etc/apache2/sites-available/ssl file, insert this two lines:
SSLEngine On
SSLCertificateFile /etc/apache2/ssl/apache.pem
Hope it helps :)
 This method, without configuraiton of any of the <Directory> directives in /etc/apache2/sites-available/ssl, makes everything in /var/www https accessible. This may not be desirable. Configure the directives as you see fit.
 
 To get SSL forwarding going for elog, in /etc/apache2/sites-available/ssl, I added the following:
 
 
  
ServerName tide1.unh.edu
        ProxyRequests Off
        ProxyPreserveHost On
        <Location /elog/>
                Order allow,deny
                allow from all
                ProxyPass  http://tide1.unh.edu:8080/
                ProxyPassReverse  http://tide1.unh.edu:8080/
                SSLRequireSSL
        </Location>
Once this is in place one must restart apache with
 sudo /etc/init.d/apache2 force-reload
 
 In /etc/elog.conf I added:
 
 URL=https://tide1.unh.edu/elog and restarted elog as above.
 
 Finally, I removed the firewall entry that allowed connections to port 8080 for non-secure elog.
 
 Items of note:
 The "apache2-ssl-certificate" created a certificate that seems to expire in 30 days. This obviously not ideal. More details about how to create certificates can be found at HERE. At some point in the future, we'll have to figure this out and create a more appropriate certificate.
 |  | 
| 46 | Fri Jul 31 13:52:32 2015 | TorstenJ | torsten.jakob@jet-services.com | Web site | Problem with Internet Explorer when saving an entry | Stable | Fri May 31 14:20:43 2019 by Stefan Ritt | 
| Hi all, first off all let me say, that I realy like this great tool. That is a lot of help for keeping our server documentation up-to-date. Thanks to all contributors for that. I right here, because I actually have an issue with saving entries working with IE11 (but also in IE9). When ever I enter an entry, and click the save button, the page open a page with the text: "OK 1"   or the second attemp: "OK 2"   3rd  "OK 3" and so on. To get back to my Item list, I have to click the back button in the internet explorer. I also opens a lot of draft entries in my databases.  When I submit my entry, I don't have an issue, and the entry is saved correctly. This issue doesn't happen when using Google Chrome. Had anyone an simlar issue using elog with IE?  It would be great to have some help with that issue. Thanks Torsten | 
| 32 | Fri Feb 19 14:05:53 2010 | Tony Albers | tony.albers@gmail.com | Other | updated eloglang.danish file | Stable |  | 
| I have updated the file. Everything should be translated now. /tony   ## Danish translation by Miljan Dedic <mde@HVIDOVRE.DK>
 # 04-06-2004
 # Updated by Tony Albers <tony.albers@gmail.com>
 # 19-02-2010
 # A more recent version may be available at :
 # http://savannah.psi.ch/websvn/listing.php?repname=elog&path=%2Ftrunk%2Fresources%2F
 #
 
 New = Ny
 Edit = Ændr
 Delete = Slet
 Reply = Svar
 Find = Find
 Last day = Sidste Dag
 Last 10 = Sidste 10
 Config = Konfigurer
 Change password = Ændre Password
 Logout = Log Ud
 Help = Hjælp
 Back = Tilbage
 Submit = Send
 First = Første
 Last = Sidste
 Previous = Forrige
 Next = Næste
 Copy to = Kopier til
 Move to = Flyt til
 Save = Gem
 Cancel = Annuller
 Wrong password = Forkert kendeord
 Please login = Log Ind
 Username = Bruger Navn
 Password = Kendeord
 Old password = Gamle kendeord
 New password = Nyt kendeord
 ELOG password = ELOG kendeord
 ELOG change password = Ændre ELOG kendeord
 Please enter password to obtain write access = Skriv kendeord for at opnå skriveadgang
 Please enter password to obtain administration access = Skriv kendeord for at opnå admin adgang
 Several logbooks are defined on this host = Flere logbøger er defineret på denne host
 Please select the one to connect to = Vælg hvilken du vil have adgang til
 Change password for user = Ændr kendeord til bruger
 Logged in as = Du er logget ind som
 Entry date = Dato for indlæg
 with = Med
 This is the last entry = Dette er det sidste indlæg
 This is the first entry = Dette er det første indlæg
 Email sent to = Email sendt til
 Email notification suppressed = Send ikke Email
 please select = Vælg venligst
 Suppress Email notification = Notificér ikke med Email
 Attachment = Vedhæft
 Reply to this = Svar på denne
 In reply to = Som svar på
 Fields marked with = Felter markeret med
 are required = Er påkrævet
 Please check that it exists and elogd has write access = Kontroller venligst om det eksisterer,og om elogd har skriveadgang
 Error: Attribute <b>%s</b> not supplied = Fejl: Attribut <b>%s</b> ikke udfyldt
 Please go back and enter the <b>%s</b> field = Gå tilbage og udfyld <b>%s</b> feltet
 Please use your browser's back button to go back = Brug tilbage knappen på din browser
 ELOG find = ELOG søg
 Find = Find
 Search = Søg
 Reset Form = Nulstil Form
 Summary only = Kun Beskrivelse
 Show attachments = Vis vedhæftede filer
 Printable output = Vis Print
 Sort in reverse order = Sorter i omvendt rækkefølge
 Start date = Start dato
 End date = Slut dato
 Year = År
 Text = Tekst
 Search all logbooks = Søg i alle log bøger
 Last %d days = Sidste %d dage
 Last %d entries = Sidste %d indlæg
 No entries found = Ingen indlæg fundet
 A new entry has been submitted on %s = Et nyt indlæg af %s
 Logbook = Logbog
 Yes = Ja
 No = Nej
 Error deleting message: status = Fejl ved sletning: Status
 Error: Command "<b>%s</b>" not allowed = Fejl: kommando "<b>%s</b>" ikke tilladt
 Cannot open file <b>%s</b> =kan ikke åbne filen  <b>%s</b>
 Cannot write to <b>%s</b> = kan ikke skrive til <b>%s</b>
 No SMTP host defined in [global] section of configuration file = Ingen SMTP host defineret i [global] sektionen af konfigurationsfilen
 Display threads = Vis tråde
 Logbook is empty = Logbog er tom
 Download = Hent
 and all its replies = Og alle Svar
 Message ID = Besked-ID
 Not logged in = Ikke logget ind
 Login = Login
 Page %d of %d = Side %d af %d
 all entries = alle indlæg
 Login name = Brugernavn
 Full name = Fulde navn
 ELOG user config = ELOG bruger Konfig
 ELOG new user = Ny ELOG bruger
 Admin = admin
 Select user = Vælg bruger
 Remove user = Fjern bruger
 New user = Ny bruger
 Retype new password = Gentag det nye kendeord
 New passwords do not match, please retype = kendeord passer ikke, prøv igen
 Retype password = Gentag kendeord
 exists already = Bruger eksisterer allerede
 Register as new user = Opret som ny bruger
 A new ELOG user has been registered on %s = En ny bruger er blevet registreret på %s
 Email = Email
 User "%s" registered on logbook "%s" = Bruger "%s" i Logbog "%s" registreret
 User [%s] has been deleted = Bruger [%s] er blevet slettet
 Hit following URL to activate that account = Tryk på følgende URL for at aktivere bruger konto
 ELOG registration = ELOG Registrering
 Your ELOG account has been activated on host = Din ELOG Konto er aktiveret
 You can access it at = Du kan opnå adgang på
 Are you sure to delete these messages? = Er du sikker på at du vil slette disse beskeder?
 Select = Vælg
 All entries = Alle indlæg
 Day = Dag
 Week = Uge
 Month = Måned
 Show last = Vis Sidste(n)
 Goto page = Gå til
 All = Alle
 Display = Vis
 entries per page = Indlæg per side
 Toggle all = Vis alle
 Selected entries = Vælg Indlæg
 Collapse = Fold Sammen
 Expand = Fold Ud
 Full = Fuld
 Summary = Beskrivelse
 Threaded = Vis som Tråde
 Filters = Filtrer
 Mode = Modus
 Options = Funktioner
 Error: start date after end date = Fejl: Start Dato efter Slut Dato
 and all their replies = Og alle deres svar
 Upload = Overfør til server
 Requested = Rekvirer
 Registration request on logbook "%s" = Anmodning om registrering på logbog "%s"
 A new ELOG user wants to register on "%s" = Ny Bruger Ønsker At Registrere på "%s" logbogen
 Search text also in attributes = Søg også text i attributerne
 Date = Dato
 ID = ID
 Forgot password? = Glemt kendeord?
 Email address <i>"%s"</i> not registered = Email Adresse <i>"%s"</i> ikke registreret
 ELOG password recovery = Gendan ELOG kendeord
 No Email address registered with user name <i>"%s"</i> = Bruger "</i> har ikke registreret mail adresse
 Error sending Email via <i>"%s"</i> = Fejl ved afsendelse af e mail via <i>"%s"</i>
 A new password for user <i>"%s"</i> has been sent to %s = Et nyt kendeord til Bruger <i>"%s"</i> er sendt til  %s
 Forgot = Glemt
 User "%s" registered on host "%s" = Bruger "%s" på host "%s" registreret
 Registration request on host "%s" = Andmodning om registrering på host "%s"
 A new password has been created for you on host %s = Et nyt kendeord er genereret på %s
 Enter your user name or email address = Skriv venligst Bruger navn eller e mail adresse
 Password recovery for ELOG %s = Genskab kendeord for  ELOG %s
 Host = Host
 Your ELOG account has been activated = Din ELOG Konto er aktiveret
 Maximum number of attachments reached = Max antal vedhæftninger nået
 on = Til
 Entry is currently edited by = Indlæg er ved at blive redigeret af
 recipients = Modtagere
 Suppress shell execution = Ignorer kommando shell
 Update = Opdater
 by = Af
 Change %s = rediger %s
 Add new option here = Tilføj ny Funktion
 Expand all = Udvid Alle
 Add %s = Tilføj %s
 User name <i>"%s"</i> not registered = Bruger Navn  <i>"%s"<i> ikke registreret
 Synchronization = Synkronisering
 Error: Value <b>%s</b> not allowed for boolean attributes = Fejl: værdi <b>%s</b> ikke tilladt for bool'ske Attributer
 Error: Attribute option <b>%s</b> not existing = Fejl: Attribut Funktion <b>%s</b> eksisterer ikke
 Last submission = Sidste Indlæg
 Synchronize = Synkroniser
 No mirror server defined in configuration file = ingen mirror-Server defineret i konfigurations filen
 user = Bruger
 Maximum number of replies (%d) exceeded = Max antal svar (%d) overskredet
 Entry can only be edited %1.2lg hours after creation = Indlæg kan kun redigeres %1.2lg timer efter oprettelse
 Display full entries = Vis alt
 No entry selected for deletion = Intet indlæg markeret til sletning
 Cannot read entry from local logbook = Kan ikke læse fra lokal logbog
 Cannot create socket = Kan ikke oprette socket
 Cannot resolve host name "%s" = Host "%s" kan ikke opløses
 Cannot connect to host %s, port %d = Kan ikke forbinde til %s, Port %d
 Cannot receive "%s" = Kan ikke modtage "%s"
 Received wrong entry id "%d" = Modtog forkert ID "%d"
 Entry #%d is locked on remote server = Indlæg #%d er låst på remote server
 Cannot save remote entry locally = Kan ikke gemme remote indlæg lokalt
 local = lokal
 remote = remote
 Please delete %s or %s entry to resolve conflict = Slet venligst indlæg %s eller %s indlæg for at løse problem
 Error sending local entry = Fejl ved afsending af lokalt indlæg
 Local entry submitted = Lokalt indlæg indlagt
 Error deleting remote entry = Fejl ved sleting af remote indlæg
 New entry cannot be written to directory "%s" = Nyt indlæg kan ikke skrives til bibliotek  "%s"
 Entry %s cannot be read from logbook "%s" = Indlæg %s kan ikke læses fra logbog "%s"
 This entry has been deleted = Dette indlæg er slettet
 Entries = Indlæg
 Cannot connect to remote server "%s" = Kan ikke forbinde til remote server  "%s"
 Remote server is not an ELOG server = Remote server er ikke en ELOG server
 Incorrect remote ELOG server version %s = Forkert Version %s fra remote server
 Error accessing remote logbook = Fejl ved adgang til remote server
 Invalid HTTP header = Forkert HTTP header
 No user name supplied to access remote logbook = Intet bruger navn angivet til remote logbog
 Synchronizing logbook %s with server "%s" = Synkroniser %s med server "%s"
 Configuration has been changed locally and remotely = Konfigurationen er ændret lokalt og remote
 Please merge manually to resolve conflict = Sammensmelt manuelt for at løse konflikt
 Logbook "%s" does not exist on remote server = Logbog "%s" eksisterer ikke på remote server
 Entry has been changed locally and remotely = Indlæg er ændret lokalt og remote
 Entry deleted locally = Indlæg slettet lokalt
 Changed local entry ID to %d = lokalt indlæg ID til %d
 Entry deleted remotely = Indlæg slettet remote
 All entries identical = Alle indlæg identiske
 Invalid mirror_id or entry_date = Ugyldigt mirror_id eller indlæg_dato
 Synchronize all logbooks = Synkroniser alle logbøger
 Calendar = Kalender
 Remote entry received = Remote indlæg modtaget
 Pick a date = Vælg dato
 Please select at least one '%s' = Vælg mindst en '%s'
 Please select a '%s' = Vælg en  '%s'
 Please enter month for attribute '%s' = Vælg måned for attribut '%s'
 Please enter day for attribute '%s' = Vælg dag for attribut '%s'
 Please enter year for attribute '%s' = Vælg år for attribut '%s'
 Please enter attribute '%s' = Vælg attribut '%s'
 Entry time = Dato/Tid
 Start = Start
 End = Slut
 From = Fra
 After = Efter
 to = Til
 Before = før
 Previous Year = Forrige år
 Next Year = Næste år
 Please enter numeric value for '%s' = Indsæt numerisk værdi for '%s'
 Error: Attribute <b>%s</b> must be numeric = Felj: Attribut <b>%s</b> skal være en numerisk værdi
 3 Months = 3 måneder
 6 Months = 6 måneder
 Error sending local message = Fejl ved adsendelse af lokalt besked
 Error receiving message = Fejl ved modtagelse af besked
 Are you sure to delete this entry? = Er du sikker på at du vil slette dette indlæg?
 ELOG CSV import = ELOG CSV Import
 Import = Import
 CSV filename = CSV filnavn
 Field separator = Felt Separator
 Edit entry = Rediger Felt
 Delete entry = Slet Felt
 CSV Import = CSV Import
 Derive attributes from CSV file = Hent attributer fra CSV fil
 Comma = Komma
 Semicolon = Semikolon
 Preview import = Forhåndsvis Import
 CSV import preview of %s = CSV import forhåndsvisning af %s
 Too many attributes in CSV file = For mange attributter i CSV fil
 %d entries successfully imported = %d indlæg successfuldt importeret
 No 'Attributes' option present in %s = Ingen 'Attributter' funktioner tilstede i %s
 CSV ("," separated) = CSV ("," separeret)
 CSV (";" separated) = CSV (";" separaret)
 Auto detect = Auto detektion
 Resubmit as new entry = send som nyt indlæg
 #
 #---- please translate following items and then remove this comment ----#
 #
 text = tekst
 Column header '%s' must be present in CSV file = Kolonneoverskrift '%s' skal være tilstede i CSV filen
 Fill text body = Brødteks
 Please re-enter filename = Genindtast venligst filnavnet
 New = Ny
 Last x = Sidste x
 Activate = Aktiver
 Entry has been modified = Indlægget er blevet modificeret
 No attachment file specified = Der er ikke specificeret en fil til vedhæftning
 Submit modified ELOG entry? = Publicer modificeret ELOG indlæg
 Delete this logbook = Slet denne logbog
 Rename this logbook = Omdøb denne logbog
 Create new logbook = Opret ny logbog
 Syntax error in config file = Indtastningsfejl i konfigurationsfilen
 Email notification = Email notifikation
 Are you sure to delete logbook "%s"? = Er du sikker på at du vil slette logbogen ''%s''?
 Logbook "%s" exists already, please choose different name = Logbogen ''%s'' findes allerede, vælg venligst et andet navn
 Rename logbook = Omdøb logbog
 Enter new logbook name = Indtast nyt navn på logbog
 Logbook name = Logbog navn
 Use existing logbook as template = Brug eksisterende logbog som skabelon
 none = ingen
 URL is redirected to: = URL er henvist til
 Remote config should be received = Fjernkonfiguration skulle blive modtaget
 Local entry should be submitted = Lokalt indlæg bør afsendes
 Remote entry should be received = Fjernindlæg bør modtages
 Local entry = Lokalt indlæg
 %s should be deleted = %s bør slettes
 Entry should be deleted locally = Indlæg bør slettes lokalt
 Local entry ID should be changed to %d = Lokalt indlægs ID bør ændres til %d
 Remote entry = Fjernindlæg
 Entry should be deleted remotely = Indlæg bør slettes på fjernlokation
 Click here to delete this entry = Tryk her for at slette dette indlæg
 Maximum number of attribute options exceeded = Maximalt tilladt antal atributmuligheder overskredet
 Please increase MAX_N_LIST in elogd.c and recompile = Forøg venligst  MAX_N_LIST i elogd.c og kompiler igen
 You can "steal" the lock by editing this entry = Du kan ''stjæle'' låsen ved at modoficere dette indlæg
 Several logbooks groups are defined on this host = Der er adskillige logbogsgrupper defineret på dette system
 Please select one to list the logbooks in that group = Vælg venligst en gruppe for at se dens logbøger
 No logbook defined on this server = Der er ikke defineret en logbog på dette system
 Goto ELOG home page = Gå til ELOG's hjemmeside
 Please enter "%s" = Indtast venligst ''%s''
 Change config file = Ændr konfigurationsfil
 Click here to delete %d entries = Tryk her for at slette %d indlæg
 Please check that it exists and elogd has write access and disk is not full = Kontroller venligst at elogd har skriveadgang og at der er ledig plads på harddisken
 Show = Vis
 Hide =  Skjul
 Hide all = Skjul alle
 Show all = Vis alle
 This logbook requires authentication = Denne logbog behøver opmærksomhed
 Attachment file <b>"%s"</b> empty or not found = Vedhæftet fil <b>''%s''</b> er tom eller kunne ikke findes
 Case sensitive = Forskel på store og små bogstaver
 List = Liste
 Date must be between 1970 and 2037 = Dato skal være mellem 1970 og 2037
 up = op
 down = ned
 stop = stands
 Entry = Indlæg
 name may not contain blanks = Der må ikke være mellemrum i navnet
 regular expressions = regulære udtryk
 Text fields are treated as %s = Teksfelter behandles som %s
 Subscribe to logbooks = Abonnér på logbøger
 enable automatic email notifications = aktiver emailnotifikationer
 Set all = Sæt alle
 Set none = Sæt ingen
 Please enter hour for attribute '%s' = Indtast venligst timetal for attribut '%s'
 Please enter minute for attribute '%s' = Indtast venligst minuttal for attribut '%s'
 Please enter second for attribute '%s' = Indtast venligst sekundtal for attribut '%s'
 No admin user has been defined in configuration file = Der er ikke defineret en administrator i konfigurationsfilen
 Duplicate = Dupliker
 Cannot lookup server name = Servernavn kan ikke slås op
 Cannot connect to server = Der kan ikke forbindes til serveren
 %s wrote = %s skrev
 Quote = Citat
 Insert current time = Indtast nuværende tidspunkt
 Please enter numeric value for year of attribute '%s' = Indtast venligst numerisk værdi for årstal i attributten '%s'
 Preview = Forhåndsvisning
 FONT = FONT
 SIZE = STØRRELSE
 COLOR = FARVE
 smiling = smiler
 happy = lykkelig
 winking = blinker
 big grin = griner
 crying = græder
 cool = kølig
 frowning = vrænger ansigt
 confused = forvirret
 mad = gal
 pleased = glad
 tongue = rækker tunge
 yawn = gaber
 Encoding = Formattering
 User "%s" not found in password file = Brugeren ''%s'' blev ikke fundet i password filen
 Cannot write to file <b>%s</b> = Kan ikke skrive til filen <b>%s</b>
 Really remove user %s? = Er du sikker på at du vil slette brugeren %s?
 Invalid user name "%s" or password for remote logbook = Ugyldigt brugernavn eller kodeord til fjernlogbog
 Hide attachments = Skjul vedhæftninger
 Show only new entries = Vis kun nye indlæg
 Show all entries = Vis alle indlæg
 New entries since = Nye indlæg siden
 An old ELOG entry has been updated = Et gammelt ELOG indlæg er blevet opdateret
 A new ELOG entry has been submitted = Et nyt ELOG indlæg er blevet publiceret
 Cannot open file "%s" = Kan ikke åbne filen ''%s''
 Invalid user name or password = Ugyldigt brugernavn eller kodeord
 Upload image = Send billede
 Please enter filename or URL = Indtast venligst filnavn eller URL
 Maximum allowed file size is = Den størst tilladte filstørrelse er
 Enter filename or URL = Indtast filnavn eller URL
 Image uploaded successfully = Billedet er korrekt overført
 Image "%s" uploaded successfully = Billedet ''%s'' er korrekt overført
 HelpELCode = HjælpELKode
 Cannot retrieve file from URL "%s" = Filen kan ikke hentes fra URL ''%s''
 Enter name of hyperlink = Indtast hyperlink navn
 Enter URL of hyperlink = Indtast hyperlink URL adresse
 astonished = forbløffet
 Error in regular expression "%s" = Fejl i regulært udtryk ''%s''
 File not found at URL "%s" = Filen blev ikke fundet på URL ''%s''
 Entry size too large for email notification = Indlæggets størrelse er for stort til email-notifikation
 Please specify a valid email address = Specificer venligst en gyldig email adresse
 Cannot send email notification to "%s" = Kan ikke sende email-notifikation til ''%s''
 Error: Command "<b>%s</b>" is not allowed for user "<b>%s</b>" = Fejl: Kommando ''<b>%s</b>'' er ikke tilladt for bruger ''<b>%s</b>''
 Shell execution not enabled via -x flag = Kommandofortolkerudførelse er ikke slået til med -x flaget
 Enter heading level (1, 2 or 3) = Indtast overskiftsniveau (1, 2 eller 3)
 User name may not contain blanks = Der må ikke være mellemrum i brugernavnet
 Empty password not allowed = Tomme kodeord er ikke tilladt
 Password may not contain blanks = Kodeord må ikke indeholde mellemrum
 Anonymous = Anonym
 Activation notice has been sent to %s = Notifiakation om aktivering er sendt til %s
 Your request has been forwarded to the administrator = Din forespørgsel er sendt videre til en administrator
 You will be notified by email upon activation of your new account = Du vil få besked i en email når din konto er aktiveret
 Select period = Vælg periode
 Last week = Sidste uge
 Last month = Sidste måned
 Last 3 Months = Sidste 3 måneder
 Last 6 Months = Sidste 6 måneder
 Last Year = Sidste år
 Enter %s = Indtast %s
 Select %s = Vælg %s
 Bold text CTRL+B = Fed tekst CTRL+B
 Italics text CTRL+I = Kursiv tekst CTRL+I
 Underlined text CTRL+U = Understreget tekst CTRL+U
 Centered text = Centreret tekst
 Insert hyperlink = Indsat hyperlink
 Insert email = Indtast email
 Insert image CTRL+M = Indsæt billede CTRL+M
 Insert quote = Indsæt citat
 Insert list CTRL+L = Indsæt liste CTRL+L
 Insert table = Indsæt tabel
 Insert heading CTRL+H = Indsæt overskrift CTRL+H
 Insert code CTRL+O = Indsæt kode CTRL+O
 Hide the smiley bar = Skjul smileymenu
 Show the smiley bar = Vis smileymenu
 Insert current time/date = Indtast nuværende tidspunkt/dato
 Entry is locked on local server and therefore skipped = Indlægget er låst på det lokal system og springes derfor over
 Keep me logged in on this computer = Lad mig blive ved at være logget ind på denne maskine
 for the next %d minutes = i de næste %d minutter
 for the next hour = i den næste time
 for the next %d hours = i de næste %d timer
 for the next %d days = i de næste %d dage
 keep original values = gem oprindelige værdier
 Entry is locked = Indlæg er låst
 Edit anyhow = Ret alligevel
 Submit entry = Publicer indlæg
 Insert image = Indsæt billede
 Insert Date/Time = Indsæt dato/tid
 Insert horizontal line = Indsæt horisontal linje
 Insert anchor point = Indsæt ankerpunkt
 keep original text = behold oprindelig tekst
 unspecified = uspecificeret
 To subscribe to any logbook, click on 'Config' in that logbook = For at abonnere på en logbog, vælg 'konfigurer' i denne logbog
 ELOG XML import = ELOG XML import
 Derive attributes from XML file = Afled attributter fra XML fil
 XML filename = XML filnavn
 Invalid date format = Ugyldigt datoformat
 XML file does not contain %s element = XML filen indeholder ikke elementet %s
 XML import preview of %s = XML import forhåndsvisning af %s
 XML Import = XML Import
 A old entry has been updated on %s = Et gammelt indlæg er blevet opdateret den %s
 This entry has in meantime been locked by %s = Dette indlæg er i mellemtiden bleve låst af %s
 This entry has in meantime been modified by someone else = Dette indlæg er i mellemtiden blevet modificeret af en anden bruger
 First entry, Ctrl-Home = Første indlæg, Ctrl-Home
 Previous entry, Ctrl-PgUp = Foregående indlæg, Ctrl-PgUp
 Next entry, Ctrl-PgDn = Næste indlæg, Ctrl-PgDn
 Last entry, Ctrl-End = Sidste indlæg, Ctrl-End
 ELOG import = ELOG import
 Please choose format to import: = Vælg det format der skal importeres
 Enter text = Indtast tekst
 Show HTML source code = Vis HTML kildekode
 or until I log out = indtil jeg logger ud
 Make smaller = Gør mindre
 Original size = Oprindelig størrelse
 Make larger = Gør større
 Rotate left = Rotér til venstre
 Rotate right = Rotér til højre
 Delete attachment = Slet vedhæftning
 Cannot create thumbnail, please check ImageMagick installation = Kan ikke danne oversigtsbilleder, kontroller at ImageMagick er korrekt installeret
 Please log on by clicking on following link and change your password = Log venligst på ved at trykke på følgende link og ændr dit kodeord
 Attachments = Vedhæftninger
 Error: Content length (%d) larger than maximum content length (%d) = Fejl: Længde af indhold (%d) er større end maksimalt tilladt (%d)
 ELOG error = ELOG fejl
 Only user <b>%s</b> can edit this entry = Kun brugeren <b>%s</b> kan rette i dette indlæg
 Export to = Eksporter til
 Do not ignore first line = Ignorer ikke første linje
 Last %d hours = Sidste %d timer
 Invalid URL = Ugyldig URL
 Attribute "%s" is not allowed in config file = Attributten ''%s'' er ikke tilladt i konfigurationsfilen
 Only user <b>%s</b> can delete this entry = Kun bruger <b>%s</b> kan slette dette indlæg
 File system full, ELOG cannot continue to work = Filsystemet er løbet fuld, ELOG kan ikke fortsætte
 
 | 
| 3 | Fri Jun  6 18:32:14 2003 | Tomas Rudolf | tomas@mba.be |  | ELOG Syntax highlighting in UltraEdit |  |  | 
| Maybe some of you use UltraEdit code editor (http://www.ultraedit.com/) to 
create/modify your ELOGD.CFG files.
Well, in that case we hope you find useful the attached syntax highlighting 
configuration file.
To intstall this file into UltraEdit :
MENU --> ADVANCED --> CONFIGURATION --> SYNTAX HIGHLIGHTING tab --> OPEN 
WORDLIST
You can also download the latest version from our website :
http://public.mba.be/demo/elog/u-edit-elog-syntax.txt | 
| Attachment 1: u-edit-elog-syntax.txt | 
| /L7"Elog" Line Comment = ; Block Comment On = /* Block Comment Off = */ String Chars = "' File Extensions = cfg
/Delimiters = ~!@%^&*()-+=|\/{}[]:;"'<> ,	.?
/C1"Elog Global functions"
** Logbook tabs
** SMTP host =
** Admin Password
** Admin user =
** Selection page
** Self register
** URL=
** Welcome Title
/C2"Elog Syntax"
** Attributes
** Back
** Bottom text
** Comment
** Config
** Copy to
** CSS
** Data dir
** Date format
** Delete
** Display Email recipients
** Display mode
** Download
** Edit
** edit
** Email
** Email All
** Email message body
** Email notification
** Entries per page
** Filtered browsing
** Find
** Find Menu commands
** Fixed Attributes Edit
** Fixed Attributes Reply
** full
** Group
** Guest find menu commands
** Guest menu commands
** Help
** Help URL
** IOptions
** Icon comment
** Language
** Last day
** Locked Attributes
** Logbook dir
** Logbook Tabs
** Logbook tabs
** Logfile
** Login
** Logout
** Main tab
** Menu commands
** Message Height
** Message Width
** MOptions
** Move to
** New
** Number Attachments
** on 
** Options
** Page Title
** Password file =
** port
** Preset
** Quick filter
** Remove on reply
** Reply
** Required Attributes
** Resource dir
** Restrict edit
** Reverse sort
** ROptions
** Search all logbooks
** Self register
** SMTP host
** Search all logbooks
** Subdir
** Submit Page
** Subst
** Subst on reply subject
** Suppress default
** Suppress Email on edit
** Suppress Email to users
** Tab cellpadding
** Theme
** Thread display
** Thread Icon
** threaded
** Use Email From
** Use Email Subject
/C3"Elog MBA reserved attributes"
** %a %d %m %y
** %%Action
** %%BookName
** %%MessageID
** %%User
AsTo 
Author
By
Categorie
Category
Contract
DateUp
DosL
DosR
Dossier
** Email AdressesEmail
** Email AsTo
** Email Partner
Email1
FollowUp
Forms
Inotifie
Inotifie
Notify
Notify
Origin
Partner
Priorite
Priority
Qualify
ShellLogFile
ShellOnSubmit0
ShellOnSubmit1
ShellParam0
ShellParam1
ShellParamVerboseType
Status
Type
 | 
| 44 | Tue Jul  8 15:43:21 2014 | TimS | timpie_s@yahoo.com | Script | Re: Custom input forms implementation | Stable | Tue Mar 19 13:18:33 2013 by Stefan Ritt | 
| 
 
    
        
            | Stefan Ritt wrote:
 |  
            | Dear ELOG users, starting with SVN revision 2328, custom input forms are implemented. This allows application specific formats for check lists etc. In our specific case we had to implement a shift check list, which was quite long. Furthermore the check list should be optimized for an iPad, which we take in the field and record various checks and readings (in our case some gas pressure gauges at the PSI particle accelerator). Since the standard ELOG interface was too inflexible, a completely hand-written form was needed. The form can be activated by the new configuration options Custom New Form, Custom Edit Form and Custom Display Form, one for a new entry, an entry to edit and and entry to display. In our case we used the same form for all three cases. This is how the shift check list looks under the Safari Browser on a PC:  
 And here is how it looks on the iPad: 
 Each section can be collapsed and expanded (blue arrows at the left), and various internal checks are made before the check list can be submitted. Implementing such forms is however more something for the advanced user, since you have to hand-write HTML with CSS and JavaScript code. It can then however be a powerful method for check lists. Please find in the attachments the elogd.cfg configuration for that logbook and the shiftcheck.html source code file. It is a bit complicated since the page is a static page, elogd just serves it from the file. This requires all the dynamic functions to be implemented inside the HTML file with JavaScript. To display an entry for example, the JavaScript loads the raw data with the "?cmd=Download" command and the populates the form fields. The collapsing and expanding is done by using CSS properties. The integrated style sheet was optimized for the rendering on an iPad. Rather large fonts were chosen so that the items can be checked easily with your finger tips. Various parameters are sent between the browser and the elogd program via hidden fields and cookies. So only something for experts! But if you go through the effort and hand-write the form, it can be very handy. Note that you have to upgrade to SVN revision 2328 for the three new options.   |    That's awesome!! Didn't know ELOG was still being developed!!  I was looking for this ...been trying this version now withsupplied example but there's files missing which are being referenced from the html file.
 Anyway it would be nice to know a little more on how to use this and how it incorporates into ELOG. Is some more work being done on this version ? Thankx heaps for this great enhancement although now it's still needs a lot of figuring out on how to do this.
 | 
| 29 | Thu Nov 27 11:43:32 2008 | T. Ribbrock | emgaron+elog@ribbrock.org | Script | /etc/init.d/elog script for Debian-like distros | Stable |  | 
| The attached script was used by the Debian package (which is no longer maintained) to start/stop elogd. I have changed it based on some comments in the forum (see script) to add some more functionality. As there is no mainatined elog package for Debian anymore, I'm placing it here in the hope that it might come in handy for users who want to run elog under Debian. This script needs to be placed in /etc/init.d and expects elogd to be installed as /usr/sbin/elogd(can be changed, of course). | 
| Attachment 1: elog | 
| #!/bin/sh
# Init script for ELOG.
# Copyright © 2003, 2005  Recai Oktaş <roktas@omu.edu.tr>
#
# Additional changes by Thomas Ribbrock <emgaron@ribbrock.org>
# - 2008-11-27: Added better reload functionality, based on suggestion and
#   code from Yoshio Imai as posted in elog forum
#
# Licensed under the GNU General Public License, version 2.
# See the file `http://www.gnu.org/copyleft/gpl.txt'.
PATH=/sbin:/bin:/usr/sbin:/usr/bin
DAEMON=/usr/sbin/elogd
NAME=elogd
DESC="ELOG daemon"
test -f $DAEMON || exit 0
set -e
# Admin should be able to lock some options.
if [ -f /etc/default/elog ]; then
	. /etc/default/elog
fi
# To be in the safe side, the followings should be always defined.
PIDFILE=${PIDFILE:-/var/run/$NAME.pid}
CONFFILE=${CONFFILE:-/etc/elog.conf}
# Add the options to argument list only if defined previously.  Since
# some options may also be present in the conffile, we couldn't preset
# those options which would otherwise overwrite the settings in the
# conffile.  Also note that, all have reasonable compiled-in defaults.
ARGS="${PIDFILE+"-f $PIDFILE"}         \
      ${CONFFILE+"-c $CONFFILE"}       \
      ${LOGBOOKDIR+"-d $LOGBOOKDIR"}   \
      ${RESOURCEDIR+"-s $RESOURCEDIR"} \
      ${PORT+"-p $PORT"}               \
      ${HOST+"-n $HOST"}               \
      ${VERBOSE+"-v"}"
      
# Always run as a daemon.
ARGS=`echo $ARGS -D`
case "$1" in
	start)
		echo -n "Starting $DESC: "
		start-stop-daemon --start --quiet --pidfile $PIDFILE \
			--exec $DAEMON -- $ARGS 2>&1
		sleep 1
		if [ -f "$PIDFILE" ] && ps h `cat "$PIDFILE"` >/dev/null; then
			echo "$NAME."
		else
			echo "$NAME failed to start; check syslog for diagnostics."
			exit 1
		fi
		;;
	stop)
		echo -n "Stopping $DESC: $NAME"
		start-stop-daemon --oknodo --stop --quiet --pidfile $PIDFILE \
			--exec $DAEMON -- $ARGS 2>&1
		echo "."
		;;
	reload)
		# Send HUP signal to reload config file
		# (Only needed if config is edited manually and not via
		# webinterface)
		if [ -f $PIDFILE ]; then
			echo -n "$DESC to reread config file ... "
			kill -HUP `cat "$PIDFILE"`
			echo "done"
		else
			echo "No $PIDFILE found!"
		fi
		;;
	restart|force-reload)
		$0 stop
		sleep 1
		$0 start
		if [ "$?" != "0" ]; then
			exit 1
		fi
		;;
	*)
		N=/etc/init.d/$NAME
		echo "Usage: $N {start|stop|restart|reload|force-reload}" >&2
		exit 1
		;;
esac
exit 0
# vim:ai:sts=8:sw=8:
 | 
| 33 | Thu Feb  3 23:51:16 2011 | T. Ribbrock | emgaron+elog@ribbrock.org | Other | Building elog on OpenBSD | Stable |  | 
| Two things are required to get elog (tested with 2.8.1) to compile on OpenBSD (tested on OpenBSD 4.8): Step 1 - Patch Makefile: 
--- Makefile~ Mon Jan 24 21:38:09 2011
+++ Makefile Mon Jan 24 21:42:57 2011
@@ -50,6 +50,10 @@
 RM = /usr/bin/rm -f
 endif
+ifeq ($(OSTYPE),OpenBSD)
+LIBS += -lcrypto
+endif
+
 ifeq ($(OSTYPE),Darwin)
 OSTYPE=darwin
 endif
 Step 2 - Use "gmake" instead of the standard "make" to build.   | 
| 37 | Tue Aug 23 19:45:16 2011 | Stuart Wilkins | swilkins@bnl.gov | Script | ELOG Mail Parser | Alpha |  | 
|  Hi! I have attached a small script which can process an e-mail and submit this e-mail as a log entry. This is alpha at the moment but if you have suggestions or find bugs please let me know.  The easiest way to process this is to use the ".forward" file in unix. If this file contains the line: | "/usr/bin/python /home/tardis/elogmail/process.py --log /home/tardis/elogmail/mail.log -r -u http://localhost:8080/TARDIS -a Category=email -a Type=Log" This will pipe the incoming mail to the e-log running on the localhost with the experiment TARDIS. Attributes can be set using the "-a" switch like in the elog command line utility. To get help with all the options please run the script with the command: python process.py -h which will give help. Any questions, please don't hesitate to contact me, and I will do my best to help. Thanks again to Stefan for a great application. Best wishes, Stuart   | 
| Attachment 1: process.py.gz | 
| Attachment 2: forward.gz | 
| 9 | Wed Jul  7 18:19:10 2004 | Steve Jones | steve.jones@freescale.com | Script | Generic Unix elogd init script | Stable | Wed Jul  7 18:19:38 2004 by Steve Jones | 
| The elogd.init script that ships in the elog distribution is Linux centric.
 This script is written to work in a generic Unix environment under 'sh' -
no frills! | 
| Attachment 1: elogd.init | 
| #!/bin/sh
# description: Start elog
# elog can have multiple instances run on the same server, pointing to different logbook areas.  This start
# script should be run from the root of each different elog area.
ELOGD="/_TOOLS_/dist/gnu-elog-2.5.3/sparc-sun-solaris2.8/bin/elogd"
ELOGDIR="/proj/sysadmin/ess/www/elog"
HOSTNAME=`hostname`
# Check for the config file
if [ ! -f $ELOGDIR/elogd.cfg ]; then
    exit 0
fi
# See how we were called.
case "$1" in
  start)
        if [ -f $ELOGDIR/elogd-$HOSTNAME.pid ] ; then
	   pid=`cat ./elogd-$HOSTNAME.pid`
	   if [ -d /proc/$pid ] ; then
	     echo "elogd already running"
	     exit 1
	   fi
	fi
####################################
# The full path *must* be specified
	echo "Starting elogd: "
	$ELOGD -f $ELOGDIR/elogd-$HOSTNAME.pid -c $ELOGDIR/elogd.cfg -D  > /dev/null 2>&1 &
	RETVAL=$?
        if [ $RETVAL -eq 0  ] ; then 
          echo "elog started" 
        else
          echo "Failed to start elog"
        fi
	echo
	;;
  stop)
     echo ""
      if [ -f $ELOGDIR/elogd-$HOSTNAME.pid ] ; then
        echo "Stopping elogd: "
        kill `cat $ELOGDIR/elogd-$HOSTNAME.pid`
	rm -f $ELOGDIR/elogd-$HOSTNAME.pid
        echo "elog stopped"
        echo
     else
        echo "No elogd running?"
	echo "Failed to start elog"
	echo
     fi
     
	;;
  restart|reload)
	$0 stop
	$0 start
	;;
  *)
	echo "Usage: $0 {start|stop|restart}"
	exit 1
esac
exit 0
 | 
| 23 | Fri Jul 13 12:36:45 2007 | Stefan Ritt | stefan.ritt@psi.ch | Other | Re: Compiling elogd.c on HP-UX 64 bit | Beta | Thu Jul 12 09:38:47 2007 by Peter Rienstra | 
| I applied most of your patches to the elog source code, SVN revision 1885. The only missing piece has to do with seteuid/setuid. I definitively need seteuid for linux, because elogd might be started under root, then it falls back to an optional elog user. But when it stops, it has to restore the original root user in order to delete the PID file (/var/run/elogd.pid) which was created under root. If seteuid does not exist under HP-UX, you should add something like 
 #ifdef HP-UX
  setuid(...)
#else
  seteuid(...)
#endif Probably the HP-UX has to be something else, but I cannot test this since I don't have such an OS here. Once you get this working I can put it into the standard distribution.
 | 
| 25 | Mon Jul 16 15:57:47 2007 | Stefan Ritt | stefan.ritt@psi.ch | Other | Re: Compiling elogd.c on HP-UX 64 bit | Beta | Thu Jul 12 09:38:47 2007 by Peter Rienstra | 
| 
 | Peter Rienstra wrote: |  | HP-UX doesn't have the "seteuid" and "setegid" functions. But there are "setuid+setgid", "setreuid+setregid" and "setresuid+setresgid" functions available. | 
 
 I had a look and found that setreuid/setregid is also available under Linux, so I use those functions instead, which should also work on HP-UX. Can you check revision 1888 (http://savannah.psi.ch/viewcvs/trunk/src/elogd.c?root=elog&rev=1888), compile it and see if you can run it at least under your non-root account.
 | 
| 30 | Mon Jul 20 14:23:56 2009 | Stefan Ritt | stefan.ritt@psi.ch | Script | Doing mathematical calculations with attributes | Stable |  | 
| Following entry was written by Richard Stamper. I moved it here for persistency: On the matter of automatic calculation of fields, it is possible using included javascript but you have to do the work yourself.  For example, we have a log which computes responsivity as the ratio of a photocurrent and optical power.  With log attributes called "Photocurrent", "Optical Power" and "Responsivity" there is a file in the logbooks directory called photomixer_javascript.html containing something like:   <script>
 if (document.form1.Photocurrent) {document.form1.Photocurrent.onchange = new Function(
 "mod();"+
 "var power = parseFloat(document.form1.Optical_Power.value);"+
 "var current = parseFloat(document.form1.Photocurrent.value);"+
 "if (!isNan(power) && !isNan(current) && power != 0.0) {"+
 "  document.form1.Responsivity.value = Math.round(current/power*100)/100.0"+
 "}"
 );
 document.form1.Optical_Power.onchange = document.form1.Photocurrent.onchange;
 }
 </script>
 and the elogd.cfg file includes Bottom text = photomixer_javascript.html for the relevant log. The assignments to the onchange handlers are guarded because this javascript is included on all pages for that log, including the list pages where there is no such field as Photocurrent, (or Optical_Power) and the event handler function is defined dynamically for the same reason.   | 
| 39 | Fri Sep 17 06:19:39 2010 | Stefan Ritt | stefan.ritt@psi.ch | Script | Custom input forms implementation | Stable | Thu Jul  2 20:55:55 2015 by Stefan Ritt | 
| Dear ELOG users, starting with SVN revision 2328, custom input forms are implemented. This allows application specific formats for check lists etc. In our specific case we had to implement a shift check list, which was quite long. Furthermore the check list should be optimized for an iPad, which we take in the field and record various checks and readings (in our case some gas pressure gauges at the PSI particle accelerator). Since the standard ELOG interface was too inflexible, a completely hand-written form was needed. The form can be activated by the new configuration options Custom New Form, Custom Edit Form and Custom Display Form, one for a new entry, an entry to edit and and entry to display. In our case we used the same form for all three cases. This is how the shift check list looks under the Safari Browser on a PC: 
 And here is how it looks on the iPad: 
 Each section can be collapsed and expanded (blue arrows at the left), and various internal checks are made before the check list can be submitted. Implementing such forms is however more something for the advanced user, since you have to hand-write HTML with CSS and JavaScript code. It can then however be a powerful method for check lists. Please find in the attachments the elogd.cfg configuration for that logbook and the shiftcheck.html source code file. It is a bit complicated since the page is a static page, elogd just serves it from the file. This requires all the dynamic functions to be implemented inside the HTML file with JavaScript. To display an entry for example, the JavaScript loads the raw data with the "?cmd=Download" command and the populates the form fields. The collapsing and expanding is done by using CSS properties. The integrated style sheet was optimized for the rendering on an iPad. Rather large fonts were chosen so that the items can be checked easily with your finger tips. Various parameters are sent between the browser and the elogd program via hidden fields and cookies. So only something for experts! But if you go through the effort and hand-write the form, it can be very handy. Note that you have to upgrade to SVN revision 2328 for the three new options.   | 
| Attachment 2: elogd.cfg | 
| [global]
Port = 8080
Password file = passwd
[ShiftCheck]
Comment = Shift Check List
Attributes = Author, D, M, Y, Shift, a1, a2, a3, a4, a5, h1, h2, h3, h4, h5, c1, c2, c3, c4, c5, c6, c7, bb1, cr1, cr2, cr3, cr4, cr5, cr6, cr7, cr8, cr9, cr10, cr11, cr12, cr13, cr14, cr15, cr16, cr17, cr18, cr19, cr20, cr21, cr22, cr23, cr24, cr25, cr26, sw1, sw2, sw3, sw4, sw5
Quick filter = Shift, Author
Options Shift = Morning, Evening, Night
Enable attachments = 0
Show text = 0
Custom new form = /home/meg/meg/online/elog/shiftcheck.html
Custom edit form = /home/meg/meg/online/elog/shiftcheck.html
Custom display form = /home/meg/meg/online/elog/shiftcheck.html
List after submit = 1
 | 
| Attachment 4: shiftcheck.html | 
| Attachment 5: sc_up.png | 
|   | 
| Attachment 6: sc_down.png | 
|   | 
| 34 | Fri Feb  4 10:26:38 2011 | Stefan Ritt | stefan.ritt@psi.ch | Other | Re: Building elog on OpenBSD | Stable |  | 
| 
 
    
        
            | T. Ribbrock wrote: |  
            | Two things are required to get elog (tested with 2.8.1) to compile on OpenBSD (tested on OpenBSD 4.8): Step 1 - Patch Makefile: 
--- Makefile~ Mon Jan 24 21:38:09 2011
+++ Makefile Mon Jan 24 21:42:57 2011
@@ -50,6 +50,10 @@
 RM = /usr/bin/rm -f
 endif
+ifeq ($(OSTYPE),OpenBSD)
+LIBS += -lcrypto
+endif
+
 ifeq ($(OSTYPE),Darwin)
 OSTYPE=darwin
 endif
 Step 2 - Use "gmake" instead of the standard "make" to build.   |  Thanks, I added your patch to the distribution.  | 
| 36 | Tue Aug 23 12:07:51 2011 | Stefan Ritt | stefan.ritt@psi.ch | Script | Re: JavaScript list auto-refresh | Stable | Tue Jul 12 12:36:16 2005 by Emiliano Gabrielli | 
| 
 | Emiliano Gabrielli wrote: |  | Here is a simple piece of JS code to accomplish a smart page reload. We don't reload if in some kind of editing mode.
 
 You can put the code everywhere you like in the elog html page, my suggestion is to put it in Bottom Text (or Top Text):
 
 
 
;auto-refresh
Bottom text = [I]<script language="JavaScript">if (null==window.location.href.match('/[0-9]+$|.*(cmd|select)=.*') ) { window.setTimeout("location.reload();", 2*60*1000); now=new Date(); document.write('<br/>Last reload at '+now.getFullYear()+'/'+(now.getMonth()+1)+'/'+now.getDate()+', '+( ((h=now.getHours())<10) ? '0'+h :h)+':'+( ((m=now.getMinutes())<10) ? '0'+m :m)+':'+( ((s=now.getSeconds())<10) ? '0'+s :s)) }</script>[/I]
 the timer is a product of # of minutes, #of seconds and milliseconds... 2 minutes in the above example
  
 
 
 
 | Revision Tue Jul 12 12:36:16 2005 wrote: |  | modified regular expression in order to not activate the auto-refresh in the signle entry view
 
 | 
 | 
 
 Starting with SVN revision 2422, there is a new config option
 
 
 refresh = <seconds> 
 which lets you do the same thing.
 | 
| 41 | Mon Jan  7 16:37:21 2013 | Stefan Ritt | stefan.ritt@psi.ch | Script | Re: Server time offset | Stable |  | 
| 
 
    
        
            | Bruce Weber wrote: |  
            | Our server runs on local time, however, we require log entries to be in UTC (-0800hrs) - is there a command to achieve this? Your assistance will be much appreciated Thanks |  Have you tried   Subst <attribute> = $utcdate   Probably you need a dedicated attribute of type "datetime" and have to play with the "Date format" options. | 
| 155 | Fri Dec  1 16:30:46 2023 | Stefan Ritt | Unstefan.ritt@psi.ch | Other | Re: Fixing repeating first inline_image in email | Stable | Fri Dec  1 16:31:37 2023 by Stefan Ritt | 
| Unfortunately you made your changes against a pretty old version of elogd.c, so I can't see which changes you made (the diffs gives 100's of changes now). If you can apply your fix against the current elogd.cxx from the bitbucket repository, I would be happy to include the fix in the distribution. Stefan 
	
		
			| rami khrais wrote: |  
			| Fixing repeating first image in email (email notification) when the user submit a new log with in_line images. |    | 
| 4 | Fri Jun 13 17:10:48 2003 | Sridhar Anandakrishnan | sak@essc.psu.edu |  | submit emails to elog (along with MIME attachments) |  |  | 
| Attached is a perl script to which you can pipe a message (or a
single-message file) to submit that message to `elog'.  The `elog'
distribution includes two programs `elogd', which is the main daemon that is
accessed via the browser, and `elog', which is a command-line interface to
elogd.
The attached perl script `mailelog', will split a multipart MIME message
into its components and submit each as an attachment to elog to create a new
entry in a specified logbook.  The attributes are the subject, from, and cc
of the message.
Usage: mailelog [-|file] [-l logbook]
(if there are no arguments, read from stdin)
(makes a command that looks like this:
elog -p 8080 -h localhost -l emails -a subject=<subject> -a from=<from> -a
cc=<cc> -f attachment-1 -f attachment-2 -f ...
attachment-1 is the body of the message and attachment-2... are the actual
MIME attachments.  Set the elogd configuration to display attachments, so
that the message body is immediately visible.
Defaults: -h localhost -p 8080 -l emails
If no `-l logbook' flag is specified, then the entry is sent to the `emails'
logbook, so make sure that logbook exists.  Save this in, e.g,
~/bin/mailelog, and make sure it is executable (`chmod +x mailelog') and on
your path (bash: `export PATH=$HOME/bin:$PATH' or csh/tcsh: `setenv PATH
$HOME/bin:$PATH')
Bugs: multi-message files don't work.  can't add other attributes.  if the
logbook doesn't have attributes subject, from, cc, they are quietly lost. | 
| Attachment 1: mailelog | 
| #!/usr/bin/perl -w
=head1 NAME
doelog - save a mime message to elog
=head1 SYNOPSIS
    doelog [-l logbook] <mime-msg-file> <mime-msg-file> ...
    
    someprocess | doelog [-l logbook] -
=head1 DESCRIPTION
Takes one or more files from the command line that contain MIME
messages, and explodes their contents out into /tmp.  The parts
are sent to elog as attachments.
Modified mimeexplode of the MIME::Tools in perl, which see.
From mimeexplode:
"This was written as an example of the MIME:: modules in the
MIME-parser package I wrote.  It may prove useful as a quick-and-dirty
way of splitting a MIME message if you need to decode something, and
you don't have a MIME mail reader on hand."
=head1 COMMAND LINE OPTIONS
None yet.  
=head1 AUTHOR
sak@essc.psu.edu
=cut
BEGIN { unshift @INC, ".." }    # to test MIME:: stuff before installing it!
require 5.001;
use strict;
use vars qw($Msgno $cmd $default_logbook $tmpdir);
use MIME::Parser;
use Getopt::Std;
##
## $Id: doelog,v 1.4 2003/06/05 13:08:16 sak Exp sak $
## $Log: doelog,v $
## Revision 1.4  2003/06/05 13:08:16  sak
## Added a kludge to force elog to return if there is nothing piped to
## it.  Now you can use doelog either as a pipe or on a single-message file
##
## Revision 1.3  2003/06/05 12:37:49  sak
## Added "configuration section" to hold config variables like default
## logbook and tmpdir.
##
## Revision 1.2  2003/06/05 12:28:03  sak
## Allow up to 50 attachments
##
## Revision 1.1  2003/06/05 12:26:24  sak
## Initial revision
##
## CONFIGURATION SECTION
## base elog cmd
$cmd = "elog -h localhost -p 8080 ";
$default_logbook="emails";
$tmpdir="/tmp";
## END CONFIGURATION SECTION
#------------------------------------------------------------
# dump_entity - dump an entity's file info
#------------------------------------------------------------
sub dump_entity {
    my $ent = shift;
    my @parts = $ent->parts;
    my $file;
    
    die "too many attachments\n" if ($#parts>50);
    if (@parts) {        # multipart...
	map { dump_entity($_) } @parts;
    }
    else {               # single part...append to elog cmd
	$file = $ent->bodyhandle->path;
	$cmd .= "-f \"$file\" ";
	###print $cmd, "\n";
	###print "    Part: ", $ent->bodyhandle->path, 
	###      " (", scalar($ent->head->mime_type), ")\n";
    }
}
#------------------------------------------------------------
# main
#------------------------------------------------------------
sub main {
    my $file;
    my $entity;
    my $subject;
    my $from;
    my $cc;
    my $logbook;
    our($opt_l);
    # Sanity:
    ## (-w ".") or die "cwd not writable, you naughty boy...";
    ## check if user wants a particular logbook
    ## fix to add host and port?
    getopts('l:');
    if($opt_l) { $logbook=$opt_l;} else {$logbook=$default_logbook;}
    $cmd .= "-l $logbook ";
    
    # Go through messages:
    @ARGV or unshift @ARGV, "-";
    while (defined($file = shift @ARGV)) {
	# Create a new parser object:
	my $parser = new MIME::Parser;
    
	# Optional: set up parameters that will affect how it extracts 
	#   documents from the input stream:
	$parser->output_under($tmpdir);
    
	# Parse an input stream:
	open FILE, $file or die "couldn't open $file";
	$entity = $parser->read(\*FILE) or 
	    print STDERR "Couldn't parse MIME in $file; continuing...\n";
	close FILE;
	## get the subject, assumes all logbooks have a subject 
	## attribute - not necessarily true.  Mine do...
	if($subject = $entity->head->get('Subject', 0)) {
	    chomp($subject);
	    $cmd .= "-a subject=\'$subject\' ";
	}
	if($from = $entity->head->get('From', 0)) {
	    chomp($from);
	    $cmd .= "-a from=\'$from\' ";
	}
	if($cc = $entity->head->get('CC', 0)) {
	    chomp($cc);
	    $cmd .= "-a cc=\'$cc\' ";
	}
	##print $cmd, "\n";
	# Congratulations: you now have a (possibly multipart) MIME entity!
	dump_entity($entity) if $entity;
	### $entity->dump_skeleton if $entity;
	### print $cmd, "\n";
        ### kludge to force elog to return
	exec "$cmd<<EOF
EOF";
    }
    1;
}
exit (&main ? 0 : -1);
#------------------------------------------------------------
1;
 | 
| 10 | Fri Sep 24 23:14:47 2004 | Sridhar Anandakrishnan | sak@essc.psu.edu | Script | Perl script to forwar emails to elog | Alpha |  | 
| Takes one or more files from the command line that contain MIME
messages, and explodes their contents out into /tmp.  The parts
are sent to elog as attachments. | 
| Attachment 1: doelog | 
| #!/usr/bin/perl -w
=head1 NAME
doelog - save a mime message to elog
=head1 SYNOPSIS
    doelog <mime-msg-file> <mime-msg-file> ...
    
    someprocess | doelog -
=head1 DESCRIPTION
Takes one or more files from the command line that contain MIME
messages, and explodes their contents out into /tmp.  The parts
are sent to elog as attachments.
Modified mimeexplode of the MIME::Tools in perl
This was written as an example of the MIME:: modules in the
MIME-parser package I wrote.  It may prove useful as a quick-and-dirty
way of splitting a MIME message if you need to decode something, and
you don't have a MIME mail reader on hand.
=head1 COMMAND LINE OPTIONS
None yet.  
=head1 AUTHOR
sak@essc.psu.edu
=cut
BEGIN { unshift @INC, ".." }    # to test MIME:: stuff before installing it!
require 5.001;
use strict;
use vars qw($Msgno $cmd);
use MIME::Parser;
use Getopt::Std;
## these should be options too?
## base elog cmd
$cmd = "~/elog -h localhost -p 8080 ";
#------------------------------------------------------------
# dump_entity - dump an entity's file info
#------------------------------------------------------------
sub dump_entity {
    my $ent = shift;
    my @parts = $ent->parts;
    my $file;
    
    die "too many attachments\n" if ($#parts>10);
    if (@parts) {        # multipart...
	map { dump_entity($_) } @parts;
    }
    else {               # single part...append to elog cmd
	$file = $ent->bodyhandle->path;
	$cmd .= "-f \"$file\" ";
##	print $cmd, "\n";
##	print "    Part: ", $ent->bodyhandle->path, 
##	      " (", scalar($ent->head->mime_type), ")\n";
    }
}
#------------------------------------------------------------
# main
#------------------------------------------------------------
sub main {
    my $file;
    my $entity;
    my $subject;
    my $logbook;
    our($opt_l);
    # Sanity:
    ## (-w ".") or die "cwd not writable, you naughty boy...";
    ## check if user wants a particular logbook
    ## fix to add host and port?
    getopts('l:');
    if($opt_l) { $logbook=$opt_l;} else {$logbook="emails";}
    $cmd .= "-l $logbook ";
    
    # Go through messages:
    @ARGV or unshift @ARGV, "-";
    while (defined($file = shift @ARGV)) {
	# Create a new parser object:
	my $parser = new MIME::Parser;
    
	# Optional: set up parameters that will affect how it extracts 
	#   documents from the input stream:
	$parser->output_under("/tmp");
    
	# Parse an input stream:
	open FILE, $file or die "couldn't open $file";
	$entity = $parser->read(\*FILE) or 
	    print STDERR "Couldn't parse MIME in $file; continuing...\n";
	close FILE;
	## get the subject, assumes all logbooks have a subject 
	## attribute - not necessarily true.  Mine do...
	chomp($subject = $entity->head->get('Subject', 0));
	$cmd .= "-a subject=\"$subject\" ";
	print $cmd, "\n";
	# Congratulations: you now have a (possibly multipart) MIME entity!
	dump_entity($entity) if $entity;
	### $entity->dump_skeleton if $entity;
	### print $cmd, "\n";
	exec $cmd;
    }
    1;
}
exit (&main ? 0 : -1);
#------------------------------------------------------------
1;
 | 
| 42 | Mon Apr 29 04:29:33 2013 | Ryan Blakeslee | rb@blakesys.net | Theme/Skin | Clean plain-text CSS - modified from default.css | Stable | Mon Apr 29 23:34:40 2013 by Ryan Blakeslee | 
| Hello,
I am using ELOG 2.5.2. I had a real need for a simplified almost text-only version of the application.  For me 
personally, I like simple, minimalist and text-only as much as possible for the tools I use.  I personally found 
the layout with all the colors to be distracting from the content of each log entry.  Again this is ONLY my 
personal preference, NO offense meant. :-)
I took the default.css and modified it to achieve what I needed.  I am uploading here, the .css file.  It uses 
"blue" for some of the things such as attribute fields on single page view, etc.  but overall it's all clean, 
plain-text.
I don't know if this css will work on newer versions of ELOG (since I know i'm using an old one.)  But it's my 
hope that others like me, will find this modification very useful.
Thank you Stefan, and community -- this is an awesome tool, that I use in my business.  It's amazing how simple 
tools are always the most powerful and scale-able!  Fantastic, excellent job on this app. | 
| Attachment 1: plaintxt-blue.css | 
| \/* default formatting */
body {
  margin:3px;
  color:black;
  background-color:white;
  font-family:sans-serif;
}
/* standard link colors and decorations */
a:link { color:#0000FF; text-decoration:none }
a:visited { color:#0000FF; text-decoration:none }
a:hover { color:#0000FF; text-decoration:underline }
a:active { color:#0000FF; text-decoration:underline }
a:focus { color:#0000FF; text-decoration:underline }
td {
  color:black;
  font-family:sans-serif; 
}
/* frame table */
.frame {
  width:100%;
}
/* printable frame table */
.pframe {
  width:600;
}
/* standard formatting for logbook tabs */
.tabs {
  font-family:sans-serif;
  font-size:10pt;
  background-color:white;
}
/* logbook selection page */
.selframe {
  width:60%;
  background-color:#486090; 
  border:1px solid #486090;
  font-size:12pt;
}
.seltitle {
  border:1px solid #0000FF;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#CCCCFF;
  color:#486090;
  text-align:center;
}
.selexp {
  border:1px solid #0000FF;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#CCCCFF;
  color:#486090;
  text-align:left;
  font-size:10pt;
}
.selspace {
  width:2%;
  border:1px solid #308000;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#EEEEEE;
}
.selgroup {
  border:1px solid #308000;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#FFCCFF;
  padding:3px;
  text-align:left;
  font-weight:bold;
  font-size:14pt;
}
.sellogbook {
  border:1px solid #308000;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#DDEEBB;
  padding:3px;
  text-align:left;
  font-weight:bold;
}
.selcomment {
  font-size:8pt;
}
.selentries {
  background-color:#E0E0A0;
  border:1px solid #0000FF;
  border-top:1px solid white;
  border-left:1px solid white;
  text-align:center;
  font-size:10pt;
}
/* unselected and selected group tabs */
.gtab a {
  background-color:#B0E0B0;
  padding-left:5px;
  padding-right:5px;
}
.gtab {
  background-color:#B0E0B0;
  border-right:1px solid #409040;
}
.sgtab a {
  color:white;
  padding-left:5px;
  padding-right:5px;
}
.sgtab {
  background-color:#486090;
  color:white;
  border-right:1px solid #084070;
}
.sgtab a:visited { color:white; } /* bug for IE */
/* unselected and selected logbook tabs */
.ltab a {
  background-color:#E0E0E0;
  padding-left:5px;
  padding-right:5px;
}
.ltab {
  background-color:#E0E0E0;
  border-right:1px solid gray;
}
.sltab a {
  background-color:#486090;
  color:white;
  padding-left:5px;
  padding-right:5px;
}
.sltab {
  background-color:#486090;
  color:white;
  border-right:1px solid #084070;
}
.sltab a:visited { color:white; } /* bug for IE */
/* logbook title, left, middle and right cell */
.title1 {
  background-color:#486090;
  border-bottom:1px solid gray;
  border-top:1px solid #E0E0E0;
  border-left:1px solid #E0E0E0;
  color:white;
  font-size:medium;
  font-family:sans-serif;
  text-align:left;
}
.title1 a:visited { color:#A0FFA0; }
.title1 a:link { color:#A0FFA0; }
.title2 {
  background-color:#486090;
  border-bottom:1px solid black;
  border-top:1px solid #E0E0E0;
  color:white;
  font-size:medium;
  font-family:sans-serif;
  text-align:center;
}
.title3 {
  border-bottom:1px solid black;
  border-top:1px solid #E0E0E0;
  border-right:0px solid gray;
  background-color:#486090;
  text-align:left;
}
/* main menu row */
.menuframe {
  border:0px solid black;
  border-top:1px solid gray;
  border-right:0px solid gray;
  border-left:0px solid gray;
  padding:3px;
  background-color:white;
}
.menu1 {
  text-align:left;
  font-size:10pt;
}
.menu2a {
  text-align:left;
  font-size:10pt;
}
.menu2b {
  text-align:right;
  font-size:10pt;
}
.menu3 {
  text-align:left;
  font-size:8pt;
  font-weight:bold;
}
.menu4 {
  text-align:right;
  font-size:10pt;
  vertical-align:middle;
}
/* frame table in listings */
.listframe {
  border:0px solid gray;
  border-top:0px solid gray;
  border-left:0pc solid gray;
  background-color:white;
  border:0px;
}
/* title row in listing */
.listtitle {
  border:0px solid black;
  border-top:1px solid gray;
  border-left:0px solid gray;
  background-color:white;
  text-align:left;
}
/* attachment line */
.attachment {
  border-left:1px solid gray;
  border-right:1px solid gray;
  border-bottom:1px solid gray;
  background-color:#FFFFB0;
  text-align:left;
}
/* threaded listing */
.thread {
  border:0px solid gray;
  border-top:0px solid gray;
  border-left:0px solid gray;
  background-color:white;
}
.threadreply {
  border:0px solid #808040;
  border-top:0px solid white;
  border-left:0px solid white;
  background-color:white;
  text-align:left;
}
/* attribute names and values on single message page */
.attribhead {
  background-color:white;
  border:0px solid gray;
  border-top:1px solid gray;
  border-bottom:1px solid gray;
  border-left:0px solid gray;
  padding:0px;
  font-size:12pt;
  font-family:sans-serif;
}
.attribname {
  width:150px;
  background-color:#486090;
  color:white;
  padding-left:5px;
  padding-right:5px;
  padding:3px;
  border:1px solid white;
}
.attribvalue {
... 225 more lines ... | 
| Attachment 2: summary.png | 
|   | 
| Attachment 3: full.png | 
|   | 
| Attachment 4: single-view.png | 
|   | 
| Attachment 5: find.png | 
|   | 
| 6 | Wed Sep 17 11:43:44 2003 | R. Beekman | rbeekman@hiscom.nl |  | ELOG v2.3.9 CSS cross-reference (used for skins) | Beta | September 17, 2003 by R. Beekman | 
| For all you guys (and girls;-) who want to add skins to ELOG, it is 
important to know what will be affected if you change a style.
So I made a cross reference of styles vs. html pages.
In the attached ZIP file you will find:
--> "ELOG CSS xref.xls" (Microsoft Excel spreadsheet)
--> "ELOG CSS xref.pdf" (PDF file for those who do not have Excel)
--> A directory containing the html pages I documented and the ELOG 
stylesheet (.css-file) that you need when you want to see the html files. 
Images are not included: they are not needed for this purpose.
I know that not all pages are documented, but Stefan told me that there is 
no complete list of all pages because they are generated. So I documented 
only the pages I need at this moment.
Please feel free to mail me when you have comments, corrections or 
additions. | 
| Attachment 1: ELOG CSS xref.zip | 
| 22 | Wed Jul 11 11:13:16 2007 | Peter Rienstra | peter.rienstra@gmail.com | Other | Compiling elogd.c on HP-UX 64 bit | Beta | Thu Jul 12 09:38:47 2007 by Peter Rienstra | 
| We succeeded in compiling and running elogd (elog-2.6.5) on HP-UX 64 bit Itanium platform (HP-UX B.11.23 U ia64). 
 The main problem was we got a core dump after starting elogd. The cause was that the memory has be allocated with a 4 byte boundary. This could be the case on other 64 bit platforms as well. A colleague of mine (Sander Notting) found the solution.
 
 Unzip and untar the zip file (elog-latest.tar.gz)
 Go to the src directory (elog-2.6.5/src)
 
 Edit elogd.c
 
 Replace all:
 
 show_selection_page(NULL);                 =>      show_selection_page();
 seteuid                                    =>      setuid
 setegid                                    =>      setgid
 
 On line 564:
 void *buffer                               =>      char *buffer
 
 
 Line 645, add the text in bold:
 
 void *xmalloc(size_t bytes)
 {
 char *temp;
 
 /* Align buffer on 4 byte boundery for HP UX and other 64 bit systems to prevent  Bus error(core dump)*/
 if (bytes & 3)
 bytes += 4 - (bytes & 3);
 
 temp = (char *) malloc(bytes + 12);
 
 
 After that compile:
 
 cc -w -c -o regex.o regex.c
 cc -w -c -o mxml.o ../../mxml/mxml.c
 cc -w -c -o strlcpy.o ../../mxml/strlcpy.c
 cc -I../../mxml -o elogd elogd.c regex.o mxml.o strlcpy.o
 
 We didn't try to run elogd under root yet.
 | 
| Attachment 1: elogdhpux64.c.gz | 
| 24 | Mon Jul 16 15:27:08 2007 | Peter Rienstra | peter.rienstra@gmail.com | Other | Re: Compiling elogd.c on HP-UX 64 bit | Beta | Thu Jul 12 09:38:47 2007 by Peter Rienstra | 
| Stefan, 
 First I want to say I really like your program. We work in a small group of 5 database administrators, and this is exactly what we need to inform each other. Elog is simple but very functional, so thanks!
 
 
 My problem is that I don't have root access to the HP-UX machines. We don't run elogd as root, so I wasn't really interested in the seteuid functionality, I just wanted to compile and run the program.
 
 HP-UX doesn't have the "seteuid" and "setegid" functions. But there are "setuid+setgid", "setreuid+setregid" and "setresuid+setresgid" functions available. I'm not sure which one is the best to use. I uploaded the manpages as attachment. I hope this will help you.
 
 If you want I can do a compile and run test on HP-UX with your altered source code. But I can't do a test with "root".
 
 
 
 
 
 | Stefan Ritt wrote: |  | I applied most of your patches to the elog source code, SVN revision 1885. The only missing piece has to do with seteuid/setuid. I definitively need seteuid for linux, because elogd might be started under root, then it falls back to an optional elog user. But when it stops, it has to restore the original root user in order to delete the PID file (/var/run/elogd.pid) which was created under root. If seteuid does not exist under HP-UX, you should add something like 
 #ifdef HP-UX
  setuid(...)
#else
  seteuid(...)
#endif Probably the HP-UX has to be something else, but I cannot test this since I don't have such an OS here. Once you get this working I can put it into the standard distribution.
 | 
 | 
| Attachment 1: man_setuid.txt | 
| 
 setuid(2)							   setuid(2)
 NAME
      setuid(), setgid() - set user and group IDs
 SYNOPSIS
      #include <unistd.h>
      int setuid(uid_t uid);
      int setgid(gid_t gid);
 DESCRIPTION
      setuid() sets the real-user-ID (ruid), effective-user-ID (euid),
      and/or saved-user-ID (suid) of the calling process.  If the Security
      Containment product is installed, these interfaces treat a process
      observing CHSUBJIDENT as a privileged process.  Otherwise, only
      processes with an euid of zero are treated as privileged processes.
      See privileges(5) for more information on Security Containment and
      fine-grained privileges.
      The following conditions govern setuid's behavior:
	   +  If the process is privileged, setuid() sets the ruid, euid,
	      and suid to uid.
	   +  If the process is not privileged and the argument uid is equal
	      to the ruid or the suid, setuid() sets the euid to uid; the
	      ruid and suid remain unchanged.  (If a set-user-ID program is
	      not running as superuser, it can change its euid to match its
	      ruid and reset itself to the previous euid value.)
	   +  If the process is not privileged, the argument uid is equal to
	      the euid, and the calling process has the PRIV_SETRUGID
	      privilege, setuid() sets the ruid to uid; the euid and suid
	      remain unchanged.
      setgid() sets the real-group-ID (rgid), effective-group-ID (egid),
      and/or saved-group-ID (sgid) of the calling process.  The following
      conditions govern setgid()'s behavior:
	   +  If the process is privileged, setgid() sets the rgid and egid
	      to gid.
	   +  If the process is not privileged and the argument gid is equal
	      to the rgid or the sgid, setgid() sets the egid to gid; the
	      rgid and sgid remain unchanged.
	   +  If the process is not privileged, the argument gid is equal to
	      the egid, and the calling process has the PRIV_SETRUGID
	      privilege, setgid() sets the rgid to gid; the egid and sgid
	      remain unchanged.
 Hewlett-Packard Company	    - 1 -      HP-UX 11i Version 2: May 2006
 setuid(2)							   setuid(2)
    Security Restrictions
      Some or all of the actions associated with this system call require
      the CHSUBJIDENT privilege.  Processes owned by the superuser have this
      privilege.  Processes owned by other users may have this privilege,
      depending on system configuration.
      See privileges(5) for more information about privileged access on
      systems that support fine-grained privileges.
 RETURN VALUE
      Upon successful completion, setuid() and setgid() return 0; otherwise,
      they return -1 and set errno to indicate the error.
 ERRORS
      setuid() and setgid() fail and return -1 if any of the following
      conditions are encountered:
	   [EPERM]	  None of the conditions above are met.
	   [EINVAL]	  uid (gid) is not a valid user (group) ID.
 WARNINGS
      It is recommended that the PRIV_SETRUGID capability be avoided, as it
      is provided for backward compatibility.  This feature may be modified
      or dropped from future HP-UX releases.  When changing the real user ID
      and real group ID, use of setresuid() and setresgid() (see
      setresuid(2)) is recommended instead.
 AUTHOR
      setuid() was developed by AT&T, the University of California,
      Berkeley, and HP.
      setgid() was developed by AT&T.
 SEE ALSO
      exec(2), getuid(2), setresuid(2), privileges(5).
 STANDARDS CONFORMANCE
      setuid(): AES, SVID2, SVID3, XPG2, XPG3, XPG4, FIPS 151-2, POSIX.1
      setgid(): AES, SVID2, SVID3, XPG2, XPG3, XPG4, FIPS 151-2, POSIX.1
 Hewlett-Packard Company	    - 2 -      HP-UX 11i Version 2: May 2006
 | 
| Attachment 2: man_setreuid.txt | 
| 
 setreuid(2)							 setreuid(2)
 NAME
      setreuid - set real and effective user IDs
 SYNOPSIS
      #include <unistd.h>
      int setreuid(uid_t ruid, uid_t euid);
 DESCRIPTION
      The setreuid() function sets the real and effective user IDs of the
      current process to the values specified by the ruid and euid
      arguments. If ruid or euid is -1, the corresponding effective or real
      user ID of the current process is left unchanged.
      A process with appropriate privileges can set either ID to any value.
      An unprivileged process can only set the effective user ID if the euid
      argument is equal to either the real, effective, or saved user ID of
      the process.
      It is unspecified whether a process without appropriate privileges is
      permitted to change the real user ID to match the current real,
      effective or saved user ID of the process.
 RETURN VALUE
      Upon successful completion, 0 is returned. Otherwise, -1 is returned
      and errno is set to indicate the error.
 ERRORS
      The setreuid() function will fail if:
	   [EINVAL]		    The value of the ruid or euid argument
				    is invalid or out-of-range.
	   [EPERM]		    The current process does not have
				    appropriate privileges, and either an
				    attempt was made to change the effective
				    user ID to a value other than the real
				    user ID or the saved set-user-ID or an
				    attempt was made to change the real user
				    ID to a value not permitted by the
				    implementation.
 SEE ALSO
      getuid(2), setuid(2), <unistd.h>.
 CHANGE HISTORY
      First released in Issue 4, Version 2.
 Hewlett-Packard Company	    - 1 -   HP-UX 11i Version 2: August 2003
 | 
| Attachment 3: man_setresuid.txt | 
| 
 setresuid(2)							setresuid(2)
 NAME
      setresuid, setresgid - set real, effective, and saved user and group
      IDs
 SYNOPSIS
      #include <unistd.h>
      int setresuid(uid_t ruid, uid_t euid, uid_t suid);
      int setresgid(gid_t rgid, gid_t egid, gid_t sgid);
 DESCRIPTION
      setresuid() sets the real, effective and/or saved user ID of the
      calling process.
      If the current real, effective or saved user ID is equal to that of a
      user having appropriate privileges, setresuid() sets the real,
      effective and saved user IDs to ruid, euid, and suid, respectively.
      Otherwise, setresuid() only sets the real, effective, and saved user
      IDs if ruid, euid, and suid each match at least one of the current
      real, effective, or saved user IDs.
      If ruid, euid, or suid is -1, setresuid() leaves the current real,
      effective or saved user ID unchanged.
      setresgid() sets the real, effective and/or saved group ID of the
      calling process.
      If the current real, effective or saved user ID is equal to that of a
      user having appropriate privileges, setresgid() sets the real,
      effective, and saved group ID to rgid, egid, and sgid, respectively.
      Otherwise, setresgid() only sets the real, effective and saved group
      ID if rgid, egid, and sgid each match at least one of the current
      real, effective or saved group ID.
      If rgid, egid, or sgid is -1, setresgid() leaves the current real,
      effective or saved group ID unchanged.
    Security Restrictions
      Some or all of the actions associated with this system call require
      the PRIV_CHSUBJIDENT privilege (CHSUBJIDENT).  Processes owned by the
      superuser will have this privilege.  Processes owned by other users
      may have this privilege, depending on system configuration.  See
      privileges(5) for more information about privileged access on systems
      that support fine-grained privileges.
 RETURN VALUE
      Upon successful completion, setresuid() and setresgid() return 0;
      otherwise, they return -1 and set errno to indicate the error.
 Hewlett-Packard Company	    - 1 -      HP-UX 11i Version 2: May 2005
 setresuid(2)							setresuid(2)
 ERRORS
      setresuid() and setresgid() fail if any of the following conditions
      are encountered:
	   [EINVAL]	  ruid, euid, or suid (rgid, egid, or sgid) is not a
			  valid user (group) ID.
	   [EPERM]	  None of the conditions above are met.
 AUTHOR
      setresuid() and setresgid() were developed by HP.
 SEE ALSO
      exec(2), getuid(2), setuid(2).
 Hewlett-Packard Company	    - 2 -      HP-UX 11i Version 2: May 2005
 | 
| 26 | Mon Jul 16 16:43:07 2007 | Peter Rienstra | peter.rienstra@gmail.com | Other | Re: Compiling elogd.c on HP-UX 64 bit | Beta | Thu Jul 12 09:38:47 2007 by Peter Rienstra | 
| 
 
 I downloaded revision 1888. There were no problems compiling it. It's running on the HP-UX system now and everything seems to work fine.
  | 
| 16 | Wed Sep  7 16:52:30 2005 | Peter Eriksson | peter@ifm.liu.se | Other | Solaris 10 SMF/Greenline management manifest for ELog | Stable |  | 
| Please find enclosed as an attachment a Solaris 10 SMF/Greenline manifest that can be used to manage ELog. (If you don't know what it is - it replaces init.d/cron/inittab and more stuff)
 | 
| Attachment 1: elog.xml | 
| <?xml version="1.0"?>
<!DOCTYPE service_bundle SYSTEM "/usr/share/lib/xml/dtd/service_bundle.dtd.1">
<!--
	Copyright (c) 2005-06-17 Peter Eriksson (peter@ifm.liu.se)
	This manifest can be used to manage an elog daemon using the 
	Solaris SMF subsystem.
	Import this manifest using: 
		svccfg -v import elog.xml
	
        Then activate the daemon with:
		svcadm enable site/elog
-->
<service_bundle type='manifest' name='IFM:elog'>
<service
	name='site/elog'
	type='service'
	version='1'>
        <single_instance />
	<!-- Need / & /usr filesystems mounted, /var mounted read/write -->
	<dependency
		name='fs-local'
		type='service'
		grouping='require_all'
		restart_on='none'>
		<service_fmri value='svc:/system/filesystem/local' />
	</dependency>
        <dependency
            name='network-service'
            grouping='require_all'
            restart_on='none'
            type='service'>
                <service_fmri value='svc:/network/service' />
        </dependency>
        <dependency
            name='name-services'
            grouping='require_all'
            restart_on='refresh'
            type='service'>
                <service_fmri value='svc:/milestone/name-services' />
        </dependency>
	
	<exec_method
		type='method'
		name='start'
		exec='/ifm/sbin/elogd -D -c /ifm/etc/elogd.cfg'
		timeout_seconds='60'>
	</exec_method>
	<exec_method
		type='method'
		name='stop'
		exec=':kill'
		timeout_seconds='30'>
	</exec_method>
	<instance name='default' enabled='false' />
	<stability value='Evolving' />
	<template>
		<common_name>
			<loctext xml:lang='C'>
			Electronic Logbook server
			</loctext>
		</common_name>
		<documentation>
			<manpage title='elogd' section='1' manpath='/usr/local/man' />
		</documentation>
	</template>
</service>
</service_bundle>
 | 
| 31 | Tue Dec 15 20:11:27 2009 | Michel Bovey | bovey (a) slf ch | Documentation | Sorting dates before and after "Sun Sep  9 > 03:46:39 CEST 2001" | Alpha |  | 
| BACKGROUNG
ELOG is storage date and time in unix time: seconds after epoch (Thu Jan  1 00:00:00 UTC 1970).
    date -u -d @0
On "Sun Sep  9 03:46:39 CEST 2001" the unix time counter is passing from a presentation of 9 digits to 10 digits.
    date -d @999999999
 
ISSUE
For sorting dates ELOG is using the character representation of the unix time. When ELOG contains dates on both
side of this 9 - 10 digits border sorting get confused.
 
WORKAROUND
in adding a leading 0 (zero) to the internal storage of dates in ELOG files we get over this problem.
On unix based system in can be easily achived with a sed command against the .log files:
    sed -i 's/modification: 9/modification: 09/g' *.log | 
| 148 | Mon Mar 11 09:28:15 2019 | Maurat | gm001@free.fr | Script | Code change for LDAP authentication | Stable | Mon Mar 11 10:15:43 2019 by Maurat | 
| Hi, I had to change code to authenticate users in my organization's LDAP directory. Indeed, accounts are distributed under several organizational units in my LDAP directory.  The current version of the code can't authenticate accounts when these are in different organizational units. Hence my contribution. I Use a read account to request LDAP to locate the account that has logged in (with e-mail address in the search filter). I get the number of LDAP entries. If I have one entry then I call ldap_get_dn function to get the DN account and then I call ldap_simple_bind_s using the account's DN and password to perform LDAP authentication. I changed configuration file elogd.cfg. I added two parameters:  LDAP DN user = <DN read account>
 LDAP PW user = <password read account>
 I changed code auth.c too (see attached file)
 I had to change Makefile. I added a call to lber library
 
ifdef USE_LDAP
 ifneq ($(USE_LDAP),0)
 CFLAGS += -DHAVE_LDAP
 LIBS += -lldap -llber
 endif
 endif
 Have good day
           | 
| Attachment 1: auth.c | 
| /********************************************************************\
  Name:         auth.c
  Created by:   Stefan Ritt
  Copyright 2000 + Stefan Ritt
  ELOG 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
  (at your option) any later version.
  ELOG is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  GNU General Public License for more details.
  You should have received a copy of the GNU General Public License
  along with ELOG.  If not, see <http://www.gnu.org/licenses/>.
  Contents:     Authentication subroutines. Currently supported:
                - password file authentication
                - kerberos5 password authentication
  $Id: elog.c 2350 2010-12-23 10:45:10Z ritt $
\********************************************************************/
#include "elogd.h"
#ifdef HAVE_KRB5
#include <krb5.h>
#endif
#ifdef HAVE_LDAP
#include <ldap.h>
LDAP *ldap_ld;
char ldap_login_attr[64];
char ldap_dn_user[256];
char ldap_pw_user[64];
char ldap_userbase[256];
char ldap_bindDN[512];
#endif  /* HAVE_LDAP */
extern LOGBOOK *lb_list;
/*==================================================================*/
/*---- Kerberos5 routines ------------------------------------------*/
#ifdef HAVE_KRB5
int auth_verify_password_krb5(LOGBOOK * lbs, const char *user, const char *password, char *error_str,
                              int error_size)
{
   char *princ_name, str[256], realm[256];
   krb5_error_code error;
   krb5_principal princ;
   krb5_context context;
   krb5_creds creds;
   krb5_get_init_creds_opt options;
   if (krb5_init_context(&context) < 0)
      return FALSE;
   strlcpy(str, user, sizeof(str));
   if (getcfg(lbs->name, "Kerberos Realm", realm, sizeof(realm))) {
      strlcat(str, "@", sizeof(str));
      strlcat(str, realm, sizeof(str));
   }
   if ((error = krb5_parse_name(context, str, &princ)) != 0) {
      strlcpy(error_str, "<b>Kerberos error:</b>... 318 more lines ...", error_size);
      strlcat(error_str, krb5_get_error_message(context, error), error_size);
      strlcat(error_str, ".
 Please check your Kerberos configuration.", error_size);
      return FALSE;
   }
   error = krb5_unparse_name(context, princ, &princ_name);
   if (error) {
      strlcpy(error_str, "<b>Kerberos error:</b>
 ", error_size);
      strlcat(error_str, krb5_get_error_message(context, error), error_size);
      strlcat(error_str, ".
 Please check your Kerberos configuration.", error_size);
      return FALSE;
   }
   sprintf(str, "Using %s as server principal for authentication", princ_name);
   write_logfile(lbs, str);
   memset(&options, 0, sizeof(options));
   krb5_get_init_creds_opt_init(&options);
   memset(&creds, 0, sizeof(creds));
   error = krb5_get_init_creds_password(context, &creds, princ,
                                        (char *) password, NULL, NULL, 0, NULL, &options);
   krb5_free_context(context);
   if (error && error != KRB5KDC_ERR_PREAUTH_FAILED && error != KRB5KDC_ERR_C_PRINCIPAL_UNKNOWN) {
      sprintf(error_str, "<b>Kerberos error %d:</b>
 ", error);
      strlcat(error_str, krb5_get_error_message(context, error), error_size);
      strlcat(error_str, ".
 Please check your Kerberos configuration.", error_size);
      return FALSE;
   }
   if (error)
      return FALSE;
   return TRUE;
}
int auth_change_password_krb5(LOGBOOK * lbs, const char *user, const char *old_pwd, const char *new_pwd,
                              char *error_str, int error_size)
{
   char *princ_name, str[256], realm[256];
   int result_code, n;
   krb5_error_code error;
   krb5_data result_code_string, result_string;
   krb5_principal princ;
   krb5_context context;
   krb5_creds creds;
   krb5_get_init_creds_opt options;
   if (krb5_init_context(&context) < 0)
      return FALSE;
   strlcpy(str, user, sizeof(str));
   if (getcfg(lbs->name, "Kerberos Realm", realm, sizeof(realm))) {
      strlcat(str, "@", sizeof(str));
      strlcat(str, realm, sizeof(str));
   }
   if ((error = krb5_parse_name(context, str, &princ)) != 0) {
      strlcpy(error_str, "<b>Kerberos error:</b>
 ", error_size);
      strlcat(error_str, krb5_get_error_message(context, error), error_size);
      strlcat(error_str, ".
 Please check your Kerberos configuration.", error_size);
      return FALSE;
   }
   error = krb5_unparse_name(context, princ, &princ_name);
   sprintf(str, "Using %s as server principal for authentication", princ_name);
   write_logfile(lbs, str);
   memset(&options, 0, sizeof(options));
   krb5_get_init_creds_opt_init(&options);
   krb5_get_init_creds_opt_set_tkt_life(&options, 300);
   krb5_get_init_creds_opt_set_forwardable(&options, FALSE);
   krb5_get_init_creds_opt_set_proxiable(&options, FALSE);
   memset(&creds, 0, sizeof(creds));
   error = krb5_get_init_creds_password(context, &creds, princ,
                                        (char *) old_pwd, NULL, NULL, 0, "kadmin/changepw", &options);
   if (error) {
      strlcpy(error_str, "<b>Kerberos error:</b>
 ", error_size);
      strlcat(error_str, krb5_get_error_message(context, error), error_size);
      strlcat(error_str, ".
 Please check your Kerberos configuration.", error_size);
      return FALSE;
   }
   error = krb5_set_password(context, &creds, (char *) new_pwd, princ,
                             &result_code, &result_code_string, &result_string);
   if (error) {
      strlcpy(error_str, "<b>Kerberos error:</b>
 ", error_size);
      strlcat(error_str, krb5_get_error_message(context, error), error_size);
      strlcat(error_str, ".
 Please check your Kerberos configuration.", error_size);
      return FALSE;
   }
   if (result_code > 0) {
      if (result_code_string.length > 0) {
         strlcpy(error_str, result_code_string.data, error_size);
         if ((int) result_code_string.length < error_size)
            error_str[result_code_string.length] = 0;
      }
      if (result_string.length > 0) {
         strlcat(error_str, ": ", error_size);
         n = strlen(error_str) + result_string.length;
         strlcat(error_str, result_string.data, error_size);
         if (n < error_size)
            error_str[n] = 0;
      }
   }
   krb5_free_data_contents(context, &result_code_string);
   krb5_free_data_contents(context, &result_string);
   krb5_free_cred_contents(context, &creds);
   krb5_get_init_creds_opt_free(context, &options);
   krb5_free_context(context);
   if (result_code > 0)
      return FALSE;
   return TRUE;
}
#endif
/*---- LDAP routines ------------------------------------------*/
#ifdef HAVE_LDAP
int ldap_init(LOGBOOK *lbs, char *error_str, int error_size)
{
   char str[512], ldap_server[256];
   int version;
   int bind=0;
   
   // Read Config file
   if (getcfg(lbs->name, "LDAP server", ldap_server, sizeof(ldap_server))) {
      strlcpy(str, ldap_server, sizeof(str));
   }
   else   {
      strlcpy(error_str, "<b>LDAP initialization error</b>
 ", error_size);
      strlcat(error_str, "
 Please check your LDAP configuration.", error_size);
      strlcat(str, "ERR: Cannot find LDAP server entry!", sizeof(str));
      write_logfile(lbs, str);
      return FALSE;
   }
   
   if (!getcfg(lbs->name, "LDAP userbase", ldap_userbase, sizeof(ldap_userbase))) {
      strlcpy(error_str, "<b>LDAP initialization error</b>
 ", error_size);
      strlcat(error_str, "
 Please check your LDAP configuration.", error_size);
      strlcat(str, ", ERR: Cannot find LDAP userbase (e.g. \'ou=People,dc=example,dc=org\')!", sizeof(str));
      write_logfile(lbs, str);
      return FALSE;
   }
   
   if (!getcfg(lbs->name, "LDAP login attribute", ldap_login_attr, sizeof(ldap_login_attr))) {
      strlcpy(error_str, "<b>LDAP initialization error</b>
 ", error_size);
      strlcat(error_str, "
 Please check your LDAP configuration.", error_size);
      strlcat(str, ", ERR: Cannot find LDAP login attribute (e.g. uid, cn, ...)!", sizeof(str));
      write_logfile(lbs, str);
      return FALSE;
   }
   if (!getcfg(lbs->name, "LDAP DN User", ldap_dn_user, sizeof(ldap_dn_user))) {
      strlcpy(error_str, "<b>LDAP initialization error</b>
 ", error_size);
      strlcat(error_str, "
 Please check your LDAP configuration.", error_size);
      strlcat(str, ", ERR: Cannot find LDAP login attribute (e.g. uid, cn, ...)!", sizeof(str));
      write_logfile(lbs, str);
      return FALSE;
   }
   
   if (!getcfg(lbs->name, "LDAP PW User", ldap_pw_user, sizeof(ldap_pw_user))) {
      strlcpy(error_str, "<b>LDAP initialization error</b>
 ", error_size);
      strlcat(error_str, "
 Please check your LDAP configuration.", error_size);
      strlcat(str, ", ERR: Cannot find LDAP login attribute (e.g. uid, cn, ...)!", sizeof(str));
      write_logfile(lbs, str);
      return FALSE;
   }
   // Initialize/open LDAP connection
   if(ldap_initialize( &ldap_ld, ldap_server )) {
      perror("ldap_initialize");
      strlcpy(error_str, "<b>LDAP initialization error</b>
 ", error_size);
      strlcat(error_str, "
 Please check your LDAP configuration.", error_size);
      return FALSE;
   }
   // Use the LDAP_OPT_PROTOCOL_VERSION session preference to specify that the client is LDAPv3 client
   version = LDAP_VERSION3;
   ldap_set_option(ldap_ld, LDAP_OPT_PROTOCOL_VERSION, &version);
   
   write_logfile(lbs, str);
   
   return TRUE;
}
int auth_verify_password_ldap(LOGBOOK *lbs, const char *user, const char *password, char *error_str,
                              int error_size)
{  LDAPMessage *result, *err, *entry;
   int bind=0, i, rc=0, nb=0;
   char str[512], filter[512];
   char *attribute , *dn;
   BerElement *ber;
   BerValue **values;
    ldap_ld = NULL;
    memset(&ldap_bindDN[0], 0, sizeof(ldap_bindDN));
   struct timeval timeOut = {3,0}; // 3 second connection/search timeout
   // zerotime.tv_sec = zerotime.tv_usec = 0L;
   
   if(!ldap_init(lbs,error_str,error_size)) {
      strlcpy(error_str, "<b>LDAP initialization error</b>
 ", error_size);
      strlcat(error_str, "
 Please check your LDAP configuration.", error_size);
      return FALSE;
   }
  
      printf("\n dn: %s\n", ldap_dn_user );
   //Bind with read account
   bind = ldap_simple_bind_s(ldap_ld, ldap_dn_user, ldap_pw_user, LDAP_AUTH_SIMPLE);
   if(bind != LDAP_SUCCESS) {
      strlcpy(error_str, "<b>LDAP BIND error with read account</b>
 ", error_size);
      strlcat(error_str, "
 Please check your LDAP configuration.", error_size);
      return FALSE;
   }
   // search user
   sprintf(filter, "(%s=%s)", ldap_login_attr, user);
   rc = ldap_search_ext_s(
          ldap_ld,             // LDAP session handle
          ldap_userbase,       // Search Base
 | 
| 19 | Sat Oct 21 02:23:17 2006 | Leo Souza | leo@leo.com | Documentation | teste abc | Stable | 1.0 | 
| alksjdkajklasjdas | 
| 150 | Fri Feb 21 19:05:18 2020 | Laurent Jean-Rigaud | lollspam@free.fr | Other | RPM build process enhancements | Stable | Fri Feb 21 19:14:53 2020 by Laurent Jean-Rigaud | 
| Hi Stefan, I enclosed a patch for RPM build process available on GIT. changes : 
	rpmbuild :
	
		checks if provider or custom build (the rm/mv are done on your computers only :-))call rpmbuild with version / release given as parameterselog.spec :
	
		last changelog entry date is set to build datebuild with debug for debuginfo rpms (product rpms are normally automatically strimmed)elog.init call /etc/ini.d/functions for RHEL/Centos/Fedora/? dists   Todo: 
	add RPMbuild options for ldap/pam/...enclosed git log in changelog automatically (the dream :-)) | 
| Attachment 1: elog_patch_for_4936b76915d63a9ebb3788d50d62faadf49cdb6b.patch | 
| diff --git a/buildrpm b/buildrpm
index 9d21f4a..dba7067 100755
--- a/buildrpm
+++ b/buildrpm
@@ -12,7 +12,7 @@ set release = $argv[2]
 set dir = /tmp/elog-$version
 set archive = elog-$version-$release.tar.gz
 
-perl -wapi.bak -e 's&^(Version:\s+).*$&${1}'"${version}"'&;s&^(Release:\s+).*$&${1}'"${release}"'&;' elog.spec
+#perl -wapi.bak -e 's&^(Version:\s+).*$&${1}'"${version}"'&;s&^(Release:\s+).*$&${1}'"${release}"'&;' elog.spec
 
 # create temporary directory
 rm -Rf $dir
@@ -68,19 +68,33 @@ rm -Rf $dir
 
 # transfer archive
 echo Transfer archive...
-cp /tmp/$archive ~ritt/html/elog/download/tar/
-cp /tmp/$archive ~ritt/html/elog/download/tar/elog-latest.tar.gz
 cp /tmp/$archive ~/rpmbuild/SOURCES/elog-$version.tar.gz
-cd ~ritt/elog
-cp -f doc/ChangeLog ~ritt/html/elog/download/ChangeLog
+# If Stefan...
+if ( -d /home/ritt ) then
+  echo "Manager mode"
+  if ( -d ~ritt/html/elog/download/tar ) then
+    cp /tmp/$archive ~ritt/html/elog/download/tar/
+    cp /tmp/$archive ~ritt/html/elog/download/tar/elog-latest.tar.gz
+    cd ~ritt/elog
+    cp -f doc/ChangeLog ~ritt/html/elog/download/ChangeLog
+  endif
+endif
+cd -
 rm -f /tmp/$archive
 
+echo Cleanup $version-$release rpms
+rm -f ~/rpmbuild/RPMS/*/elog*${version}-${release}*.rpm
+rm -f ~/rpmbuild/SRPMS/elog*${version}-${release}*.rpm
 # building RPMs
-echo Build RPMs...
-rm -f ~/rpmbuild/RPMS/x86_64/*
-rm -f ~/rpmbuild/SRPMS/*
-rpmbuild -ba elog.spec || exit $?
-cp ~/rpmbuild/RPMS/x86_64/elog*rpm ~ritt/html/elog/download/RPMS/
-cp ~/rpmbuild/RPMS/x86_64/elog-$version-$release.x86_64.rpm ~ritt/html/elog/download/RPMS/elog-latest.x86_64.rpm
-cp ~/rpmbuild/SRPMS/elog*rpm ~ritt/html/elog/download/SRPMS/
-cp ~/rpmbuild/SRPMS/elog-$version-$release.src.rpm ~ritt/html/elog/download/SRPMS/elog-latest.src.rpm
+echo Build RPMs..
+rpmbuild -ba --define "version ${version}" --define "release ${release}" elog.spec || exit $?
+
+# If Stefan...
+if ( -d /home/ritt ) then
+  if ( -d ~ritt/html/elog/download/tar ) then
+    cp ~/rpmbuild/RPMS/x86_64/elog*rpm ~ritt/html/elog/download/RPMS/
+    cp ~/rpmbuild/RPMS/x86_64/elog-$version-$release.x86_64.rpm ~ritt/html/elog/download/RPMS/elog-latest.x86_64.rpm
+    cp ~/rpmbuild/SRPMS/elog*rpm ~ritt/html/elog/download/SRPMS/
+    cp ~/rpmbuild/SRPMS/elog-$version-$release.src.rpm ~ritt/html/elog/download/SRPMS/elog-latest.src.rpm
+  endif
+endif
diff --git a/elog.spec b/elog.spec
index 16add8f..8397eab 100755
--- a/elog.spec
+++ b/elog.spec
@@ -1,9 +1,13 @@
-# OpenSSH privilege separation requires a user & group ID
+# ELOG weblog application
+# rpmbuild -ba --define 'version 3.1.4' --define 'release 2' --define "date $(LC_TIME=En date '+%a %b %d %Y')" elog.spec
+ 
+#define	date	$(LC_TIME=En date '+%a %b %d %Y')      
+%define build_timestamp %(LC_TIME=En date '+%a %b %d %Y')
 
 Name:       elog
 Summary:    elog is a standalone electronic web logbook
-Version:    3.1.4
-Release:    2
+Version:    %version
+Release:    %release%{?dist}
 License:    GPL
 Group:      Applications/Networking
 Source:     http://elog.psi.ch/elog/download/elog-%{version}.tar.gz
@@ -41,6 +45,8 @@ access control, etc. Moreover, a single server can host several weblogs, and
 each weblog can be totally different from the rest. 
 
 %changelog
+* %{build_timestamp} Stefan Ritt <stefan.ritt@psi.ch> %version-%release
+- Updated from git 
 * Wed Sep 26 2018 Stefan Ritt <stefan.ritt@psi.ch>
 - Made adjustments for new elog server and RH7
 * Fri Aug 29 2014 Stefan Ritt <stefan.ritt@psi.ch>
@@ -72,7 +78,7 @@ each weblog can be totally different from the rest.
    -g elog -M -r elog 2>/dev/null || :
 
 %build
-make
+make CFLAGS='-O3 -funroll-loops -fomit-frame-pointer -W -Wall -Wno-deprecated-declarations -Imxml -g'
 sed "s#\@PREFIX\@#%{prefix}#g" elogd.init_template > elogd.init
 
 %install
diff --git a/elogd.init b/elogd.init
index 5d4e7ee..e04143c 100644
--- a/elogd.init
+++ b/elogd.init
@@ -6,6 +6,9 @@
 # config: /usr/local/elog/elogd.cfg
 # pidfile: /var/run/elogd.pid
 
+# RHEL
+[ -f /etc/init.d/functions ] && . /etc/init.d/functions
+
 # Check for the config file
 if [ ! -f /usr/local/elog/elogd.cfg ]; then
     exit 0
diff --git a/elogd.init_template b/elogd.init_template
index e94b5d7..bb1b330 100755
--- a/elogd.init_template
+++ b/elogd.init_template
@@ -6,6 +6,9 @@
 # config: @PREFIX@/elog/elogd.cfg
 # pidfile: /var/run/elogd.pid
 
+# RHEL
+[ -f /etc/init.d/functions ] && . /etc/init.d/functions
+
 # Check for the config file
 if [ ! -f @PREFIX@/elog/elogd.cfg ]; then
     exit 0
 | 
| 151 | Mon Mar  2 14:31:12 2020 | Laurent Jean-Rigaud | lollspam@free.fr | Other | Re: RPM build process enhancements | Stable | Wed Mar  4 18:40:40 2020 by Laurent Jean-Rigaud | 
| Hi Stefan, 2nd patch for RPM build which adds : 
	dynamic build options for krb5/ldap/pam/ssl support :
	
		for git / non rpm users : 
		
			buildrpm version release [-krb5] [-ldap] [-pam] [-ssl]for rpm users using SRPMS (dependances are managed) :
		
			rpm -i elog-ver-rel.src.rpm && rpmbuld -bb [--use krb5] [--use ldap] [--use pam] [--use ssl] ~/rpmbuild/SPECS/elog.specdynamic 2 last changelog entries :
	
		last with build information with
		
			dynamic user 's info (use your info if builded from PSI, or use %packager from ~/.rpmmacros if exists, or set to username username@ostname)build options list (KBR5, LDAP, PAM, SSL)before last for product changelog of current ELOG version-releasecustomrel flag for local rebuild :
	
		release = %elogrel%{?customrel}%{?dist)so custom builder can add --define 'customrel NSA'  at rpmbuild command or in .rpmmacros file -> elog-3.1.4-2.NSA.el7.x86_64.rpm by example.elog version and release are delivered in specfile as default for rebuild (tarball name uses it so it can not be changed for local rebuild from SRPMS).buildrpm uses ~/rpmbuild/SPECS/elog.spec generated from elog.spec.template (elog.spec is deleted in repo, replaced by elog.spec.template).   Tested on EL6 and EL7 x86_64 :-) Bye   
	
		
			| Laurent Jean-Rigaud wrote: |  
			| Hi Stefan, I enclosed a patch for RPM build process available on GIT. changes : 
				rpmbuild :
				
					checks if provider or custom build (the rm/mv are done on your computers only :-))call rpmbuild with version / release given as parameterselog.spec :
				
					last changelog entry date is set to build datebuild with debug for debuginfo rpms (product rpms are normally automatically strimmed)elog.init call /etc/ini.d/functions for RHEL/Centos/Fedora/? dists   Todo: 
				add RPMbuild options for ldap/pam/...enclosed git log in changelog automatically (the dream :-)) |    | 
| Attachment 1: elog-git_dd35f04ec8effce1c12927078a9efb59822ceb3f-add_use_options.diff | 
| diff --git a/Makefile b/Makefile
index d8eecba..87cb502 100644
--- a/Makefile
+++ b/Makefile
@@ -23,16 +23,32 @@ RCDIR      = $(ROOT)/etc/rc.d/init.d
 SRVDIR     = $(ROOT)/usr/lib/systemd/system
 
 # flag for SSL support
+ifdef USESSL
 USE_SSL    = 1
+else
+USE_SSL    = 0
+endif
 
 # flag for Kerberos support, please turn on if you need Kerberos
+ifdef USEKRB5
+USE_KRB5   = 1
+else
 USE_KRB5   = 0
+endif
 
 # flag for LDAP support, please turn on if you need LDAP
+ifdef USELDAP
+USE_LDAP   = 1
+else
 USE_LDAP   = 0
+endif
 
 # flag for PAM support, please turn on if you need PAM
+ifdef USEPAM
+USE_PAM    = 1
+else
 USE_PAM    = 0
+endif
 
 #############################################################
 
diff --git a/buildrpm b/buildrpm
index 1c0b9bc..8dde819 100755
--- a/buildrpm
+++ b/buildrpm
@@ -1,17 +1,38 @@
 #!/bin/csh
-# Usage: build [-n] <version> <release>
+# Usage: build [-n] <version> <release> [-krb5] [-ldap] [-pam] [-ssl]
 # Build ELOG distribution
 
 if ($#argv < 2) then
-  echo "Usage: build <version> <release>"
+  echo "Usage: build <version> <release> [-krb5] [-ldap] [-pam] [-ssl]"
   exit
 endif
  
 set version = $argv[1]
 set release = $argv[2]
+set i = 0
+set BUILDOPTS=""
+foreach argument ($argv)
+  set i=`expr $i + 1`
+  if ($i <= 2) continue
+  switch ($argument)
+    case "-ldap":
+       set BUILDOPTS="$BUILDOPTS --with ldap"
+       breaksw
+    case "-pam":
+       set BUILDOPTS="$BUILDOPTS --with pam"
+       breaksw
+    case "-ssl":
+       set BUILDOPTS="$BUILDOPTS --with ssl"
+       breaksw
+    case "-krb5":
+       set BUILDOPTS="$BUILDOPTS --with krb5"
+       breaksw
+  endsw
+end
+
 set dist = `rpm --eval %{\?dist}`
 set dir = /tmp/elog-$version
-set archive = elog-$version.tar.gz
+set archive = elog-$version-$release.tar.gz
 
 # create temporary directory
 rm -Rf $dir
@@ -65,7 +86,8 @@ rm -Rf $dir
 
 # transfer archive
 echo Transfer archive...
-mkdir -p ~/rpmbuild/SOURCES && cp /tmp/$archive ~/rpmbuild/SOURCES/elog-$version.tar.gz
+[ ! -d ~/rpmbuild/SOURCES ] && mkdir -p ~/rpmbuild/SOURCES 
+cp /tmp/$archive ~/rpmbuild/SOURCES/elog-$version-$release.tar.gz
 
 # if running on at PSI copy to download area
 if (`hostname` == 'elog01.psi.ch') then
@@ -75,6 +97,8 @@ if (`hostname` == 'elog01.psi.ch') then
     cp -v /tmp/$archive ~ritt/html/elog/download/tar/elog-latest.tar.gz
     cp -vf doc/ChangeLog ~ritt/html/elog/download/ChangeLog
   endif
+  # define Factory Packager
+  set BUILDOPTS="${BUILDOPTS} --define \"packager Stefan Ritt <stefan.ritt@psi.ch>\""
 endif
 rm -f /tmp/$archive
 
@@ -83,8 +107,13 @@ rm -f ~/rpmbuild/RPMS/*/elog*${version}-${release}*.rpm
 rm -f ~/rpmbuild/SRPMS/elog*${version}-${release}*.rpm
 
 # building RPMs
+cp elog.spec.template ~/rpmbuild/SPECS/elog.spec
+sed -i "s/__ELOGVER__/${version}/;s/__ELOGREL__/${release}/" ~/rpmbuild/SPECS/elog.spec
 echo Build RPMs...
-rpmbuild -ba --define "version ${version}" --define "release ${release}" elog.spec || exit $?
+set factorydate = `env LC_TIME=C date '+%a %b %d %Y'`
+rpmbuild -ba ${BUILDOPTS} --define "factorydate ${factorydate}" \
+	--define "version ${version}" --define "elogrel ${release}" \
+	~/rpmbuild/SPECS/elog.spec || exit $?
 
 # if running on at PSI copy to download area
 if (`hostname` == 'elog01.psi.ch') then
diff --git a/elog.spec b/elog.spec
deleted file mode 100755
index 8397eab..0000000
--- a/elog.spec
+++ /dev/null
@@ -1,107 +0,0 @@
-# ELOG weblog application
-# rpmbuild -ba --define 'version 3.1.4' --define 'release 2' --define "date $(LC_TIME=En date '+%a %b %d %Y')" elog.spec
- 
-#define	date	$(LC_TIME=En date '+%a %b %d %Y')      
-%define build_timestamp %(LC_TIME=En date '+%a %b %d %Y')
-
-Name:       elog
-Summary:    elog is a standalone electronic web logbook
-Version:    %version
-Release:    %release%{?dist}
-License:    GPL
-Group:      Applications/Networking
-Source:     http://elog.psi.ch/elog/download/elog-%{version}.tar.gz
-Vendor:     Stefan Ritt <stefan.ritt@psi.ch>
-URL:        http://elog.psi.ch/elog
-BuildRoot:  /tmp/%{name}-root
-Prefix:     /usr/local
-BuildRequires: openssl-devel >= 0.9.8e
-
-%description
-ELOG is part of a family of applications known as weblogs. 
-Their general purpose is : 
-
-1. To make it easy for people to put information online in a chronological
-   fashion, in the form of short, time-stamped text messages ("entries") 
-   with optional HTML markup for presentation, and optional file attachments 
-   (images, archives, etc.) 
-
-2. To make it easy for other people to access this information through a 
-   Web interface, browse entries, search, download files, and optionally add, 
-   update, delete or comment on entries. 
-
-ELOG is a remarkable implementation of a weblog in at least two respects : 
-
-- Its simplicity of use: you don't need to be a seasoned server operator 
-and/or an experimented database administrator to run ELOG ; one executable 
-file (under Unix or Windows), a simple configuration text file, and it works. 
-No Web server or relational database required. It is also easy to translate 
-the interface to the appropriate language for your users. 
-
-- Its versatility: through its single configuration file, ELOG can be made 
-to display an infinity of variants of the weblog concept. There are options 
-for what to display, how to display it, what commands are available and to whom, 
-access control, etc. Moreover, a single server can host several weblogs, and 
-each weblog can be totally different from the rest. 
-
-%changelog
-* %{build_timestamp} Stefan Ritt <stefan.ritt@psi.ch> %version-%release
-- Updated from git 
-* Wed Sep 26 2018 Stefan Ritt <stefan.ritt@psi.ch>
-- Made adjustments for new elog server and RH7
-* Fri Aug 29 2014 Stefan Ritt <stefan.ritt@psi.ch>
-- Added BuildRequires, thanks to Stefan Roiser from CERN
-* Fri Oct 21 2005 Stefan Ritt <stefan.ritt@psi.ch>
-- Added resources/ directory
-* Fri Mar 14 2003 Stefan Ritt <stefan.ritt@psi.ch>
-- Added %post to change ownership of elog files
-* Thu Jan 30 2003 Stefan Ritt <stefan.ritt@psi.ch>
-- Added installation of man pages, thanks to Serge Droz <serge.droz@psi.ch>
-* Tue Aug 13 2002 Stefan Ritt <stefan.ritt@psi.ch>
-- Added elog group and user, thanks to Nicolas Chuche [nchuche@teaser.fr]
-* Tue Jun 18 2002 Stefan Ritt <stefan.ritt@psi.ch>
-- Put elogd.init into TAR file, add logbooks directory, put elogd in sbin/
-* Tue Jun 18 2002 Serge Droz <serge.droz@psi.ch>
-- Update to 2.0.0
-* Mon Jun  3 2002 Serge Droz <serge.droz@psi.ch>
-- Update to 1.3.6 
-* Fri May 31 2002 Serge Droz <serge.droz@psi.ch>
-- Initial RPM
-
-
-%prep
-%setup -q
-
-%pre
-%{_sbindir}/groupadd -r elog 2>/dev/null || :
-%{_sbindir}/useradd -d / -s /bin/false \
-   -g elog -M -r elog 2>/dev/null || :
-
-%build
-make CFLAGS='-O3 -funroll-loops -fomit-frame-pointer -W -Wall -Wno-deprecated-declarations -Imxml -g'
-sed "s#\@PREFIX\@#%{prefix}#g" elogd.init_template > elogd.init
-
-%install
-make install ROOT=$RPM_BUILD_ROOT MANDIR=$RPM_BUILD_ROOT%{_mandir}
-
-%post
-chown -R elog:elog $RPM_BUILD_ROOT%{prefix}/elog
-
-%clean
-rm -rf $RPM_BUILD_ROOT
-
-%files
-%defattr(-,root,root)
-/etc/rc.d/init.d/elogd
-%{_mandir}/man1/*
-%{_mandir}/man8/*
-%doc	README COPYING doc
-%defattr(-,elog,elog)
-%prefix/bin/*
-%prefix/sbin/elogd
-%prefix/elog/resources
-%prefix/elog/ssl
-%prefix/elog/themes
-%prefix/elog/scripts
-%prefix/elog/logbooks
-%config(noreplace) %prefix/elog/elogd.cfg
diff --git a/elog.spec.template b/elog.spec.template
--- a/elog.spec.template
+++ b/elog.spec.template
0a1,139
> # ELOG weblog application
> # rpmbuild -ba --define 'elogver 3.1.4' --define 'elogrel 2' --with ssl --with pam --with ldap --with krb5 --define 'factorydate date'
>  
> # define date of build for changelog and default release
> %define build_timestamp %(LC_TIME=C date '+%a %b %d %Y')
> %{!?factorydate: %define factorydate %build_timestamp}
> 
> # default version and release
> %{!?elogver: %define elogver __ELOGVER__ }
> %{!?elogrel: %define elogrel __ELOGREL__ }
> # default release is build date
> %{!?elogrel: %define elogrel %{build_timestamp} }
> 
> # Build options :
> # Read: If neither macro exists, then add the default definition.
> %{?_with_krb5: %define _with_krb5 USEKRB5=1}
> %{?_with_ldap: %define _with_ldap USELDAP=1}
> %{?_with_pam: %define _with_pam USEPAM=1}
> %{?_with_ssl: %define _with_ssl USESSL=1}
> # Default build options are with SSL 
> %{!?_with_ssl: %{!?_without_ssl: %define _with_ssl USESSL=1}}
> # builder info
> %define whoami %(eval who am i | awk '{print $1}')
> %define HOSTNAME %(hostname)
> %{!?packager: %define packager %{whoami} %{whoami}@%{HOSTNAME}}
> 
> Name:       elog
> Summary:    elog is a standalone electronic web logbook
> Version:    %elogver
> Release:    %elogrel%{?customrel}%{?dist}
> License:    GPL
> Group:      Applications/Networking
> Source:     http://elog.psi.ch/elog/download/elog-%{elogver}-%{elogrel}.tar.gz
> Vendor:     Stefan Ritt <stefan.ritt@psi.ch>
> URL:        http://elog.psi.ch/elog
> BuildRoot:  /tmp/%{name}-root
> Prefix:     /usr/local
> # Add build dependencies for pam, ssl and ldap features if enabled.
> # Note: Tag tokens must start at beginning-of-line.
> #
> # Read: If feature is enabled, then add the build dependency.
> %{?_with_krb5:BuildRequires: krb5-devel}
> %{?_with_krb5:Requires: krb5-libs}
> %{?_with_ldap:BuildRequires: openldap-devel >= 2.4.1}
> %{?_with_ldap:Requires: openldap >= 2.4.1}
> %{?_with_pam:BuildRequires: pam-devel >= 1.1.1}
> %{?_with_ssl:BuildRequires: openssl-devel >= 0.9.8e}
> 
> %description
> ELOG is part of a family of applications known as weblogs. 
> Their general purpose is : 
> 
> 1. To make it easy for people to put information online in a chronological
>    fashion, in the form of short, time-stamped text messages ("entries") 
>    with optional HTML markup for presentation, and optional file attachments 
>    (images, archives, etc.) 
> 
> 2. To make it easy for other people to access this information through a 
>    Web interface, browse entries, search, download files, and optionally add, 
>    update, delete or comment on entries. 
> 
> ELOG is a remarkable implementation of a weblog in at least two respects : 
> 
> - Its simplicity of use: you don't need to be a seasoned server operator 
> and/or an experimented database administrator to run ELOG ; one executable 
> file (under Unix or Windows), a simple configuration text file, and it works. 
... 74 more lines ... | 
| 152 | Wed Mar  4 18:40:57 2020 | Laurent Jean-Rigaud | lollspam@free.fr | Other | Re: Re: RPM build process enhancements | Stable | Wed Mar  4 18:45:05 2020 by Laurent Jean-Rigaud | 
| Sorry, the patch is malformed for the template file. Check PJ. Bye, Laurent   
	
		
			| Laurent Jean-Rigaud wrote: |  
			| Hi Stefan, 2nd patch for RPM build which adds : 
				dynamic build options for krb5/ldap/pam/ssl support :
				
					for git / non rpm users : 
					
						buildrpm version release [-krb5] [-ldap] [-pam] [-ssl]for rpm users using SRPMS (dependances are managed) :
					
						rpm -i elog-ver-rel.src.rpm && rpmbuld -bb [--use krb5] [--use ldap] [--use pam] [--use ssl] ~/rpmbuild/SPECS/elog.specdynamic 2 last changelog entries :
				
					last with build information with
					
						dynamic user 's info (use your info if builded from PSI, or use %packager from ~/.rpmmacros if exists, or set to username username@ostname)build options list (KBR5, LDAP, PAM, SSL)before last for product changelog of current ELOG version-releasecustomrel flag for local rebuild :
				
					release = %elogrel%{?customrel}%{?dist)so custom builder can add --define 'customrel NSA'  at rpmbuild command or in .rpmmacros file -> elog-3.1.4-2.NSA.el7.x86_64.rpm by example.elog version and release are delivered in specfile as default for rebuild (tarball name uses it so it can not be changed for local rebuild from SRPMS).buildrpm uses ~/rpmbuild/SPECS/elog.spec generated from elog.spec.template (elog.spec is deleted in repo, replaced by elog.spec.template).   Tested on EL6 and EL7 x86_64 :-) Bye   
				
					
						| Laurent Jean-Rigaud wrote: |  
						| Hi Stefan, I enclosed a patch for RPM build process available on GIT. changes : 
							rpmbuild :
							
								checks if provider or custom build (the rm/mv are done on your computers only :-))call rpmbuild with version / release given as parameterselog.spec :
							
								last changelog entry date is set to build datebuild with debug for debuginfo rpms (product rpms are normally automatically strimmed)elog.init call /etc/ini.d/functions for RHEL/Centos/Fedora/? dists   Todo: 
							add RPMbuild options for ldap/pam/...enclosed git log in changelog automatically (the dream :-)) |    |    | 
| Attachment 1: elog.spec.template | 
| # ELOG weblog application
# rpmbuild -ba --define 'elogver 3.1.4' --define 'elogrel 2' --with ssl --with pam --with ldap --with krb5 --define 'factorydate date'
 
# define date of build for changelog and default release
%define build_timestamp %(LC_TIME=C date '+%a %b %d %Y')
%{!?factorydate: %define factorydate %build_timestamp}
# default version and release
%{!?elogver: %define elogver __ELOGVER__ }
%{!?elogrel: %define elogrel __ELOGREL__ }
# default release is build date
%{!?elogrel: %define elogrel %{build_timestamp} }
# Build options :
# Read: If neither macro exists, then add the default definition.
%{?_with_krb5: %define _with_krb5 USEKRB5=1}
%{?_with_ldap: %define _with_ldap USELDAP=1}
%{?_with_pam: %define _with_pam USEPAM=1}
%{?_with_ssl: %define _with_ssl USESSL=1}
# Default build options are with SSL 
%{!?_with_ssl: %{!?_without_ssl: %define _with_ssl USESSL=1}}
# builder info
%define whoami %(eval who am i | awk '{print $1}')
%define HOSTNAME %(hostname)
%{!?packager: %define packager %{whoami} %{whoami}@%{HOSTNAME}}
Name:       elog
Summary:    elog is a standalone electronic web logbook
Version:    %elogver
Release:    %elogrel%{?customrel}%{?dist}
License:    GPL
Group:      Applications/Networking
Source:     http://elog.psi.ch/elog/download/elog-%{elogver}-%{elogrel}.tar.gz
Vendor:     Stefan Ritt <stefan.ritt@psi.ch>
URL:        http://elog.psi.ch/elog
BuildRoot:  /tmp/%{name}-root
Prefix:     /usr/local
# Add build dependencies for pam, ssl and ldap features if enabled.
# Note: Tag tokens must start at beginning-of-line.
#
# Read: If feature is enabled, then add the build dependency.
%{?_with_krb5:BuildRequires: krb5-devel}
%{?_with_krb5:Requires: krb5-libs}
%{?_with_ldap:BuildRequires: openldap-devel >= 2.4.1}
%{?_with_ldap:Requires: openldap >= 2.4.1}
%{?_with_pam:BuildRequires: pam-devel >= 1.1.1}
%{?_with_ssl:BuildRequires: openssl-devel >= 0.9.8e}
%description
ELOG is part of a family of applications known as weblogs. 
Their general purpose is : 
1. To make it easy for people to put information online in a chronological
   fashion, in the form of short, time-stamped text messages ("entries") 
   with optional HTML markup for presentation, and optional file attachments 
   (images, archives, etc.) 
2. To make it easy for other people to access this information through a 
   Web interface, browse entries, search, download files, and optionally add, 
   update, delete or comment on entries. 
ELOG is a remarkable implementation of a weblog in at least two respects : 
- Its simplicity of use: you don't need to be a seasoned server operator 
and/or an experimented database administrator to run ELOG ; one executable 
file (under Unix or Windows), a simple configuration text file, and it works. 
No Web server or relational database required. It is also easy to translate 
the interface to the appropriate language for your users. 
- Its versatility: through its single configuration file, ELOG can be made 
to display an infinity of variants of the weblog concept. There are options 
for what to display, how to display it, what commands are available and to whom, 
access control, etc. Moreover, a single server can host several weblogs, and 
each weblog can be totally different from the rest. 
%changelog
* %{build_timestamp} %{packager} %{version}-%{release}
- rebuild with option(s): %{?_with_krb5:KRB5 }%{?_with_ldap:LDAP }%{?_with_pam:PAM }%{?_with_ssl:SSL}
* %{factorydate} Stefan Ritt <stefan.ritt@psi.ch> %{version}-%{release}
- Updated from git 
* Wed Sep 26 2018 Stefan Ritt <stefan.ritt@psi.ch>
- Made adjustments for new elog server and RH7
* Fri Aug 29 2014 Stefan Ritt <stefan.ritt@psi.ch>
- Added BuildRequires, thanks to Stefan Roiser from CERN
* Fri Oct 21 2005 Stefan Ritt <stefan.ritt@psi.ch>
- Added resources/ directory
* Fri Mar 14 2003 Stefan Ritt <stefan.ritt@psi.ch>
- Added %post to change ownership of elog files
* Thu Jan 30 2003 Stefan Ritt <stefan.ritt@psi.ch>
- Added installation of man pages, thanks to Serge Droz <serge.droz@psi.ch>
* Tue Aug 13 2002 Stefan Ritt <stefan.ritt@psi.ch>
- Added elog group and user, thanks to Nicolas Chuche [nchuche@teaser.fr]
* Tue Jun 18 2002 Stefan Ritt <stefan.ritt@psi.ch>
- Put elogd.init into TAR file, add logbooks directory, put elogd in sbin/
* Tue Jun 18 2002 Serge Droz <serge.droz@psi.ch>
- Update to 2.0.0
* Mon Jun  3 2002 Serge Droz <serge.droz@psi.ch>
- Update to 1.3.6 
* Fri May 31 2002 Serge Droz <serge.droz@psi.ch>
- Initial RPM
%prep
%setup -q
%pre
%{_sbindir}/groupadd -r elog 2>/dev/null || :
%{_sbindir}/useradd -d / -s /bin/false \
   -g elog -M -r elog 2>/dev/null || :
%build
make %{?_with_ssl} %{?_with_pam} %{?_with_ldap} %{?_with_krb5} CFLAGS='-O3 -funroll-loops -fomit-frame-pointer -W -Wall -Wno-deprecated-declarations -Imxml -g'
sed "s#\@PREFIX\@#%{prefix}#g" elogd.init_template > elogd.init
%install
make install ROOT=$RPM_BUILD_ROOT MANDIR=$RPM_BUILD_ROOT%{_mandir}
%post
chown -R elog:elog $RPM_BUILD_ROOT%{prefix}/elog
%clean
rm -rf $RPM_BUILD_ROOT
%files
%defattr(-,root,root)
/etc/rc.d/init.d/elogd
%{_mandir}/man1/*
%{_mandir}/man8/*
%doc	README COPYING doc
%defattr(-,elog,elog)
%prefix/bin/*
%prefix/sbin/elogd
%prefix/elog/resources
%prefix/elog/ssl
%prefix/elog/themes
%prefix/elog/scripts
%prefix/elog/logbooks
%config(noreplace) %prefix/elog/elogd.cfg
 | 
| 149 | Sat Jun 15 06:13:07 2019 | John | secondcomingtechnologies@fastmail.com | Script | Re: Custom input forms implementation | Stable | Sat Jun 15 06:19:24 2019 by John | 
| I have been trying to get my head around this application module. I assume that after the input is done on this example (ShiftCheck), if goes into the  usual file system directorys for storage? Or is it (or can it) goto another db like sql, flat, etc.?  I also assume that the 'normal' Elog screens we see for input (and output), would be a completely seperate module that you have for (ShiftCheck).. but we do not see them here (as one of the attachments)? I am asking these questions because I am trying to recreate this (type) of input/output system for users, so I would like to know how the 'whole picture' is done with your example here. Thanx again. 
	
		
			| Stefan Ritt wrote: |  
			| Dear ELOG users, starting with SVN revision 2328, custom input forms are implemented. This allows application specific formats for check lists etc. In our specific case we had to implement a shift check list, which was quite long. Furthermore the check list should be optimized for an iPad, which we take in the field and record various checks and readings (in our case some gas pressure gauges at the PSI particle accelerator). Since the standard ELOG interface was too inflexible, a completely hand-written form was needed. The form can be activated by the new configuration options Custom New Form, Custom Edit Form and Custom Display Form, one for a new entry, an entry to edit and and entry to display. In our case we used the same form for all three cases. This is how the shift check list looks under the Safari Browser on a PC: 
 And here is how it looks on the iPad: 
 Each section can be collapsed and expanded (blue arrows at the left), and various internal checks are made before the check list can be submitted. Implementing such forms is however more something for the advanced user, since you have to hand-write HTML with CSS and JavaScript code. It can then however be a powerful method for check lists. Please find in the attachments the elogd.cfg configuration for that logbook and the shiftcheck.html source code file. It is a bit complicated since the page is a static page, elogd just serves it from the file. This requires all the dynamic functions to be implemented inside the HTML file with JavaScript. To display an entry for example, the JavaScript loads the raw data with the "?cmd=Download" command and the populates the form fields. The collapsing and expanding is done by using CSS properties. The integrated style sheet was optimized for the rendering on an iPad. Rather large fonts were chosen so that the items can be checked easily with your finger tips. Various parameters are sent between the browser and the elogd program via hidden fields and cookies. So only something for experts! But if you go through the effort and hand-write the form, it can be very handy. Note that you have to upgrade to SVN revision 2328 for the three new options.   |    | 
| 35 | Tue May 24 22:43:38 2011 | JacekK | doctor99@poczta.onet.pl | Script | Javascript verification of simple attributes with regexp | Beta | Tue May 24 22:46:38 2011 by JacekK | 
| Hi, I added possibility for a new verification of required fields in generated Javascript "function chkform()". To do this I added new logbook option "ValidPattern", in which you can set regular expression for an attribute, for example ValidPattern HexDigits=[0-9a-fA-F]+
 If there is a pattern set for required field, then in chkform()function is generated additional verification, if value of the field matches validation regexp. Changes I made should not decrease performance of elogd. Let me know please if you can add it to regular version.   Jacek | 
| Attachment 1: JScriptREVerify.patch | 
| Index: elogd.c
===================================================================
--- elogd.c	(revision 2414)
+++ elogd.c	(working copy)
@@ -74,6 +74,8 @@
 char attr_list[MAX_N_ATTR][NAME_LENGTH];
 char attr_options[MAX_N_ATTR][MAX_N_LIST][NAME_LENGTH];
 int attr_flags[MAX_N_ATTR];
+/** Validation pattern for attribute, to test if it contains expected value */
+char attr_valid_pattern[MAX_N_ATTR][NAME_LENGTH];
 
 char attr_list_default[][NAME_LENGTH] = { "Author", "Type", "Category", "Subject", "" };
 
@@ -7033,7 +7035,7 @@
 
 int scan_attributes(char *logbook)
 /* scan configuration file for attributes and fill attr_list, attr_options
- and attr_flags arrays */
+ and attr_flags and attr_valid_pattern arrays */
 {
    char list[10000], str[NAME_LENGTH], str2[NAME_LENGTH], type[NAME_LENGTH],
        tmp_list[MAX_N_ATTR][NAME_LENGTH];
@@ -7062,11 +7064,20 @@
          }
       }
 
-      /* get options lists for attributes */
+      /* get options lists and validation patterns for attributes */
       memset(attr_options, 0, sizeof(attr_options));
+      memset(attr_valid_pattern, 0, sizeof(attr_valid_pattern));
       for (i = 0; i < n; i++) {
          n_options = 0;
 
+         sprintf(str, "ValidPattern %s", attr_list[i]);
+         if (getcfg(logbook, str, list, sizeof(list)))
+         {
+            strncpy(attr_valid_pattern[i], list, sizeof(attr_valid_pattern[i])-1);
+            attr_valid_pattern[i][sizeof(attr_valid_pattern[i])-1] = 0;
+            attr_flags[i] |= AF_HAS_VALID_PATT;
+         }
+
          sprintf(str, "Options %s", attr_list[i]);
          if (getcfg(logbook, str, list, sizeof(list)))
             n_options = strbreak(list, attr_options[i], MAX_N_LIST, ",", FALSE);
@@ -9650,6 +9661,17 @@
             rsprintf("    document.form1.%s.focus();\n", ua);
             rsprintf("    return false;\n");
             rsprintf("  }\n");
+            if (attr_flags[i] & AF_HAS_VALID_PATT) 
+            {
+              sprintf(str, loc("var validPatt=new RegExp(\"%s\");"), attr_valid_pattern[i]);
+              rsprintf("  %s\n", str);
+              rsprintf("  if (!validPatt.test(document.form1.%s.value)) {\n", ua);
+              sprintf(str, loc("Invalid value for attribute '%s'"), attr_list[i]);
+              rsprintf("    alert(\"%s\");\n", str);
+              rsprintf("    document.form1.%s.focus();\n", ua);
+              rsprintf("    return false;\n");
+              rsprintf("  }\n");
+            }
          }
       }
 
Index: elogd.h
===================================================================
--- elogd.h	(revision 2414)
+++ elogd.h	(working copy)
@@ -192,6 +192,7 @@
 #define AF_MUSERLIST         (1<<13)
 #define AF_USEREMAIL         (1<<14)
 #define AF_MUSEREMAIL        (1<<15)
+#define AF_HAS_VALID_PATT    (1<<16)
 
 /* attribute format flags */
 #define AFF_SAME_LINE              1
 | 
| 49 | Wed May 11 09:35:23 2016 | Hanno Perrey | hanno.perrey@nuclear.lu.se | Script | Re: Re: Custom input forms implementation | Stable | Wed May 11 09:43:34 2016 by Hanno Perrey | 
| 
	
		
			| Stefan Ritt wrote: |  
			| Dear ELOG users, starting with SVN revision 2328, custom input forms are implemented. This allows application specific formats for check lists etc. In our specific case we had to implement a shift check list, which was quite long. Furthermore the check list should be optimized for an iPad, which we take in the field and record various checks and readings (in our case some gas pressure gauges at the PSI particle accelerator). Since the standard ELOG interface was too inflexible, a completely hand-written form was needed. The form can be activated by the new configuration options Custom New Form, Custom Edit Form and Custom Display Form, one for a new entry, an entry to edit and and entry to display. In our case we used the same form for all three cases. This is how the shift check list looks under the Safari Browser on a PC: 
 And here is how it looks on the iPad: 
 Each section can be collapsed and expanded (blue arrows at the left), and various internal checks are made before the check list can be submitted. Implementing such forms is however more something for the advanced user, since you have to hand-write HTML with CSS and JavaScript code. It can then however be a powerful method for check lists. Please find in the attachments the elogd.cfg configuration for that logbook and the shiftcheck.html source code file. It is a bit complicated since the page is a static page, elogd just serves it from the file. This requires all the dynamic functions to be implemented inside the HTML file with JavaScript. To display an entry for example, the JavaScript loads the raw data with the "?cmd=Download" command and the populates the form fields. The collapsing and expanding is done by using CSS properties. The integrated style sheet was optimized for the rendering on an iPad. Rather large fonts were chosen so that the items can be checked easily with your finger tips. Various parameters are sent between the browser and the elogd program via hidden fields and cookies. So only something for experts! But if you go through the effort and hand-write the form, it can be very handy. Note that you have to upgrade to SVN revision 2328 for the three new options.   |  Thank you very much for this nice example! I found a little issue with newer ELOG versions: if the authentication is done via session cookies, the submission of the checklist will fail with the error "Cannot open file passwd". This is actually misleading as the cause of the error is the empty user name submitted (since the cookie storing user name and pwd hash is never created) and not the password file itself. This can be worked around by removing the user name and pwd fields in the html form before submitting in case there is a SID cookie around. The attached shiftcheck.html contains this workaround and seems to be functioning fine on my installation (ELOG 3.1.0).   Cheers, Hanno | 
| Attachment 1: shiftcheck.html | 
| 5 | Thu Jul  3 17:04:58 2003 | Fred Hooper | fhooper@sushisoft.com |  | elog2sql - version 0.99 - scripts to convert an elog logbook to a MySQL database |  |  | 
| Announcing:  elog2sql
elog2sql was created to help translate logbooks created by the program
``elog'' from the native elog flat file format to a MySQL database.  I had a
need to have the elog data in a database, and it appears from the forum that
several others had a similar need.
 I created a set of perl scripts that will allow the translation of elog
logbooks into a MySQL database. The design and implementation of these
scripts are a simple one, and allow the one-time copying of a set of logbooks.
The elog2sql toolkit consists of two scripts. The first script, parsecfg.pl,
reads a elogd.cfg, and creates a sql file that will create a set of db
tables corresponding to elog logbooks. The second script, parselog.pl, takes
a set of elog logfiles, and creates a sql file that will enter the logbook
data into the database. The result is a copy of the elog logbook that can
used as desired inside the framework of MySQL. Attachments are handled by
inserting an entry of the attachment name into an seperate attachment table.
This allows multiple attachments per entry.
You can download the elog2sql program archive at
http://www.davidfannin.com/elog2sql/elog2sql.tar.gz . It contains the
scripts and basic documentation.  You can read the man page at
http://www.davidfannin.com/elog2sql/index.html 
I have also uploaded a copy of the archive here.
email me for questions or comments. | 
| Attachment 1: elog2sql.tar.gz | 
| 8 | Wed Feb  4 11:24:14 2004 | Fred Hooper | fhooper@sushisoft.com | Script | Javascript for Bookmark Link  for one-click submission  to elog | Alpha | February 04, 2004 by Stefan Ritt | 
| I have created a javascript to be used as a browser link that allows a one
step cut and paste from a web browser into a elog logbook. 
The intended application is allow a user to do a text selection in a web
browser, then click on a bookmark that automagically pastes the selected
text, the current browser page url, and the current browser page title into
a pre-defined elog logbook.   I do some research where I would like to save
some text from a webpage, but also have a record of where the webpage came
from.  However, you should find that you can extend this script in a varity
of ways for your own application.  
The script is a simple one: it uses javascript in a saved bookmark to get
your selected text, title, and url, and then creates a new browser window
with a elog form, and print the document variables into the form, and then
submits the form to elog.   The key advantage to this approach is that you
can use the "post" command, rather than "get", to submit to the text section
of an elog logbook.  The only way I found now to submit to elog via a
bookmark is using the "get" command, and it doesn't allow entry of the
"text" field, only attribute fields.    
The second major advantage to using POST is that you can submit a much 
large quanity of information ; However, some checking on this leads me to 
believe that the limit is browser and server depended, so YMMV.  However, a 
great discussion on the limits of browsers can be found here: 
http://www.squarefree.com/bookmarklets/browsers.html .
One of the major limits is that IE6.0 browsers have a maxium of 508 bytes
per bookmark - This book runs over 800 bytes, so I suspect tha IE6+ will 
not allow it. I tested the link with Mozilla and Firebird 0.7.
This script will need to edited for you to use with your elog logbook.
The script should be fairly self-explainitory, if you are used to html 
forms and have some exposure to javascript.
You will need to modifiy the following fields:
1) in form action = http://<your_domain.com>/elog/<logbook>/?cmd=New
   
   change the link to point to your specific logbook to be used for entry.
2) the attribute fields need match up with the ones in your logbook.
   The ones listed in the template are Author, Email, Title, and URL.
   If you have fixed fields (like Author and Email), then you can
   predefine these fields as shown.  
   I have the page title used as the entry for Title, and the page url is
   use as the URL attribute.
   Finally, I have the text selection used as the entry for the Text field.
   You can add additional fields by creating a new <input ...>  segment
   in the script.  For those more clever than me, you can concatinate the
   title, url and selection to paste into the Text area as well.  
3) once you have a edited version of the script (make sure you keep it as a
single line), you can then create a new bookmark in your browser, and then
paste the script into the properties->location field (for Mozilla/Firebird)
or the properites->url field (IE). Give it a good name like "post to elog"
4) once saved, you can then go a web page, select some text, and then go to
your bookmarks and click on the bookmark. It should then create a new
window in elog with a completed logbook entry.
some notes:
1) again, this may not work on IE6+ browsers due to M$ limitations.
2) You may have to be logged in already to elog for this work - I have not
tested the interaction using a password protected elog
3) You can only post to a single elog logbook - You'll need to have 
multiple bookmarks for multiple logbooks.
__________________________
Note added by Stefan Ritt:
I zipped the attached JavaScript, since our email router does not allow .js 
file name extensions. | 
| Attachment 1: elogsubmit-template.zip | 
| 7 | Wed Jan 14 18:30:34 2004 | Francois Cukier | Francois.Cukier@Umontreal.ca | Theme/Skin | Bubble for pleasure 1 -- still under developpement but working ;) | Beta |  | 
| Uncompress "Bubbleforpleasure1.zip" in your Themes\default folder if you 
want to replace the original elog theme. Otherwise, if you decompress it in 
another folder, you will need to modify your elogd.cfg file as described at 
this adress: http://midas.psi.ch/elog/config.html | 
| Attachment 1: Bubbleforpleasure1.zip | 
| Attachment 2: BubbleForPleasure1-theme.GIF | 
|   | 
| 17 | Mon Oct 10 18:47:09 2005 | Exaos Lee | Exaos.Lee@gmail.com | Script | How to run elogd on Gentoo Linux | Stable | Tue Oct 11 08:06:55 2005 by Stefan Ritt | 
| I have created some scripts for running elogd on Gentoo Linux. Please untar the attachment and read the file "elogd_gentoo_readme". Any comment is welcomed. | 
| Attachment 1: elogd_gentoo.tar.gz | 
| 20 | Wed Jan 10 23:08:27 2007 | Exaos Lee | Exaos.Lee@gmail.com | Script | Script for running ELOGD on Ubuntu Linux | Stable |  | 
| I prepared one init script for ELOGD running on Ubuntu Linux. Please see the attachment.
 | 
| Attachment 1: elogd_ubuntu.tgz | 
| 12 | Wed Feb 23 11:25:51 2005 | Emiliano Gabrielli | AlberT@SuperAlberT.it | Script | bash script for thumbnails creation, version: 0.2.0 | Stable | Mon May  2 14:51:29 2005 by Emiliano Gabrielli | 
| The following script creates a thumbnail for image/ps/pdf files.  
it can be used with "Execute edit" and "Execute new" configuration commands  
in order to get resized thumbs of attachments.  
  
It uses file(1), convert(1) for images, gs(1) is also required for ps and pdf.  
  
You have to start elogd with the "-x" option to enable execution and put  
something similar to the following in you configuration elog file:  
  
Execute new = /path/to/make_thumbs -s 650 -q 95 $attachments  
Execute edit = /path/to/make_thumbs -s 100 $attachments  
  
make_thumbs have to be executable by the user running elogd, of course.  
 
 
ChangeLog: 
* version 0.2.0 Fixes a BUG in PDF creation  | 
| Attachment 1: make_thumbs | 
| #!/bin/bash
#
# Makes thumbnails (a jpeg image) from a given set of input files.
# Supported input file types are those supported by 'convert',
# plus PDF.
# Requires convert(1), gs(1) and file(1)
#
# Usage:      make_thumbs [options] [ file1 file2 ... ]
# Author:     Emiliano Gabrielli
# License:    GPL
# Latest Version at http://SuperAlberT.it/download/command_line_scripts/elog/
#
# $Id: make_thumbs,v 1.7 2005/04/14 10:01:37 albert Exp $
function parse_cmdline()
{
	export OPTERR=1
	while getopts "s:q:Vh" "option" ; do
		case "$option" in
		s)
			MAXSIZE=$OPTARG
			;;
		q)
			QUALITY=$OPTARG
			;;
		V)
			echo "$0 version $VERSION by $AUTHOR"
			exit 1
			;;
		h|*)
			echo -e "\nUsage: make_thumb [options] [ file1 file2 ... ]"
			echo -e "Options:\n"\
			        " -s MAXSIZE  the size of the thumbnail to be created\n"\
			        " -q QUALITY  the quality of the JPEG image created\n"\
				    " -V          print version and exit\n"\
				    " -h          print this help and exit\n"
			exit 1
			;;
		esac
	done
}
function make_thumb()
{
	[ ! -z "$1" ] || exit 1
	FILE="$1"
	# Test if file is readable
	if ! [ -r "$FILE" ] ; then
		echo "ERROR in $0: $FILE is not readable."
		exit 1
	fi
	THUMBFILE="$FILE.thumb"
	EXTENSION="`echo \"$FILE\" | sed 's/.*\.\([^.]*\)$/\1/'`"
	# we need this extension in order to instruct 'convert'
	# will be renamed at the end of the job
	JPEGFILE="$THUMBFILE.jpg"
	ROTATE=""
	# PDF needs special handling
	if [[ `file $FILE | grep "PDF document"` ]] ||
	   [[ `file $FILE | grep "PostScript document"` ]]
	then
	    # look if we should rotate
		DEG=`head -200 $FILE | strings | grep "/Rotate " | head -1 | sed -e 's#.*/Rotate \([0-9]\+\).*#\1#'`
		[ ! -z "$DEG" ] && ROTATE="-rotate $DEG"
		# Extract first page and convert: PDF -> PS -> JPEG (needs 'gs' and 'convert')
		gs -q -dNOPAUSE -dBATCH -r75 -dLastPage=1 -sDEVICE=jpeg -sOutputFile=\|cat "$FILE" | \
		convert - $ROTATE -size ${MAXSIZE}x${MAXSIZE} -resize ${MAXSIZE}x${MAXSIZE} -quality $QUALITY +profile "*" "$JPEGFILE" &&
		mv "$JPEGFILE" "$THUMBFILE" &
	# Else it must be one of the following: postscript, JPEG, GIF, TIFF, RS
	elif [[ `file $FILE | grep "\(JPEG\|GIF\|PNG\|TIFF\) image data"` ]] ||
		 [[ "$EXTENSION" == "rs" ]]   || [[ "$EXTENSION" == "RS" ]]
	then
		convert -size ${MAXSIZE}x${MAXSIZE} "$FILE" -resize ${MAXSIZE}x${MAXSIZE} -quality $QUALITY +profile "*" "$JPEGFILE" &&
		mv "$JPEGFILE" "$THUMBFILE" &
	fi
}
AUTHOR="Emiliano 'AlberT' Gabrielli"
VERSION="0.2.0"
MAXSIZE=600   # default value
QUALITY=70    # default value
parse_cmdline $@
shift `expr $OPTIND - 1`
for file in "$@" ; do
	make_thumb $file
done
# vim:ai:ts=4:sw=4:
 | 
| 14 | Fri Jul  8 17:34:02 2005 | Emiliano Gabrielli | AlberT@SuperAlberT.it | Script | JavaScript list auto-refresh | Stable | Tue Jul 12 12:36:16 2005 by Emiliano Gabrielli | 
| Here is a simple piece of JS code to accomplish a smart page reload. We don't reload if in some kind of editing mode.
 
 You can put the code everywhere you like in the elog html page, my suggestion is to put it in Bottom Text (or Top Text):
 
 
 
;auto-refresh
Bottom text = [I]<script language="JavaScript">if (null==window.location.href.match('/[0-9]+$|.*(cmd|select)=.*') ) { window.setTimeout("location.reload();", 2*60*1000); now=new Date(); document.write('<br/>Last reload at '+now.getFullYear()+'/'+(now.getMonth()+1)+'/'+now.getDate()+', '+( ((h=now.getHours())<10) ? '0'+h :h)+':'+( ((m=now.getMinutes())<10) ? '0'+m :m)+':'+( ((s=now.getSeconds())<10) ? '0'+s :s)) }</script>[/I]
 the timer is a product of # of minutes, #of seconds and milliseconds... 2 minutes in the above example
  
 
 
 
 | Revision Tue Jul 12 12:36:16 2005 wrote: |  | modified regular expression in order to not activate the auto-refresh in the signle entry view
 
 | 
 | 
| 15 | Thu Jul 28 18:42:48 2005 | Emiliano Gabrielli | AlberT@SuperAlberT.it | Other | [New Feature]: JS calendar filter | Beta | Thu Aug  4 11:20:36 2005 by Emiliano Gabrielli | 
| NOTE: it seems that for some strange reason it slows down elog very much when and only when elog is stunneled over ssl!
 
 The attached tarball contains a full featured JavaScript allowing everyone to use a JS calendar (no popup windows, just JS and CSS!) to perform date-based filtering actions. An uncompressed version and the tarball for the last cvs rvision of this script is available at www.SuperAlberT.it
 
 You can browse the ChangeLog here.
 
 A simple way to use it is to uncompress the wall package into the elog data dir, under the "scripts" subdir.
 
 the you can add the following code to your elog.cfg:
 
 
Filter Menu text = scripts/calendar_filter/calendar_filter.html
 note that this configuration parameter is available in elog starting from
 Revision 1.732  2005/07/29
 
 and automagically have the new calendar_filter icon showed
  
 
  | 
| Attachment 2: elog_calendar_filter-1.0.1.tar.gz | 
| 27 | Tue Jan 29 23:18:39 2008 | Diogo Alves | diogomiguelalves@gmail.com | Script | Multiple file upload for Firefox | Stable | Wed Jan 30 07:56:53 2008 by Stefan Ritt | 
| Here's a firefox extension that works extremely well if one uses drag n'drop to upload several attachment files at once:   https://addons.mozilla.org/en-US/firefox/addon/219   | 
| 53 | Sat Sep 16 15:47:16 2017 | David Pilgram | David.Pilgram@epost.org.uk | Script | Re: Check logbook files for wrong references | Stable | Sat Sep 16 15:52:58 2017 by David Pilgram | 
| I had to modify the script because I'm still on elog 2.9.2, where there are not subdirectories (by year) foreach logbook.  Line 5 had to be changed to
 $logf=q/[0-9][0-9][01][0-9][0-3][0-9]a.log/; to do this. Once done, I found the deliberate orphan script that I had put in to test, and rather too many other orphans than I had expected.  One or two I cannot explain.   If I had clicked on any of those entries elog would have gone into infinate loop. A very useful utility.  Thanks Andreas! 
	
		
			| Andreas Luedeke wrote: |  
			| You can run this little script to check if all entries referenced "In reply to:" do actually exist. To use it, you first need to "cd" to your logbook directory ("cd /usr/local/elog/logbooks") and then run it without arguments "logcheck". If it finds references pointing to a missing entry, it'll print the path to the file with the offending reference and some lines. For example: ### error: reference to entry 146, that exists 0 times. Reference is:### Proscan/2012/120507a.log-<p>[...].</p>
 ### Proscan/2012/120507a.log-$ @ MID @ $: 147
 ### Proscan/2012/120507a.log-Date: Mon, 07 May 2012 13:44:03 +0200
 ### Proscan/2012/120507a.log:In reply to: 146
 ### Proscan/2012/120507a.log-Wann: 1336373261
 ### Proscan/2012/120507a.log-Autor: [...]
 ### Proscan/2012/120507a.log-Eintrag: Problem
 [...]-
 Very often this happens if an entry is deleted AFTER someone already replied to it. Normally that is no problem, but in some cases you might get infinite loops and that causes ELOG to hang. The script is not checking for loops, but wrong references might give you a hint where to look. The script will print duplicate entries as well, if the referenced entry exist more than once. Cheers, Andreas PS: never include the string "$ @ MID @ $:" without spaces in an ELOG entry: apparently ELOG cuts off all text from that token on. |    | 
| 47 | Sun Aug 23 21:27:00 2015 | Daniel Sajdyk | daniel.sajdyk@gmail.com | Theme/Skin | Simple theme | Beta | Tue Sep  1 07:39:45 2015 by Daniel Sajdyk | 
| Hello.  I did simple theme for ELOG called "dansaj".  This is verision which I did for my ELOG, and if you have troubles in other configurations, please let me know, and we will correct it.  Vectors versions of icons you can find in oryginals folder (if you want to transform it).  The most current version you can download from my blog - Elog theme, czyli skórka, albo temat. Regards Daniel. | 
| Attachment 1: choose_elog.png | 
|   | 
| Attachment 2: entry.png | 
|   | 
| Attachment 3: Full.png | 
|   | 
| Attachment 4: login.png | 
|   | 
| Attachment 5: Summary.png | 
|   | 
| Attachment 6: Threaded_demo_logbook.png | 
|   | 
| Attachment 7: dansaj.7z | 
| Attachment 8: Threaded.png | 
|   | 
| 45 | Thu May  7 09:14:25 2015 | Christof Hanke | hanke@rzg.mpg.de | Script | systemd-unit file | Stable | 1 | 
| sample systemd-unit file. Use it as you like. | 
| Attachment 1: elogd.service | 
| [Unit]
Description=ELOG Daemon
Wants=network-online.target
After=network-online.target
[Service]
Type=forking
ExecStart=@PREFIX@/elogd -D -c @PREFIX@/elog/elogd.cfg
StandardOutput=null
[Install]
WantedBy=multi-user.target
 | 
| 40 | Mon Jan  7 08:45:10 2013 | Bruce Weber | bruce.weber@inmarsat.com | Script | Server time offset | Stable |  | 
| Our server runs on local time, however, we require log entries to be in UTC (-0800hrs) - is there a command to achieve this? Your assistance will be much appreciated Thanks | 
| 43 | Mon Jun 30 15:00:05 2014 | Branislav Gardon | branislav.gardon@gmail.com | Theme/Skin | blue-gray theme | Stable |  | 
| I`ve edited-prepared new default.css It`s very simple but maybe will for someone useful.
 Have a nice day. regardsBranislav
 | 
| Attachment 1: default.css | 
| /* default formatting */
body {
  margin:3px;
  color:black;
  background-color:white;
  font-family:verdana,tahoma,sans-serif;
  /* background-image:url(elog.gif); */
}
/* standard link colors and decorations */
a:link { color:#000000; text-decoration:none }
a:visited { color:#606060; text-decoration:none }
a:hover { color:#FF0092; text-decoration:underline }
a:active { color:#FF0092; text-decoration:underline }
a:focus { color:#FF0092; text-decoration:underline }
td {
  color:black;
  font-size:12px;
}
/* frame table */
.frame {
  width:100%;
}
/* printable frame table */
.pframe {
  width:600px;
}
/* standard formatting for logbook tabs */
.tabs {
  font-family:sans-serif;
  font-size:10pt;
  background-color:white;
}
/* logbook selection page */
.selframe {
  width:60%;
  background-color:#486090; 
  border:1px solid #486090;
  font-size:10pt;
}
.seltitle {
  border:1px solid #486090;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#ffffff;
  color:#486090;
  text-align:center;
}
.selexp {
  border:1px solid #0000FF;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#CCCCFF;
  color:#486090;
  text-align:left;
  font-size:10pt;
}
.selspace {
  width:2%;
  border:1px solid #308000;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#EEEEEE;
}
.selgroup {
  border:1px solid #308000;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#00ffff;
  padding:3px;
  text-align:left;
  font-weight:bold;
  font-size:14pt;
}
.sellogbook {
  border:1px solid #486090;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#ffffff;
  padding:3px;
  text-align:left;
  font-weight:normal;
}
.selcomment {
  font-size:8pt;
}
.selentries {
  background-color:#ffffff;
  border:1px solid #486090;
  border-top:1px solid white;
  border-left:1px solid white;
  text-align:center;
  font-size:10pt;
}
/* unselected and selected group tabs */
.gtab a {
  background-color:#B0E0B0;
  padding-left:5px;
  padding-right:5px;
}
.gtab {
  background-color:#B0E0B0;
  border-right:1px solid #409040;
}
.sgtab a {
  color:white;
  padding-left:5px;
  padding-right:5px;
}
.sgtab {
  background-color:#486090;
  color:white;
  border-right:1px solid #084070;
}
.sgtab a:visited { color:white; } /* bug for IE */
/* unselected and selected logbook tabs */
.ltab a {
  background-color:#EEEEEE;
  padding-left:5px;
  padding-right:5px;
}
.ltab {
  background-color:#EEEEEE;
  border-top:1px solid white;
  border-left:1px solid white;
  border-right:1px solid gray;
}
.sltab a {
  background-color:#486090;
  color:white;
  padding-left:5px;
  padding-right:5px;
}
.sltab {
  background-color:#486090;
  color:white;
  border-left:1px solid #EEEEEE;
  border-right:1px solid #084070;
}
.sltab a:visited { color:white; } /* bug for IE */
/* logbook title, left, middle and right cell */
.title1 {
  padding:5px;
  background-color:#486090;
  border-bottom:1px solid black;
  border-left:1px solid #EEEEEE;
  color:#486090;
  font-size:small;
  font-family:sans-serif;
  text-align:left;
}
.title1 a:visited { color:#A0FFA0; }
.title1 a:link { color:#A0FFA0; }
.title2 {
  background-color:#486090;
  border-bottom:1px solid black;
  color:white;
  font-size:xs-small;
  font-family:sans-serif;
  text-align:right;
}
.title3 {
  border-bottom:1px solid black;
  border-right:1px solid black;
  background-color:#486090;
  text-align:right;
  width:100px;
}
/* main menu row */
.menuframe {
  border:1px solid #486090;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#EEEEEE;
  height:29px;
}
.menu1 {
  text-align:left;
  font-size:10pt;
  vertical-align:middle;
}
.menu1a {
  text-align:center;
  width:110px;
  font-size:10pt;
  font-weight:bold;
  vertical-align:middle;
}
.menu2a {
  text-align:left;
  font-size:10pt;
}
.menu2b {
  text-align:right;
  font-size:10pt;
}
.menu3 {
  text-align:left;
  font-size:8pt;
  font-weight:bold;
}
.menu4 {
  text-align:right;
  font-size:10pt;
  vertical-align:middle;
}
.menucenter {
  border:1px solid #486090;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#EEEEEE;
  text-align:center;
  font-size:10pt;
}
.toolframe {
  border:1px solid #486090;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#EEEEEE;
  padding:2px;
}
/* frame table in listings */
.listframe {
  border:1px solid #0000FF;
  border-top:1px solid white;
  border-left:1pc solid white;
  background-color:#486090;
  border:0px;
}
/* title row in listing */
.listtitle {
  border:1px solid #000000;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#EEEEEE;
  font-size:10pt;  
  font-weight:normal;
  text-align:center;
  width:0%;
}
.listtitle2 {
  border:1px solid #000000;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#EEEEEE;
  font-size:10pt;  
  font-weight:normal;
  text-align:center;
  width:100%;
}
.listtitle3 {
  border:1px solid #000000;
  border-top:1px solid white;
  border-left:1px solid white;
  background-color:#EEEEEE;
  text-align:center;
  width:0%;
... 387 more lines ... | 
| Attachment 2: ScreenShot174.jpg | 
|   | 
| 153 | Tue Dec  7 01:38:23 2021 | Anthony J Krishock | ajkrishock@gmail.com | Theme/Skin | Astronomical logbook using Elog | Stable | Tue Dec  7 01:44:25 2021 by Anthony J Krishock | 
| Hello all, I became aware of the usefulness of Elog while working at Brookhaven National Lab. Since that time, I have developed a version of Elog that can be used as a log book for observations in Astronomy (my longtime hobby). Attached is my default.css theme and replacement icon files that match the theme. The color scheme is chosen to minimize bright lights and preserve night vision To install, just place the default.css file in the default theme directory and copy over the icon files into the default theme directory and replace the default ones.  Comments and suggestions welcome! Thank you | 
| Attachment 1: theme.zip | 
| Attachment 2: elog.PNG | 
|   | 
| 38 | Fri Sep  9 12:08:26 2011 | Andreas Luedeke | andreas.luedeke@psi.ch | Script | create incremental daily backups of logbooks for Unix/Linux | Beta |  | 
| A very simple backup utility for elog logbooks.
If you want to recover your logbook from corrupted entries, an incremental backup comes in handy:
you can just replace the corrupted files with the previous versions.
Below is a very simple wrapper to create backups of the logbook into some local directory (/logbooks_backup in
the example script). The second wrapper lists the files in a given ".tar" archive.
You would run the backup from a cron job with the line:
1 0 * * * /usr/local/elog/elog_backup_daily
This will create daily backups of modified logbook and config files and a weekly backup of the password file
/usr/local/elog/passwd.txt (if you wonder why: our passwd.txt file has more than 1 MByte and of course it
changes with every login).
elog_backup_daily (copy to /usr/local/elog) script to create tar file and remove tar files older than 90 days
exclude-logbooks  (copy to /usr/local/elog) list of files to be excluded in backup (thumbnails, etc.) 
elog_backup_listfiles (copy to /usr/local/bin) shows content of a given tar file (omits directories in list) | 
| Attachment 1: elog_backup_daily | 
| #!/bin/sh
# source file directory
srcd=/usr/local/elog/
# backup all files newer than 25 hours
date=$(date -d "-25hours" "+%Y%m%d %H:%M")
# backup file directory
tard=/logbooks_backup
# backup tar file name
tarf=$tard/$(date +%Y%m%d_%a.tar)
# do not backup files that match patterns in this file
excf=/usr/local/elog/exclude-logbooks
# create backup
cd $srcd
tar --ignore-case -X $excf --newer "$date" -cf $tarf . logbooks/*
# copy passwd.txt
if [ "$(date +%u)" -eq 1 ]
then
	passwd=$tard/passwd_$(date +%Y%m%d_%a.txt)
	cp $srcd/passwd.txt $passwd
	gzip -9 $passwd
fi
# delete all backups older than 90 days
find $tard -mtime +90 -name "*_???.tar"           -exec rm -f {} +
find $tard -mtime +90 -name "passwd_*_???.txt.gz" -exec rm -f {} +
 | 
| Attachment 2: exclude-logbooks | 
| *.png.png
*.gif.png
*.jpg.png
*.pdf.png
oldLogbooks/*
logbooks/elog.log
passwd.txt
ssl/*
logbooks/Backup/*
logbooks/old/*
 | 
| Attachment 3: elog_backup_listfiles | 
| tar -tf $1|grep -v "^.*/$"
 | 
| 50 | Tue Jul 26 10:16:22 2016 | Andreas Luedeke | simon.ebner@psi.ch | Script | Python module to read/write/edit/reply/delete ELOG entries | Stable | Tue Jul 26 10:26:34 2016 by Andreas Luedeke | 
| 
Hello Everybody!
I would just like to inform you that there is a new Python module available to access and work with ELOG (read/write/edit/reply/delete).
Currently the module is only supported for Python version 3. The package is pure Python and has no special dependencies. Therefore you can use the package on any machine.
The documentation you can find on https://github.com/paulscherrerinstitute/py_elog
If you want to install the package in an Anaconda on your local machine just use
conda install -c paulscherrerinstitute elog
(also works from outside PSI - the package is available at https://anaconda.org/paulscherrerinstitute/elog)
If there are issues with the package please use the issue tracker that comes with the github repository
https://github.com/paulscherrerinstitute/py_elog/issues or let me know.
 
Best
Simon | 
| 52 | Fri Sep 15 17:19:47 2017 | Andreas Luedeke | andreas.luedeke@psi.ch | Script | Check logbook files for wrong references | Stable | Fri Sep 15 17:41:41 2017 by Andreas Luedeke | 
| You can run this little script to check if all entries referenced "In reply to:" do actually exist. To use it, you first need to "cd" to your logbook directory ("cd /usr/local/elog/logbooks") and then run it without arguments "logcheck". If it finds references pointing to a missing entry, it'll print the path to the file with the offending reference and some lines. For example: ### error: reference to entry 146, that exists 0 times. Reference is:### Proscan/2012/120507a.log-<p>[...].</p>
 ### Proscan/2012/120507a.log-$ @ MID @ $: 147
 ### Proscan/2012/120507a.log-Date: Mon, 07 May 2012 13:44:03 +0200
 ### Proscan/2012/120507a.log:In reply to: 146
 ### Proscan/2012/120507a.log-Wann: 1336373261
 ### Proscan/2012/120507a.log-Autor: [...]
 ### Proscan/2012/120507a.log-Eintrag: Problem
 [...]-
 Very often this happens if an entry is deleted AFTER someone already replied to it. Normally that is no problem, but in some cases you might get infinite loops and that causes ELOG to hang. The script is not checking for loops, but wrong references might give you a hint where to look. The script will print duplicate entries as well, if the referenced entry exist more than once. Cheers, Andreas PS: never include the string "$ @ MID @ $:" without spaces in an ELOG entry: apparently ELOG cuts off all text from that token on. | 
| Attachment 1: logcheck | 
| #!/usr/bin/perl
$cmd=q/find * -noleaf -maxdepth 0 -wholename Backup -prune -o -wholename en -prune -o -type d -exec printf '%s:' {} + /;
#print $cmd;
$logf=q/*\/[0-9][0-9][01][0-9][0-3][0-9]a.log/;
open(INP,$cmd . "2>/dev/null |") || die "can't open " . $cmd . ": $!";
$list=<INP>;
close(INP);
#print "list=" . $list ."\n";
foreach $dir (split(":",$list)) {
    chomp $dir;
    if (length($dir) > 1) {
        print "Check \"" . $dir . "\"\n";
        $files=$dir . "/" . $logf;
        $cmd="grep ^In.reply.to: " . $files . " 2>/dev/null | cut -d \" \" -f 4 | sort -nu |";
        open(INPB,$cmd) || die "can't open " . $cmd . ": $!";
        while (<INPB>) {
            chomp;
            $id=$_;
            $cmd="grep '[\$\]\@MID\@[\$\]:.$id\$' $files |";
            open(INPC,$cmd) || die "can't open " . $cmd . ": $!";
            $c=0;
            while (<INPC>) {$c++};
            close(INPC);
            if ($c != 1) {
                print "### error: reference to entry $id, that exists $c times. Reference is:\n";
                $cmd="grep -C 3 '^In.reply.to:.$id\$' $files |";
                #print $cmd;
                open(INPD,$cmd) || die "can't open " . $cmd . ": $!";
                while (<INPD>) {
                    print "### ".$_;
                }
                close(INPD);
            }
        }
        close(INPB);
    }
}
 | 
| 13 | Thu Apr 28 15:45:58 2005 | Alex H | alexsynergie-infcom | Theme/Skin | Bubble for pleasure by L'ange noir | Stable | Mon Aug  1 09:35:26 2005 by Alex H | 
| The original theme is from Francois Cukier but I have change a some color 
and font.
Francois Cukier  said : "Uncompress "Bubble.zip" in your Elog default 
folder if you want to replace the original elog theme. Otherwise, if you 
decompress it in another folder, you will need to modify your elogd.cfg 
file as described at this adress: http://midas.psi.ch/elog/config.html"
Do it at the same ;o)
I want to thanks Francois Cukier and Stephan Ritt for their works, so 
THANKS a lot !
I wait your comments :o).
-UPDATE------------------------------------------------------------------------
2005/08/1 : Alexander Sheremet correct CSS bug thanks to it, archive re-uploaded | 
| Attachment 1: bubble2-1.gif | 
|   | 
| Attachment 2: bubble2-2.gif | 
|   | 
| Attachment 3: Bubble.zip |