2012-02-28 17:40:13 +05:30
|
|
|
# ERPNext - web based ERP (http://erpnext.com)
|
|
|
|
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2012-07-19 13:40:31 +05:30
|
|
|
from __future__ import unicode_literals
|
2012-02-27 18:03:54 +05:30
|
|
|
import webnotes
|
|
|
|
|
|
|
|
@webnotes.whitelist()
|
|
|
|
def get_list(arg=None):
|
|
|
|
"""get list of messages"""
|
|
|
|
webnotes.form_dict['limit_start'] = int(webnotes.form_dict['limit_start'])
|
|
|
|
webnotes.form_dict['limit_page_length'] = int(webnotes.form_dict['limit_page_length'])
|
|
|
|
webnotes.form_dict['user'] = webnotes.session['user']
|
|
|
|
|
2012-12-03 11:33:08 +05:30
|
|
|
# set all messages as read
|
2013-02-03 22:42:05 +05:30
|
|
|
webnotes.conn.begin()
|
2012-12-03 11:33:08 +05:30
|
|
|
webnotes.conn.sql("""UPDATE `tabComment`
|
|
|
|
set docstatus = 1 where comment_doctype in ('My Company', 'Message')
|
|
|
|
and comment_docname = %s
|
|
|
|
""", webnotes.user.name)
|
2013-02-03 22:42:05 +05:30
|
|
|
webnotes.conn.commit()
|
2012-12-03 11:33:08 +05:30
|
|
|
|
2012-02-27 18:03:54 +05:30
|
|
|
if webnotes.form_dict['contact'] == webnotes.session['user']:
|
2012-02-27 18:17:57 +05:30
|
|
|
# return messages
|
2012-03-30 12:29:06 +05:30
|
|
|
return webnotes.conn.sql("""select * from `tabComment`
|
2012-10-03 18:32:10 +05:30
|
|
|
where (owner=%(contact)s
|
|
|
|
or comment_docname=%(user)s
|
|
|
|
or (owner=comment_docname and ifnull(parenttype, "")!="Assignment"))
|
|
|
|
and comment_doctype ='Message'
|
2012-02-27 18:03:54 +05:30
|
|
|
order by creation desc
|
|
|
|
limit %(limit_start)s, %(limit_page_length)s""", webnotes.form_dict, as_dict=1)
|
|
|
|
else:
|
2012-03-30 12:29:06 +05:30
|
|
|
return webnotes.conn.sql("""select * from `tabComment`
|
2012-02-27 18:03:54 +05:30
|
|
|
where (owner=%(contact)s and comment_docname=%(user)s)
|
|
|
|
or (owner=%(user)s and comment_docname=%(contact)s)
|
2012-10-03 18:32:10 +05:30
|
|
|
or (owner=%(contact)s and comment_docname=%(contact)s)
|
|
|
|
and comment_doctype ='Message'
|
2012-02-27 18:03:54 +05:30
|
|
|
order by creation desc
|
|
|
|
limit %(limit_start)s, %(limit_page_length)s""", webnotes.form_dict, as_dict=1)
|
|
|
|
|
|
|
|
|
|
|
|
@webnotes.whitelist()
|
|
|
|
def get_active_users(arg=None):
|
2012-09-27 18:41:46 +05:30
|
|
|
return webnotes.conn.sql("""select name,
|
|
|
|
(select count(*) from tabSessions where user=tabProfile.name
|
|
|
|
and timediff(now(), lastupdate) < time("01:00:00")) as has_session
|
|
|
|
from tabProfile
|
2012-03-01 13:47:51 +05:30
|
|
|
where ifnull(enabled,0)=1 and
|
|
|
|
docstatus < 2 and
|
2012-02-27 18:03:54 +05:30
|
|
|
name not in ('Administrator', 'Guest')
|
|
|
|
order by first_name""", as_dict=1)
|
|
|
|
|
|
|
|
@webnotes.whitelist()
|
|
|
|
def post(arg=None):
|
2012-04-30 14:22:02 +05:30
|
|
|
import webnotes
|
2012-02-27 18:03:54 +05:30
|
|
|
"""post message"""
|
2013-02-15 18:27:05 +05:30
|
|
|
if not arg:
|
2012-03-08 12:10:51 +05:30
|
|
|
arg = {}
|
|
|
|
arg.update(webnotes.form_dict)
|
2013-02-15 18:27:05 +05:30
|
|
|
|
|
|
|
if isinstance(arg, basestring):
|
|
|
|
import json
|
|
|
|
arg = json.loads(arg)
|
|
|
|
|
2012-02-27 18:03:54 +05:30
|
|
|
from webnotes.model.doc import Document
|
2012-03-30 12:29:06 +05:30
|
|
|
d = Document('Comment')
|
2012-12-11 16:28:33 +05:30
|
|
|
d.parenttype = arg.get("parenttype")
|
2012-02-27 18:03:54 +05:30
|
|
|
d.comment = arg['txt']
|
|
|
|
d.comment_docname = arg['contact']
|
|
|
|
d.comment_doctype = 'Message'
|
|
|
|
d.save()
|
2012-04-06 17:54:17 +05:30
|
|
|
|
|
|
|
import webnotes.utils
|
|
|
|
if webnotes.utils.cint(arg.get('notify')):
|
|
|
|
notify(arg)
|
2012-02-27 18:41:11 +05:30
|
|
|
|
|
|
|
@webnotes.whitelist()
|
|
|
|
def delete(arg=None):
|
2012-03-30 12:29:06 +05:30
|
|
|
webnotes.conn.sql("""delete from `tabComment` where name=%s""",
|
2012-02-27 18:41:11 +05:30
|
|
|
webnotes.form_dict['name']);
|
2012-04-06 17:54:17 +05:30
|
|
|
|
|
|
|
def notify(arg=None):
|
2013-02-15 18:27:05 +05:30
|
|
|
from webnotes.utils import cstr, get_fullname
|
2013-02-13 23:42:48 +05:30
|
|
|
from startup import get_url
|
|
|
|
|
2013-02-15 18:27:05 +05:30
|
|
|
fn = get_fullname(webnotes.user.name) or webnotes.user.name
|
|
|
|
|
2012-12-07 19:10:16 +05:30
|
|
|
url = get_url()
|
2013-02-15 18:27:05 +05:30
|
|
|
|
2012-12-07 19:28:27 +05:30
|
|
|
message = '''You have a message from <b>%s</b>:
|
2012-04-06 17:54:17 +05:30
|
|
|
|
2012-12-07 19:10:16 +05:30
|
|
|
%s
|
2012-04-06 17:54:17 +05:30
|
|
|
|
2012-12-07 19:10:16 +05:30
|
|
|
To answer, please login to your erpnext account at \
|
|
|
|
<a href=\"%s\" target='_blank'>%s</a>
|
|
|
|
''' % (fn, arg['txt'], url, url)
|
2012-04-06 17:54:17 +05:30
|
|
|
|
2013-02-15 18:27:05 +05:30
|
|
|
sender = webnotes.conn.get_value("Profile", webnotes.user.name, "email") \
|
|
|
|
or webnotes.user.name
|
|
|
|
recipient = [webnotes.conn.get_value("Profile", arg["contact"], "email") \
|
|
|
|
or arg["contact"]]
|
2012-03-08 12:06:27 +05:30
|
|
|
|
2012-04-06 17:54:17 +05:30
|
|
|
from webnotes.utils.email_lib import sendmail
|
2013-02-15 18:27:05 +05:30
|
|
|
sendmail(recipient, sender, message, arg.get("subject") or "You have a message from %s" % (fn,))
|
2013-02-13 23:42:48 +05:30
|
|
|
|