2 Unix SMB/CIFS implementation.
4 Copyright (C) Andrew Tridgell 1992-1998
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3 of the License, or
9 (at your option) any later version.
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21 This file handles the messaging system calls for winpopup style
28 extern userdom_struct current_user_info;
30 /* look in server.c for some explanation of these variables */
31 static char msgbuf[1600];
33 static fstring msgfrom;
36 /****************************************************************************
38 ****************************************************************************/
40 static void msg_deliver(void)
49 if (! (*lp_msg_command())) {
50 DEBUG(1,("no messaging command specified\n"));
55 /* put it in a temporary file */
56 slprintf(name,sizeof(name)-1, "%s/msg.XXXXXX",tmpdir());
57 fd = smb_mkstemp(name);
60 DEBUG(1,("can't open message file %s\n",name));
65 * Incoming message is in DOS codepage format. Convert to UNIX.
68 if ((len = (int)convert_string_allocate(NULL,CH_DOS, CH_UNIX, msgbuf, msgpos, (void **)(void *)&msg, True)) < 0 || !msg) {
69 DEBUG(3,("Conversion failed, delivering message in DOS codepage format\n"));
70 for (i = 0; i < msgpos;) {
71 if (msgbuf[i] == '\r' && i < (msgpos-1) && msgbuf[i+1] == '\n') {
75 sz = write(fd, &msgbuf[i++], 1);
77 DEBUG(0,("Write error to fd %d: %ld(%d)\n",fd, (long)sz, errno ));
81 for (i = 0; i < len;) {
82 if (msg[i] == '\r' && i < (len-1) && msg[i+1] == '\n') {
86 sz = write(fd, &msg[i++],1);
88 DEBUG(0,("Write error to fd %d: %ld(%d)\n",fd, (long)sz, errno ));
96 if (*lp_msg_command()) {
97 fstring alpha_msgfrom;
101 pstrcpy(s,lp_msg_command());
102 pstring_sub(s,"%f",alpha_strcpy(alpha_msgfrom,msgfrom,NULL,sizeof(alpha_msgfrom)));
103 pstring_sub(s,"%t",alpha_strcpy(alpha_msgto,msgto,NULL,sizeof(alpha_msgto)));
104 standard_sub_basic(current_user_info.smb_name,
105 current_user_info.domain, s, sizeof(s));
106 pstring_sub(s,"%s",name);
113 /****************************************************************************
115 conn POINTER CAN BE NULL HERE !
116 ****************************************************************************/
118 int reply_sends(connection_struct *conn, char *inbuf,char *outbuf, int dum_size, int dum_buffsize)
125 START_PROFILE(SMBsends);
129 if (! (*lp_msg_command())) {
130 END_PROFILE(SMBsends);
131 return(ERROR_DOS(ERRSRV,ERRmsgoff));
134 outsize = set_message(inbuf,outbuf,0,0,True);
136 p = smb_buf(inbuf)+1;
137 p += srvstr_pull_buf(inbuf, SVAL(inbuf, smb_flg2), msgfrom, p,
138 sizeof(msgfrom), STR_ASCII|STR_TERMINATE) + 1;
139 p += srvstr_pull_buf(inbuf, SVAL(inbuf, smb_flg2), msgto, p,
140 sizeof(msgto), STR_ASCII|STR_TERMINATE) + 1;
145 len = MIN(len,sizeof(msgbuf)-msgpos);
147 memset(msgbuf,'\0',sizeof(msgbuf));
149 memcpy(&msgbuf[msgpos],msg+2,len);
154 END_PROFILE(SMBsends);
158 /****************************************************************************
160 conn POINTER CAN BE NULL HERE !
161 ****************************************************************************/
163 int reply_sendstrt(connection_struct *conn, char *inbuf,char *outbuf, int dum_size, int dum_buffsize)
168 START_PROFILE(SMBsendstrt);
170 if (! (*lp_msg_command())) {
171 END_PROFILE(SMBsendstrt);
172 return(ERROR_DOS(ERRSRV,ERRmsgoff));
175 outsize = set_message(inbuf,outbuf,1,0,True);
177 memset(msgbuf,'\0',sizeof(msgbuf));
180 p = smb_buf(inbuf)+1;
181 p += srvstr_pull_buf(inbuf, SVAL(inbuf, smb_flg2), msgfrom, p,
182 sizeof(msgfrom), STR_ASCII|STR_TERMINATE) + 1;
183 p += srvstr_pull_buf(inbuf, SVAL(inbuf, smb_flg2), msgto, p,
184 sizeof(msgto), STR_ASCII|STR_TERMINATE) + 1;
186 DEBUG( 3, ( "SMBsendstrt (from %s to %s)\n", msgfrom, msgto ) );
188 END_PROFILE(SMBsendstrt);
192 /****************************************************************************
194 conn POINTER CAN BE NULL HERE !
195 ****************************************************************************/
197 int reply_sendtxt(connection_struct *conn, char *inbuf,char *outbuf, int dum_size, int dum_buffsize)
202 START_PROFILE(SMBsendtxt);
204 if (! (*lp_msg_command())) {
205 END_PROFILE(SMBsendtxt);
206 return(ERROR_DOS(ERRSRV,ERRmsgoff));
209 outsize = set_message(inbuf,outbuf,0,0,True);
211 msg = smb_buf(inbuf) + 1;
214 len = MIN(len,sizeof(msgbuf)-msgpos);
216 memcpy(&msgbuf[msgpos],msg+2,len);
219 DEBUG( 3, ( "SMBsendtxt\n" ) );
221 END_PROFILE(SMBsendtxt);
225 /****************************************************************************
227 conn POINTER CAN BE NULL HERE !
228 ****************************************************************************/
230 int reply_sendend(connection_struct *conn, char *inbuf,char *outbuf, int dum_size, int dum_buffsize)
233 START_PROFILE(SMBsendend);
235 if (! (*lp_msg_command())) {
236 END_PROFILE(SMBsendend);
237 return(ERROR_DOS(ERRSRV,ERRmsgoff));
240 outsize = set_message(inbuf,outbuf,0,0,True);
242 DEBUG(3,("SMBsendend\n"));
246 END_PROFILE(SMBsendend);