Exemplo n.º 1
0
async def submit_reply(event, ctx, user, *args, **kwargs):
    data = event.body
    replier_uid = str(user['_id'])
    rid = 'r' + str(uuid.uuid4())[:13]
    qid = data.qid
    q_m = QuestionModel.get_maybe(qid)
    if q_m == Nothing:
        raise LambdaError(404, 'question not found')
    body = data.body
    if not (0 < len(body) <= 4000):
        raise Exception("Your question is too large!")
    ts = datetime.datetime.now()
    parent_rid = data.get('parent_rid', None)
    child_rids = list()
    is_staff = await has_role('qanda_staff', user['_id'])
    r = Reply(rid=rid,
              qid=qid,
              uid=replier_uid,
              body=body,
              ts=ts,
              parent_rid=parent_rid,
              child_rids=child_rids,
              is_staff=is_staff,
              display_name=gen_display_name(user, data.display_choice))
    r.save()
    update_actions = [
        ReplyIdsByQid.rids.set(
            (ReplyIdsByQid.rids | []).prepend([GenericPointer(ts=ts, id=rid)]))
    ]
    ReplyIdsByQid(qid="global").update(actions=update_actions)
    ReplyIdsByQid(qid=qid).update(actions=update_actions)
    ReplyIdsByUid(uid=replier_uid).update(actions=update_actions)
    await email_notify_new_reply(replier_uid, r, q_m.getValue())
    return {'reply': r.to_python(), 'submitted': True, 'rid': rid}
Exemplo n.º 2
0
def show_comment(tid):
    form = ReplyForm()
    if request.method == 'GET':
        page = request.args.get('page')
        if not page:
            page = 1
        else:
            page = int(page)
        if page == 1:
            comment = Comment.query.get(tid)
        else:
            comment = None

        title = Comment.query.get(tid).title
        reply_list = Reply.query.filter_by(tid = tid).order_by(Reply.tid).paginate(page, MAX_REPLY_NUM_ONE_PAGE,False)
        return render_template('showcomment.html', tid = tid, title = title, comment = comment, page = page,reply_list = reply_list, form = form)
    else:
        reply = Reply(tid = tid, userid = current_user.userid, nickname = current_user.nickname, \
                        content = form.content.data, post_time = get_now_time())

        comment = Comment.query.get(tid)
        comment.re += 1
        reply.save()
        db.session.commit()
        return redirect(request.referrer)
Exemplo n.º 3
0
Arquivo: api.py Projeto: evot/blog
def add_reply():
    form = request.json
    r = Reply.validation(form)
    if r.get('success'):
        reply = Reply.new(form)
        r['data'] = reply.json
    return jsonify(r)
Exemplo n.º 4
0
 def save(self, user, topic, reply=None):
     data = self.data
     content = unicode(data.get('content'))
     data.update({
         'user_id': user.id,
         'topic_id': topic.id,
         'content': strip_xss_tags(content)
     })
     if reply:
         category = 'edit'
         pre_content = reply.content
         cur_content = data.get('content')
         changed = 0
         if pre_content != cur_content:
             diff_content = ghdiff.diff(pre_content, cur_content, css=None)
             changed = 1
         if changed == 1:
             reply.content = cur_content
             History(user_id=user.id,
                     content=diff_content,
                     reply_id=reply.id).save()
         else:
             return reply
     else:
         category = 'create'
         reply = Reply(**data)
     return reply.save(category=category)
Exemplo n.º 5
0
    def all_source_replies(source_uuid):
        if request.method == 'GET':
            source = get_or_404(Source, source_uuid, column=Source.uuid)
            return jsonify(
                {'replies': [reply.to_json() for
                             reply in source.replies]}), 200
        elif request.method == 'POST':
            source = get_or_404(Source, source_uuid,
                                column=Source.uuid)
            if request.json is None:
                abort(400, 'please send requests in valid JSON')

            if 'reply' not in request.json:
                abort(400, 'reply not found in request body')

            user = get_user_object(request)

            data = request.json
            if not data['reply']:
                abort(400, 'reply should not be empty')

            source.interaction_count += 1
            try:
                filename = current_app.storage.save_pre_encrypted_reply(
                    source.filesystem_id,
                    source.interaction_count,
                    source.journalist_filename,
                    data['reply'])
            except NotEncrypted:
                return jsonify(
                    {'message': 'You must encrypt replies client side'}), 400

            # issue #3918
            filename = path.basename(filename)

            reply = Reply(user, source, filename)

            reply_uuid = data.get('uuid', None)
            if reply_uuid is not None:
                # check that is is parseable
                try:
                    UUID(reply_uuid)
                except ValueError:
                    abort(400, "'uuid' was not a valid UUID")
                reply.uuid = reply_uuid

            try:
                db.session.add(reply)
                db.session.add(source)
                db.session.commit()
            except IntegrityError as e:
                db.session.rollback()
                if 'UNIQUE constraint failed: replies.uuid' in str(e):
                    abort(409, 'That UUID is already in use.')
                else:
                    raise e

            return jsonify({'message': 'Your reply has been stored',
                            'uuid': reply.uuid,
                            'filename': reply.filename}), 201
Exemplo n.º 6
0
def reply(obj):
    user = User.object.get(id = obj[u"user"])
    reply = Reply(post_id = obj[u"post"],user_id = user.name,content = obj[u"content"],time = obj[u"time"])
    try:
        reply.save()
        error = None
    except(ValueError, IntegrityError) as e:
        error = str(e)
    return error
Exemplo n.º 7
0
 def post(self):
     user = user_utils.get_user_from_rosefire_user(self.user())
     post = post_utils.get_post_by_id(int(self.request.get('post_id')))
     reply = Reply(parent=post.key,
                   author=user.key,
                   text=self.request.get('text'))
     reply.put()
     time.sleep(.5)
     self.redirect(self.request.referer)
Exemplo n.º 8
0
 def post(self):
     cookie = self.request.cookies.get('user_id')
     username = utils.get_username_from_cookie(cookie)
     a = self.request.get("key")
     b = self.request.get("comment")
     a = a.replace(" ", "")
     u = Querydbase.gql("WHERE questionid = '%s'" % a).get()
     cor = Reply(post=a, author=username, text=b)
     cor.put()
     self.redirect('/showqu')
Exemplo n.º 9
0
def reply(obj):
    user = User.object.get(id=obj[u"user"])
    reply = Reply(post_id=obj[u"post"],
                  user_id=user.name,
                  content=obj[u"content"],
                  time=obj[u"time"])
    try:
        reply.save()
        error = None
    except (ValueError, IntegrityError) as e:
        error = str(e)
    return error
Exemplo n.º 10
0
    def post(self, request, *args, **kwargs):

        request_id = kwargs['request_id']
        request = RequestSend.objects.get(id=request_id)
        email_to = request.recruiter.user.email
        subject = " Contact details "
        message = " contact details of " + request.jobseeker.user.first_name + request.jobseeker.user.last_name + "Email : " + str(request.jobseeker.user.email) + "Mobile:" + str(request.jobseeker.mobile) + "Land Line:" + str(request.jobseeker.land_num)
        from_email = settings.DEFAULT_FROM_EMAIL 
        reply = Reply()
        reply.request = request
        reply.request.is_replied = True
        request.save()
        reply.save()
        send_mail(subject, message, from_email,[email_to])
        return HttpResponseRedirect(reverse('request')) 
Exemplo n.º 11
0
def add_reply(source: Source, journalist: Journalist,
              journalist_who_saw: Optional[Journalist]) -> None:
    """
    Adds a single reply to a source.
    """
    record_source_interaction(source)
    fname = "{}-{}-reply.gpg".format(source.interaction_count,
                                     source.journalist_filename)
    EncryptionManager.get_default().encrypt_journalist_reply(
        for_source_with_filesystem_id=source.filesystem_id,
        reply_in=next(replies),
        encrypted_reply_path_out=Path(Storage.get_default().path(
            source.filesystem_id, fname)),
    )
    reply = Reply(journalist, source, fname, Storage.get_default())
    db.session.add(reply)

    # Journalist who replied has seen the reply
    author_seen_reply = SeenReply(reply=reply, journalist=journalist)
    db.session.add(author_seen_reply)

    if journalist_who_saw:
        other_seen_reply = SeenReply(reply=reply,
                                     journalist=journalist_who_saw)
        db.session.add(other_seen_reply)

    db.session.commit()
Exemplo n.º 12
0
def comment():
    tid = request.args.get('tid')
    form = ReplyForm()
    if request.method == 'GET':
        pid = request.args.get('pid')
        pn = request.args.get('pn')
        if not pn:
            pn = 1
        else:
            pn = int(pn)
        if pn == 1:
            comment = Comment.query.filter_by(tid=tid).first()
        else:
            comment = None

        title = Comment.query.filter_by(tid=tid).first().title
        reply_list = Reply.query.filter_by(
            tid=tid).order_by('reply.rid').paginate(pn, MAX_REPLY_NUM_ONE_PAGE)
        return render_template('comment.html', pid = pid, tid = tid, title = title, comment = comment, pn = pn, \
                                                reply_list = reply_list, form = form)
    else:
        reply = Reply(tid = tid, userid = current_user.userid, nickname = current_user.nickname, \
                        content = form.content.data, post_time = get_now_time())

        comment = Comment.query.filter_by(tid=tid).first()
        comment.re += 1
        db.session.add(reply)
        db.session.commit()
        return redirect(request.referrer)
Exemplo n.º 13
0
def add_reply(
    source: Source, journalist: Journalist, journalist_who_saw: Optional[Journalist]
) -> None:
    """
    Adds a single reply to a source.
    """
    record_source_interaction(source)
    fname = "{}-{}-reply.gpg".format(source.interaction_count, source.journalist_filename)
    current_app.crypto_util.encrypt(
        next(replies),
        [
            current_app.crypto_util.get_fingerprint(source.filesystem_id),
            config.JOURNALIST_KEY,
        ],
        current_app.storage.path(source.filesystem_id, fname),
    )

    reply = Reply(journalist, source, fname)
    db.session.add(reply)
    db.session.flush()

    # Journalist who replied has seen the reply
    author_seen_reply = SeenReply(reply_id=reply.id, journalist_id=journalist.id)
    db.session.add(author_seen_reply)

    if journalist_who_saw:
        other_seen_reply = SeenReply(reply_id=reply.id, journalist_id=journalist_who_saw.id)
        db.session.add(other_seen_reply)

    db.session.commit()
Exemplo n.º 14
0
 def get(self, reply_id):
     reply_id = int(reply_id)
     reply = Reply.get(id=reply_id)
     if not reply:
         raise tornado.web.HTTPError(404)
     action = self.get_argument('action', None)
     user = self.current_user
     if action and user:
         if action == 'up':
             if reply.user_id != user.id:
                 result = user.up(reply_id=reply.id)
             else:
                 result = {'status': 'info', 'message':
                         '不能为自己的评论投票'}
         if action == 'down':
             if reply.user_id != user.id:
                 result = user.down(reply_id=reply.id)
             else:
                 result = {'status': 'info', 'message':
                         '不能为自己的评论投票'}
         if action == 'collect':
             result = user.collect(reply_id=reply.id)
         if action == 'thank':
             result = user.thank(reply_id=reply.id)
         if action == 'report':
             result = user.report(reply_id=reply.id)
         if self.is_ajax:
             return self.write(result)
         self.flash_message(result)
         return self.redirect_next_url()
     return self.render("reply/index.html", reply=reply)
Exemplo n.º 15
0
def reply_letter(user_id, letter_id):
    import datetime
    error = None
    letter = db.session.query(LetterToJuliet).filter_by(id=letter_id)
    form = NewLetter(request.form)
    if request.method == 'POST':
        if form.validate_on_submit():
            letter.first().reply_status = 1
            reply_letter = Reply(user_id, form.title.data, form.content.data,
                                 datetime.date.today(), letter_id)
            db.session.add(reply_letter)
            db.session.commit()
            flash('The letter was reply')
            return redirect(url_for('user_page', user_id=user_id))
        else:
            return render_template('reply_letter.html',
                                   letters=letter,
                                   user_id=user_id,
                                   letter_id=letter_id,
                                   form=form,
                                   error=error)  #may need modified
    if request.method == 'GET':
        return render_template('reply_letter.html',
                               letters=letter,
                               user_id=user_id,
                               letter_id=letter_id,
                               form=form)
Exemplo n.º 16
0
    def getOP(self, page_soup, params, thread):
        op_post = page_soup.find_all("div",
                                     {"class": "postContainer opContainer"})
        op_message = op_post[0].find_all("blockquote",
                                         {"class": "postMessage"})[0]

        op_img = op_post[0].find_all("div", {"class": "fileText"})
        op_img_src = ''
        op_img_text = ''
        if len(op_img) > 0:
            op_img_src = op_img[0].find("a")["href"]
            op_img_text = op_img[0].find("a").text
            op_img_src = 'https:{}'.format(op_img_src)

            if params.preserve:
                self.download(op_img_src, op_img_text, params)
                op_img_src = '{}/{}'.format(thread.tid, op_img_text)

        op_subject = op_post[0].find_all("span", {"class": "subject"})[1].text
        op_name = op_post[0].find_all("span", {"class": "name"})[0].text
        op_date = op_post[0].find_all(
            "span", {"class": "dateTime"})[0].text.split("No")[0]
        op_pid = op_post[0].find_all("div", {"class": "post op"})[0]['id'][1:]

        if params.verbose:
            print("Downloading post:", op_pid, "posted on", op_date[:-9])

        p1 = Reply(op_name, op_date, op_message, op_pid, op_img_src,
                   op_img_text, op_subject)
        return p1
Exemplo n.º 17
0
 def setUp(self):
     self.fake_user = User(username='******', password='******')
     self.fake_user.save()
     self.fake_post = Post(title='Fake Post', author=self.fake_user, content='This is a fake post used for testing')
     self.fake_post.save()
     self.fake_reply = Reply(post=self.fake_post, name='FakeName', email='*****@*****.**',
                             content='This is fake reply to be used for testing')
Exemplo n.º 18
0
def add_reply(pid):
    #name = self.get_argument("reply[name]", default='')
    #email = self.get_argument("reply[email]", default='')
    #website = self.get_argument("reply[website]", default='')
    #origin_content = self.get_argument("reply[content]", default='')
    name = request.form["reply[name]"]
    email = request.form["reply[email]"]
    website = request.form["reply[website]"]
    origin_content = request.form["reply[content]"]
    content = markdown.markdown(formatText(origin_content))
    if name == "":
        return redirect("/post/%d" % int(pid), error=u"请填入名字")
    if email == "":
        return redirect("/post/%d" % int(pid), error=u"请填入邮箱地址")
    if origin_content == "":
        return redirect("/post/%d" % int(pid), error=u"请输入评论内容")
    number = db.query(Reply).filter(Reply.pid == pid).count() + 1
    db.add(
        Reply(pid=int(pid),
              name=name,
              email=email,
              website=website,
              content=content,
              origin_content=origin_content,
              number=number))
    db.commit()
    base.replyerSet(name, email, website)
    return redirect("/post/%d" % (int(pid)))
Exemplo n.º 19
0
    def reply() -> werkzeug.Response:
        """Attempt to send a Reply from a Journalist to a Source. Empty
        messages are rejected, and an informative error message is flashed
        on the client. In the case of unexpected errors involving database
        transactions (potentially caused by racing request threads that
        modify the same the database object) logging is done in such a way
        so as not to write potentially sensitive information to disk, and a
        generic error message is flashed on the client.

        Returns:
           flask.Response: The user is redirected to the same Source
               collection view, regardless if the Reply is created
               successfully.
        """
        form = ReplyForm()
        if not form.validate_on_submit():
            for error in form.message.errors:
                flash(error, "error")
            return redirect(url_for('col.col', filesystem_id=g.filesystem_id))

        g.source.interaction_count += 1
        filename = "{0}-{1}-reply.gpg".format(g.source.interaction_count,
                                              g.source.journalist_filename)
        current_app.crypto_util.encrypt(
            form.message.data,
            [
                current_app.crypto_util.get_fingerprint(g.filesystem_id),
                config.JOURNALIST_KEY
            ],
            output=current_app.storage.path(g.filesystem_id, filename),
        )

        try:
            reply = Reply(g.user, g.source, filename)
            db.session.add(reply)
            db.session.flush()
            seen_reply = SeenReply(reply_id=reply.id, journalist_id=g.user.id)
            db.session.add(seen_reply)
            db.session.commit()
            store.async_add_checksum_for_file(reply)
        except Exception as exc:
            flash(
                gettext("An unexpected error occurred! Please "
                        "inform your admin."), "error")
            # We take a cautious approach to logging here because we're dealing
            # with responses to sources. It's possible the exception message
            # could contain information we don't want to write to disk.
            current_app.logger.error(
                "Reply from '{}' (ID {}) failed: {}!".format(
                    g.user.username, g.user.id, exc.__class__))
        else:

            flash(
                Markup("<b>{}</b> {}".format(
                    # Translators: Precedes a message confirming the success of an operation.
                    escape(gettext("Success!")),
                    escape(gettext("Your reply has been stored.")))),
                'success')
        finally:
            return redirect(url_for('col.col', filesystem_id=g.filesystem_id))
Exemplo n.º 20
0
 def get(self, reply_id):
     reply = Reply.get(id=reply_id)
     if not reply:
         return self.redirect_next_url()
     if not reply.histories:
         return self.redirect(reply.topic.url)
     return self.render("reply/history.html", reply=reply, histories=reply.histories)
Exemplo n.º 21
0
def replyComment():
    from_id = int(request.form.get("from_id"))  #form
    to_id = int(request.form.get("to_id"))  #to
    to_name = request.form.get("to_name")
    cid = int(request.form.get("cid"))
    content = request.form.get("content")
    type = request.form.get("type")
    if (type == '0'):
        rid = cid
    else:
        rid = request.form.get("rid")
    reply = Reply(from_id=from_id,
                  cid=cid,
                  content=content,
                  to_id=to_id,
                  to_name=to_name,
                  reply_id=rid,
                  type=type)
    try:
        db.session.add(reply)
        db.session.commit()
        return (jsonify({"static": 1}))
    except Exception as e:
        print(e)
        return (jsonify({"static": 0}))
Exemplo n.º 22
0
def reply(journalist, source, num_replies):
    """Generates and submits *num_replies* replies to *source*
    from *journalist*. Returns reply objects as a list.

    :param Journalist journalist: The journalist to write the
                                     reply from.

    :param Source source: The source to send the reply to.

    :param int num_replies: Number of random-data replies to make.

    :returns: A list of the :class:`Reply`s submitted.
    """
    assert num_replies >= 1
    replies = []
    for _ in range(num_replies):
        source.interaction_count += 1
        fname = "{}-{}-reply.gpg".format(source.interaction_count,
                                         source.journalist_filename)
        current_app.crypto_util.encrypt(
            str(os.urandom(1)), [
                current_app.crypto_util.get_fingerprint(source.filesystem_id),
                config.JOURNALIST_KEY
            ], current_app.storage.path(source.filesystem_id, fname))

        reply = Reply(journalist, source, fname)
        replies.append(reply)
        db.session.add(reply)
        db.session.flush()
        seen_reply = SeenReply(reply_id=reply.id, journalist_id=journalist.id)
        db.session.add(seen_reply)

    db.session.commit()
    return replies
Exemplo n.º 23
0
 def get(self, reply_id):
     reply_id = int(reply_id)
     reply = Reply.get(id=reply_id)
     if not reply:
         raise tornado.web.HTTPError(404)
     action = self.get_argument('action', None)
     user = self.current_user
     if action and user:
         if action == 'up':
             if reply.user_id != user.id:
                 result = user.up(reply_id=reply.id)
             else:
                 result = {'status': 'info', 'message': '不能为自己的评论投票'}
         if action == 'down':
             if reply.user_id != user.id:
                 result = user.down(reply_id=reply.id)
             else:
                 result = {'status': 'info', 'message': '不能为自己的评论投票'}
         if action == 'collect':
             result = user.collect(reply_id=reply.id)
         if action == 'thank':
             result = user.thank(reply_id=reply.id)
         if action == 'report':
             result = user.report(reply_id=reply.id)
         if self.is_ajax:
             return self.write(result)
         self.flash_message(result)
         return self.redirect_next_url()
     return self.render("reply/index.html", reply=reply)
Exemplo n.º 24
0
def reply(storage, journalist, source, num_replies):
    """Generates and submits *num_replies* replies to *source*
    from *journalist*. Returns reply objects as a list.

    :param Journalist journalist: The journalist to write the
                                     reply from.

    :param Source source: The source to send the reply to.

    :param int num_replies: Number of random-data replies to make.

    :returns: A list of the :class:`Reply`s submitted.
    """
    assert num_replies >= 1
    replies = []
    for _ in range(num_replies):
        source.interaction_count += 1
        fname = "{}-{}-reply.gpg".format(source.interaction_count,
                                         source.journalist_filename)

        EncryptionManager.get_default().encrypt_journalist_reply(
            for_source_with_filesystem_id=source.filesystem_id,
            reply_in=str(os.urandom(1)),
            encrypted_reply_path_out=storage.path(source.filesystem_id, fname),
        )

        reply = Reply(journalist, source, fname, storage)
        replies.append(reply)
        db.session.add(reply)
        seen_reply = SeenReply(reply=reply, journalist=journalist)
        db.session.add(seen_reply)

    db.session.commit()
    return replies
Exemplo n.º 25
0
    def put(self, reply_id):
        reply_id = int(reply_id)
        reply = Reply.get(id=reply_id)
        action = self.get_argument('action', None)
        user = self.current_user

        if not reply:
            raise tornado.web.HTTPError(404)

        result = {}
        if not action:
            result = {'status': 'info', 'message':
                      '缺少 action 参数'}
        if action == 'up':
            if reply.user_id != user.id:
                result = user.up(reply_id=reply.id)
            else:
                result = {'status': 'info', 'message':
                          '不能为自己的评论投票'}
        if action == 'down':
            if reply.user_id != user.id:
                result = user.down(reply_id=reply.id)
            else:
                result = {'status': 'info', 'message':
                          '不能为自己的评论投票'}
        if action == 'collect':
            result = user.collect(reply_id=reply.id)
        if action == 'thank':
            result = user.thank(reply_id=reply.id)
        if action == 'report':
            result = user.report(reply_id=reply.id)
        return self.send_result(result)
Exemplo n.º 26
0
 def get(self, reply_id):
     reply = Reply.get(id=reply_id)
     if not reply:
         return self.redirect_next_url()
     if not reply.histories:
         return self.redirect(reply.topic.url)
     return self.render("reply/history.html", reply=reply, histories=reply.histories)
Exemplo n.º 27
0
    def getReplyWrite(self, params, thread):
        reply_post = self.thread_data["posts"][1:]

        replies = []
        total_posts = len(reply_post)
        if params.total_posts:
            total_posts = min(params.total_posts, len(reply_post))

        for i in range(0, total_posts):
            reply = reply_post[i]

            if "tim" in reply.keys():
                reply["img_src"] = "https://i.4cdn.org/{}/{}{}".format(
                    thread.board, reply["tim"], reply["ext"])
                reply_img_text = "{}{}".format(reply["filename"], reply["ext"])
                if params.preserve:
                    self.download(reply["img_src"], reply_img_text, params)
                    reply["img_src"] = '{}/{}'.format(thread.tid,
                                                      reply_img_text)

            if params.verbose:
                print("Downloading reply:", reply["no"], "replied on",
                      reply["now"])

            reply["board"] = thread.board
            reply_info = Reply(reply)
            replies.append(reply_info)
            self.db.insert_reply(reply_info)
        return replies
Exemplo n.º 28
0
class ReplyVisibilityTests(TestCase):
    def setUp(self):
        self.fake_user = User(username='******', password='******')
        self.fake_user.save()
        self.fake_post = Post(title='Fake Post', author=self.fake_user, content='This is a fake post used for testing')
        self.fake_post.save()
        self.fake_reply = Reply(post=self.fake_post, name='FakeName', email='*****@*****.**',
                                content='This is fake reply to be used for testing')

    def test_reply_approve_method_sets_is_approved_to_True(self):
        self.fake_reply.approve()
        self.assertTrue(self.fake_reply.approved_reply)

    def test_reply_delete_method_set_is_deleted_to_True(self):
        self.fake_reply.delete()
        self.assertTrue(self.fake_reply.is_deleted)
Exemplo n.º 29
0
 def get(self, reply_id):
     reply_id = int(reply_id)
     reply = Reply.get(id=reply_id)
     if not reply:
         raise tornado.web.HTTPError(404)
     action = self.get_argument("action", None)
     user = self.current_user
     if action and user:
         if action == "up":
             if reply.user_id != user.id:
                 result = user.up(reply_id=reply.id)
             else:
                 result = {"status": "info", "message": "不能为自己的评论投票"}
         if action == "down":
             if reply.user_id != user.id:
                 result = user.down(reply_id=reply.id)
             else:
                 result = {"status": "info", "message": "不能为自己的评论投票"}
         if action == "collect":
             result = user.collect(reply_id=reply.id)
         if action == "thank":
             result = user.thank(reply_id=reply.id)
         if action == "report":
             result = user.report(reply_id=reply.id)
         if self.is_ajax:
             return self.write(result)
         self.flash_message(result)
         return self.redirect_next_url()
     return self.render("reply/index.html", reply=reply)
Exemplo n.º 30
0
 def get(self, reply_id):
     if not self.has_permission:
         return
     reply = Reply.get(id=reply_id)
     if not reply or (reply.author != self.current_user and not self.current_user.is_admin):
         return self.redirect_next_url()
     form = ReplyForm(content=reply.content)
     return self.render("reply/edit.html", form=form, reply=reply)
Exemplo n.º 31
0
def replies():
    dict = json.loads(request.get_data(as_text=True))
    comment_id = dict.get('comment_id',0)
    text = dict.get('text', '')
    re = Reply(comment_id=comment_id,user_id=current_user.id,reply=text)
    db.session.add(re)
    db.session.commit()
    return jsonify({'status': 'success','reply_id':re.id})
Exemplo n.º 32
0
 def get(self, reply_id):
     if not self.has_permission:
         return
     reply = Reply.get(id=reply_id)
     if not reply:
         return self.redirect_next_url()
     form = ReplyForm(content=reply.content)
     return self.render("reply/edit.html", form=form, reply=reply)
Exemplo n.º 33
0
 def get(self, reply_id):
     if not self.has_permission:
         return
     reply = Reply.get(id=reply_id)
     if not reply:
         return self.redirect_next_url()
     form = ReplyForm(content=reply.content)
     return self.render("reply/edit.html", form=form, reply=reply)
Exemplo n.º 34
0
def create_source_and_submissions(
        source_index,
        source_count,
        num_submissions=2,
        num_replies=2,
        journalist_who_replied=None  # noqa: W605, E501
):
    # Store source in database
    codename = current_app.crypto_util.genrandomid()
    filesystem_id = current_app.crypto_util.hash_codename(codename)
    journalist_designation = current_app.crypto_util.display_id()
    source = Source(filesystem_id, journalist_designation)
    source.pending = False
    db.session.add(source)
    db.session.commit()

    # Generate submissions directory and generate source key
    os.mkdir(current_app.storage.path(source.filesystem_id))
    current_app.crypto_util.genkeypair(source.filesystem_id, codename)

    # Generate some test submissions
    for _ in range(num_submissions):
        source.interaction_count += 1
        submission_text = next(submissions)
        fpath = current_app.storage.save_message_submission(
            source.filesystem_id, source.interaction_count,
            source.journalist_filename, submission_text)
        source.last_updated = datetime.datetime.utcnow()
        submission = Submission(source, fpath)
        db.session.add(submission)

    # Generate some test replies
    for _ in range(num_replies):
        source.interaction_count += 1
        fname = "{}-{}-reply.gpg".format(source.interaction_count,
                                         source.journalist_filename)
        current_app.crypto_util.encrypt(
            next(replies), [
                current_app.crypto_util.get_fingerprint(source.filesystem_id),
                config.JOURNALIST_KEY
            ], current_app.storage.path(source.filesystem_id, fname))

        if not journalist_who_replied:
            journalist = Journalist.query.first()
        else:
            journalist = journalist_who_replied
        reply = Reply(journalist, source, fname)
        db.session.add(reply)
        db.session.flush()
        seen_reply = SeenReply(reply_id=reply.id, journalist_id=journalist.id)
        db.session.add(seen_reply)

    db.session.commit()

    print("Test source {}/{} (codename: '{}', journalist designation '{}') "
          "added with {} submissions and {} replies".format(
              source_index, source_count, codename, journalist_designation,
              num_submissions, num_replies))
Exemplo n.º 35
0
 def get(self, reply_id):
     if not self.has_permission:
         return
     reply = Reply.get(id=reply_id)
     if not reply or (reply.author != self.current_user
                      and not self.current_user.is_admin):
         return self.redirect_next_url()
     form = ReplyForm(content=reply.content)
     return self.render("reply/edit.html", form=form, reply=reply)
Exemplo n.º 36
0
def comment_reply(request, post_id, comment_id):
    if request.method == 'GET':
        reply_text = request.GET['reply_text']

        # forbidden_words = Forbidden.objects.all()
        #
        # for forbidden_word in forbidden_words:
        #     reply_text = reply_text.replace(forbidden_word.word, ("*" * len(forbidden_word.word)))

        comment = Comment.objects.get(pk=comment_id)
        reply = Reply(reply_comment=comment,
                      reply_text=reply_text,
                      reply_user=request.user)
        reply.save()
        return HttpResponseRedirect('/ourblog/post/' + post_id)

    else:
        return HttpResponse("Request method is not a GET")
def get_reply_locations(trump_status_id):
    locations = []
    for reply in Reply.select().where(
            Reply.in_reply_to_status_id_str == trump_status_id).order_by(
                Reply.created_at):
        location = reply.location
        if location:
            locations.append(location)
    return locations
Exemplo n.º 38
0
def post_reply(userid,message,postid,replyid=None,callback=None):
	confidence = ranking.confidence(1,0)
	if replyid is None:
		replyid = postid  #first set of comments 
	
	reply = Reply(id=ObjectId(),ParentId=replyid,UserId=userid,Message=message,Time=datetime.datetime.now(),
		Hotness=confidence,Upvotes=1,Downvotes=0)
	user = User.objects(id=userid).first()
	reply.id = str(reply.id).lower()
	user.Votes[reply.id] = 1
	post = Post.objects(id=postid).first()
	post.Reply.append(reply)
	
	post.save()
	user.save()
	if callback != None:
		return callback(RespSuccess.DEFAULT_SUCCESS)
	return RespSuccess.DEFAULT_SUCCESS
Exemplo n.º 39
0
def create_reply(request, thread_id, main, board_name):
    username = request.form.get('username')
    split_username = username.split('#', 1)
    user = split_username[0]
    if user == '':
        user = '******'
    tripcode = split_username[1] if len(split_username) > 1 else None
    if tripcode:
        tripcode = trip(tripcode)
    options = request.form.get('options')
    subject = request.form.get('subject')
    content = request.form.get('content')
    file = request.files.get('upfile', False)
    filename = ''
    original_filename = ''
    thumbnail_name = ''
    if file and allowed_file(file.filename):
        original_filename = file.filename
        filename = ''.join(
            random.choice(string.ascii_uppercase + string.digits)
            for _ in range(10))
        thumbnail_name = filename + '_thumb'
        filename += '.' + original_filename.rsplit('.', 1)[1].lower()
        thumbnail_name += '.' + original_filename.rsplit('.', 1)[1].lower()
        file.save(os.path.join(app.config['UPLOAD_FOLDER'], filename))
        thumbnail = create_thumbnail(file)
        thumbnail.save(
            os.path.join(app.config['UPLOAD_FOLDER'], thumbnail_name))
    board = db.session.query(Board).filter_by(name=board_name)[0]
    board_id = board.post_counter + 1
    board.post_counter = board_id
    if not main:
        threads = db.session.query(Thread).filter_by(board_name=board_name)
        thread = [
            thread for thread in threads if thread.board_id == thread_id
        ][0]
        thread_id = thread.id
    reply = Reply(
        board_id=board_id,
        username=user,
        user_ip=request.remote_addr,
        content=content,
        options=options,
        subject=subject,
        tripcode=tripcode,
        filename=filename,
        thumbnail_name=thumbnail_name,
        original_filename=original_filename,
        date=datetime.now(),
        main=main,
        thread_id=thread_id,
    )
    db.session.add(reply)
    db.session.commit()
    return reply
Exemplo n.º 40
0
def send_reply(user_id, tweet_id, tweet, reply):
    existing_reply = Reply.get_by_id(tweet_id)
    if existing_reply:
        logging.warn('Skipping existing reply: %r', existing_reply)
        return

    logging.info('Tweet: %s', tweet)
    logging.info('Reply: %s', reply)
    try:
        status = update_status(reply, in_reply_to_status_id=tweet_id)
    except Exception, e:
        logging.exception('Error updating status: %s', e)
Exemplo n.º 41
0
    def new_reply(self, journalist_id, source_id):
        source = Source.query.get(source_id)

        # A source may have a null fid according to the DB, but this will
        # break storage.path.
        if source.filesystem_id is None:
            return

        journalist = Journalist.query.get(journalist_id)
        filename = self.fake_file(source.filesystem_id)
        reply = Reply(journalist, source, filename)
        db.session.add(reply)
Exemplo n.º 42
0
async def test():
    await orm.create_pool(loop=loop, host='127.0.0.1', port=3306, user='******', password='******', db='awesome')

    # u = User(name='Test2', email='*****@*****.**', passwd='1234567890', image='about:blank2')

    # await u.save()
    reply = Reply(comment_id='001527235629310f05f5b66fd3f441dac59368bc6a5c243000',
                  user_id='0015271444248050b6689072c8f441cb53e158e535c2a9a000',
                  user_name='abc',
                  user_image='http://www.gravatar.com/avatar/4adcca49b3b1e5a08ac202f5d5a9e688?d=mm&s=120',
                  content='content content content2')

    await reply.save()
Exemplo n.º 43
0
def post_view(request,article_id):
    try:
        article = Article.objects.get_article_by_article_id(article_id)
    except Article.DoesNotExist:
        raise Http404

    form = ReplyForm(request.POST)
    if not form.is_valid():
        return get_view(request,article_id,errors=form.errors)

    now = timezone.now()

    reply = Reply(
        article = article,
        nickname = form.cleaned_data.get('nickname'),
        content = form.cleaned_data.get('content'),
        created = now,
    )

    reply.save()

    return redirect('/article/%s/#reply' %article.id )
Exemplo n.º 44
0
def add_comment(request,tid):
	'''
		func add comment
	'''
	content = request.POST.get("rv_comment",'')
	if content.strip() == '':
		return redirect("topic",id=tid)
	ref_user = request.POST.get("ref_user","")
	ref_content = request.POST.get("ref_content","")
	all_content = content
	if ref_user != '' and ref_content != '':
		all_content = "||"+ref_content+"    "+ref_user+"""  \n\n
			%s
		"""%content
	topic = Topic.objects.get(id=tid)
	reply = Reply(content=all_content,creator=request.user,topic=topic)
	reply.save()
	#we need to update the Topic_reply_amount table
	topic_reply_amount = Topic_reply_amount.objects.get(topic=topic)
	topic_reply_amount.amount  = F('amount') + 1
	topic_reply_amount.save()
	return redirect("topic",id=tid)
Exemplo n.º 45
0
 def post(self, reply_id):
     reply = Reply.get(id=reply_id)
     if not reply or (reply.author != self.current_user and not self.current_user.is_admin):
         return self.redirect_next_url()
     user = self.current_user
     form = ReplyForm(self.request.arguments)
     if form.validate():
         reply = form.save(user=user, topic=reply.topic, reply=reply)
         reply.put_notifier()
         result = {'status': 'success', 'message': '评论修改成功',
                   'reply_url': reply.url}
         return self.send_result(result, reply.url)
     data = dict(form=form, reply=reply)
     return self.send_result_and_render(form.result, "reply/edit.html", data)
Exemplo n.º 46
0
 def save(self, user, topic, reply=None):
     data = self.data
     content = unicode(data.get('content'))
     data.update({'user_id': user.id, 'topic_id': topic.id,
         'content': strip_xss_tags(content)})
     if reply:
         category = 'edit'
         pre_content = reply.content
         cur_content = data.get('content')
         changed = 0
         if pre_content != cur_content:
             diff_content = ghdiff.diff(pre_content, cur_content, css=None)
             changed = 1
         if changed == 1:
             reply.content = cur_content
             History(user_id=user.id, content=diff_content,
                     reply_id=reply.id).save()
         else:
             return reply
     else:
         category = 'create'
         reply = Reply(**data)
     return reply.save(category=category)
Exemplo n.º 47
0
 def post(self, reply_id):
     if not self.has_permission:
         return
     reply = Reply.get(id=reply_id)
     if not reply or (reply.author != self.current_user and not self.current_user.is_admin):
         return self.redirect_next_url()
     user = self.current_user
     form = ReplyForm(self.request.arguments)
     if form.validate():
         reply = form.save(user=user, topic=reply.topic, reply=reply)
         result = {"status": "success", "message": "评论修改成功", "reply_url": reply.url}
         if self.is_ajax:
             return self.write(result)
         self.flash_message(result)
         return self.redirect(reply.url)
     if self.is_ajax:
         return self.write(form.result)
     return self.render("reply/edit.html", form=form, reply=reply)
Exemplo n.º 48
0
 def post(self, reply_id):
     if not self.has_permission:
         return
     reply = Reply.get(id=reply_id)
     if not reply:
         return self.redirect_next_url()
     user = self.current_user
     form = ReplyForm(self.request.arguments)
     if form.validate():
         reply = form.save(user=user, topic=reply.topic, reply=reply)
         result = {'status': 'success', 'message': '评论修改成功',
                 'reply_url': reply.url}
         if self.is_ajax:
             return self.write(result)
         self.flash_message(result)
         return self.redirect(reply.url)
     if self.is_ajax:
         return self.write(form.result)
     return self.render("reply/edit.html", form=form, reply=reply)
Exemplo n.º 49
0
 def delete(self, reply_id):
     if not self.current_user.is_admin:
         return self.redirect_next_url()
     reply = Reply.get(id=reply_id)
     if not reply:
         return self.redirect_next_url()
     subject = "评论删除通知 - " + config.site_name
     template = (
             '<p>尊敬的 <strong>%(nickname)s</strong> 您好!</p>'
             '<p>您在主题 <strong><a href="%(topic_url)s">「%(topic_title)s」</a></strong>'
             '下的评论由于违反社区规定而被删除,我们以邮件的形式给您进行了备份,备份数据如下:</p>'
             '<div class="content">%(content)s</div>'
             ) % {'nickname': reply.author.nickname,
                     'topic_url': config.site_url + reply.topic.url,
                     'topic_title': reply.topic.title,
                     'content': reply.content}
     self.send_email(self, reply.author.email, subject, template)
     reply.remove()
     result = {'status': 'success', 'message': '已成功删除'}
     return self.write(result)
Exemplo n.º 50
0
 def get(self, reply_id):
     if not self.current_user.is_admin:
         return self.redirect_next_url()
     reply = Reply.get(id=reply_id)
     if not reply:
         return self.redirect_next_url()
     subject = "评论删除通知 - " + config.site_name
     template = (
         "<p>尊敬的 <strong>%(nickname)s</strong> 您好!</p>"
         '<p>您在主题 <strong><a href="%(topic_url)s">「%(topic_title)s」</a></strong>'
         "下的评论由于违反社区规定而被删除,我们以邮件的形式给您进行了备份,备份数据如下:</p>"
         '<div class="content">%(content)s</div>'
     ) % {
         "nickname": reply.author.nickname,
         "topic_url": config.site_url + reply.topic.url,
         "topic_title": reply.topic.title,
         "content": reply.content,
     }
     self.send_email(self, reply.author.email, subject, template)
     reply.remove()
     result = {"status": "success", "message": "已成功删除"}
     self.flash_message(result)
     return self.redirect_next_url()
Exemplo n.º 51
0
 def get(self, reply_id):
     reply_id = int(reply_id)
     reply = Reply.get(id=reply_id)
     if not reply:
         raise tornado.web.HTTPError(404)
     return self.render("reply/index.html", reply=reply)