MadElf1337
de62e11c23
integrations: Add webhook payloads for StatusPage.io.
2017-12-28 15:53:06 -05:00
Steve Howell
80477da481
quick fix: Stop tracebacks with missedmessage_hook.
...
A `None` value is not properly handled in this function, which
indicates some lack of testing or a recent regression we don't
understand. We were getting lots of tracebacks from this line
of code on our test server:
mentioned = 'mentioned' in flags and 'read' not in flags
2017-12-28 08:10:56 -05:00
Kiy4h
2e35b7fd60
mypy: Use Python 3 type syntax in zerver/webhooks/taiga/view.py.
2017-12-28 07:26:44 -05:00
Kiy4h
93cc19e3f8
mypy: Use Python 3 type syntax in zerver/webhooks/helloworld/view.py.
2017-12-28 07:26:44 -05:00
Kiy4h
3b7fbc1a1d
mypy: Use Python 3 type syntax in zerver/webhooks/gosquared/view.py.
2017-12-28 07:26:44 -05:00
Kiy4h
6fa51be822
mypy: Use Python 3 type syntax in zerver/views/push_notifications.py.
2017-12-28 07:26:44 -05:00
Kiy4h
64413e3b91
mypy: Use Python 3 type syntax in zerver/views/email_mirror.py.
2017-12-28 07:26:44 -05:00
Kiy4h
238cd2b132
mypy: Use Python 3 type syntax in zerver/views/alert_words.py.
2017-12-28 07:26:44 -05:00
Kiy4h
78e71faefe
mypy: Use Python 3 type syntax in zerver/lib/test_fixtures.py.
2017-12-28 07:26:44 -05:00
Rhea Parekh
ed4054d110
Import script: Check and add system bots after every import.
...
This checks for the existing system bots and adds them if they
aren't included in the import.
2017-12-27 07:52:45 -05:00
Rhea Parekh
62aec0688f
Slack importer: Add slack to zulip data conversion script as a manage.py command.
2017-12-27 07:50:53 -05:00
Rhea Parekh
cd332a7f59
Slack importer: Append ids to the existing ids in the database.
...
For import with the condition `--import-into-nonempty`, the ids
of the mapped data will be appended to the existing ids in the
database.
2017-12-27 07:50:53 -05:00
Rhea Parekh
5b37c5562b
Slack importer: Add the slack to zulip data conversion files.
2017-12-27 07:50:53 -05:00
Rhea Parekh
3d4ee3b862
zerver/tests/test_email_mirror: Sweep force_str.
2017-12-26 09:09:31 -05:00
Rhea Parekh
25e5969add
zerver/lib/mobile_auth_otp: Sweep force_str.
2017-12-26 09:09:31 -05:00
Rhea Parekh
cc872ad976
zerver/lib/upload.py: Sweep force_bytes from ensure_medium_avatar_image.
2017-12-26 09:09:31 -05:00
Rhea Parekh
092472f42d
tests: Add test coverage for uploading avatars to S3UploadBackend.
...
Add test coverage for the function upload_avatar_image and
ensure_medium_avatar_image in S3UploadBackend.
2017-12-26 09:09:31 -05:00
Rhea Parekh
bebd8df728
zerver/webhooks/github/view: Sweep force_str.
2017-12-26 09:09:31 -05:00
Rhea Parekh
99cb001345
zerver/webhooks/beanstalk/view.py: Sweep force_bytes and force_str.
2017-12-26 09:09:31 -05:00
Rhea Parekh
b792a90842
Remove unused imports in the codebase.
2017-12-26 09:09:31 -05:00
derAnfaenger
94c8e8b8e7
embedded bots: Strip @-mention from message.
...
This is in order to comply with the most recent
code in the `zulip_bots` package.
2017-12-26 08:50:00 -05:00
Xavier Cooney
f66f04f83a
mypy: Use Python 3 type syntax in 'bitbucket/tests.py'.
2017-12-26 08:34:38 -05:00
Xavier Cooney
63142385ca
mypy: Use Python 3 type syntax in 'send_password_reset_email.py'.
2017-12-26 08:34:38 -05:00
Xavier Cooney
34aee15d63
mypy: Use Python 3 type syntax in 'gitlab/view.py'.
2017-12-26 08:34:38 -05:00
Xavier Cooney
36b58ff6fc
mypy: Use Python 3 type syntax in 'views/users.py'.
2017-12-26 08:34:38 -05:00
Xavier Cooney
78042d7f18
mypy: Use Python 3 type syntax in 'webhooks/gogs/tests.py'.
2017-12-26 08:34:38 -05:00
nyan-salmon
51be0e5e76
mypy: Use Python 3 type syntax in zerver/webhooks/solano/view.py.
2017-12-26 08:34:06 -05:00
nyan-salmon
0fd0332a2c
mypy: Use Python 3 type syntax in zerver/views/custom_profile_fields.py.
2017-12-26 08:34:06 -05:00
nyan-salmon
613856c33b
mypy: Use Python 3 type syntax in zerver/lib/send_email.py.
2017-12-26 08:34:06 -05:00
nyan-salmon
4f4d689f86
mypy: Use Python 3 type syntax in zerver/webhooks/splunk/view.py.
2017-12-26 08:34:06 -05:00
nyan-salmon
6c5f66c561
mypy: Use Python 3 type syntax in zerver/webhooks/slack/view.py.
2017-12-26 08:34:06 -05:00
Viraat Chandra
de3eb89d5c
mypy: Use Python 3 syntax for typing in `zerver/lib/request.py`.
2017-12-26 08:31:43 -05:00
Viraat Chandra
bbf24ec68e
mypy: Use Python 3 syntax for typing in `zerver/lib/webhooks/git.py`.
2017-12-26 08:31:43 -05:00
Viraat Chandra
553711e671
mypy: Use Python 3 syntax for typing in `zerver/tests/test_home.py`.
2017-12-26 08:31:43 -05:00
Viraat Chandra
0494902e6d
mypy: Use Python 3 syntax for typing in `zerver/views/auth.py`.
2017-12-26 08:31:43 -05:00
fredfishgames
55801d2feb
mypy: Use Python 3 type syntax in zerver/tornado/event_queue.py.
2017-12-26 08:31:09 -05:00
fredfishgames
ccc3d69f61
mypy: Use Python 3 type syntax in zerver/webhooks/bitbucket2/tests.py.
2017-12-26 08:31:09 -05:00
greysome
6bcc01bfee
mypy: Use Python 3 type syntax in zerver/webhooks/bitbucket/view.py
2017-12-26 08:30:33 -05:00
greysome
f2f9efd1a7
mypy: Use Python 3 type syntax in zerver/lib/integrations.py
2017-12-26 08:30:33 -05:00
greysome
fb7ee942c4
mypy: Use Python 3 type syntax in zerver/lib/export.py
2017-12-26 08:30:33 -05:00
greysome
da9c808db4
mypy: Use Python 3 type syntax in zerver/webhooks/transifex/view.py
2017-12-26 08:30:33 -05:00
greysome
64ce353d4b
mypy: Use Python 3 type syntax in zerver/webhooks/circleci/view.py
2017-12-26 08:30:33 -05:00
greysome
bbe2d91d31
mypy: Use Python 3 type syntax in zerver/forms.py
2017-12-26 08:30:33 -05:00
Xavier Cooney
06b462ba19
mypy: Use Python 3 type syntax in tests/test_auth_backends.py.
2017-12-26 08:29:30 -05:00
Xavier Cooney
61704dc20b
mypy: Use Python 3 type syntax in views/pointer.py.
2017-12-26 08:29:30 -05:00
Xavier Cooney
5b2819645e
mypy: Use Python 3 type syntax in decorator.py.
2017-12-26 08:29:30 -05:00
Rishi Gupta
e62d9742aa
emails: Fix notify_new_login emails have unserializable context.
...
Regression introduced in e0f30d0
(PR #7569 ).
2017-12-22 16:34:18 -05:00
Steve Howell
c33102f692
Fix mypy error in AdminNotifyHandler.emit().
2017-12-22 15:02:18 -05:00
Greg Price
ac6f3373b6
errors tests: Deduplicate and isolate the magical part.
...
This makes the tests look a lot more boring and straightforward, in
addition to being a bit shorter.
2017-12-22 11:52:13 -05:00
Greg Price
de5c944980
errors tests: De-indent a bunch of code.
...
This diff is nothing but dedentation -- it's empty under
`git diff -b`. These with-statements are only needed for
a pretty narrow scope of code, so make that clear in the
source.
2017-12-22 11:52:13 -05:00
Greg Price
ca5c991994
errors: Simplify manual testing of error emails.
...
There are two different things you need to patch in order to get error
emails (at `/emails`) in dev. Flip one of them in dev all the time,
and make the comment on the other a bit more explicit.
2017-12-22 11:52:13 -05:00
Greg Price
a34c01780f
errors: Compute deployment metadata on the right deployment.
...
When I added this "Deployed code" feature to the error reporting,
I apparently hadn't worked out enough of how this code works to
realize that `notify_server_error` may be in a different process,
at a different time and potentially even on a different machine
from the actual error being reported.
Given that architecture, all the data about the error must be computed
in `AdminNotifyHandler`, before sending the report through the queue,
or else it risks being wrong. The job of `notify_server_error` and
friends is only to format the data and send it off. So, move the
implementation of this feature in order to do that.
(@showell added some "nocoverage" directives here for code that
is hard to test (exceptions being thrown, deployment files not
existing) and that was originally part of a file that didn't
require 100% coverage)
2017-12-22 11:52:13 -05:00
Greg Price
eea1ceb0db
errors: Show what logger and source code the message comes from.
2017-12-22 11:52:13 -05:00
Greg Price
77e47900dd
errors: Stop showing a long list of Nones when there's no request.
...
This had contributed to making the emails look broken and of uncertain
accuracy.
2017-12-22 11:52:13 -05:00
Greg Price
68fa29c3ec
errors: Make Zulip and email paths more parallel.
...
This helps prevent them from diverging and getting different sets of
features and fixes. As a bonus, the email path gets a nice tweak that
the Zulip path has had for years, since f7f2ec0ac
, which makes the
emails clearer and less broken-looking when logging a message with no
stack trace.
2017-12-22 11:52:13 -05:00
Greg Price
8c0fd5beaf
errors: Clean up the logic slightly.
...
This deduplicates a little bit of logic, and also has us always put
things into `report` the same way.
Empirically an exception in this codepath is very rare, so we won't
complicate the code by trying to salvage a lot of partial information
if it happens -- just log the traceback, and try to get a minimal
notification sent of the bare fact this happened.
2017-12-22 11:52:13 -05:00
Greg Price
b15231dfc2
logging: Rename AdminZulipHandler to AdminNotifyHandler.
...
This name hasn't been right since f7f2ec0ac
back in 2013; this handler
sends the log record to a queue, whose consumer will not only maybe
send a Zulip message but definitely send an email. I found this
pretty confusing when I first worked on this logging code and was
looking for how exception emails got sent; so now that I see exactly
what's actually happening here, fix it.
2017-12-22 11:52:13 -05:00
neiljp (Neil Pilgrim)
73a834990b
mypy: Swap order of `user` initialization in ZulipPasswordResetForm.save.
...
When running with `--strict-optional`, this helps mypy see what's
going on here.
[Fix changed by greg.]
2017-12-23 01:22:22 +09:00
neiljp (Neil Pilgrim)
7c819f4d90
mypy: Account for Optional variables in addressee.py.
2017-12-23 01:22:22 +09:00
neiljp (Neil Pilgrim)
57e7ec94a0
mypy: Adjust 2 emoji.py functions to allow for strict-optional.
2017-12-23 01:22:22 +09:00
neiljp (Neil Pilgrim)
451af39561
mypy: Correct get*notifications_stream to return Optional[Stream].
2017-12-23 01:22:22 +09:00
neiljp (Neil Pilgrim)
d01dcbd018
mypy: Amend tos_version parameter of create_user_profile to be Optional.
...
tos_version is marked as Optional[Text] in UserProfile & is Optional
in other places within zerver/lib/create_user.py
2017-12-23 01:22:22 +09:00
Aastha Gupta
78e8d18ef3
integrations: Rename HUBOT_INTEGRATIONS_LEGACY.
...
It is now simply called HUBOT_INTEGRATIONS.
Fixes #7402
2017-12-22 10:38:47 -05:00
Angelika Serwa
2f575cca72
Add Dropbox webhook integration.
...
This is just a basic Dropbox webhook integration. It just
notifies a user when something has changed, it does not
specify what changed. Doing so would require storing data,
as Dropbox API was created mainly for file managers, not
integrations like this.
Closes #5672
2017-12-22 10:36:21 -05:00
Marco Burstein
6fc50fa21a
mypy: Use Python 3 type syntax in `zerver/webhooks/sentry/view.py`.
2017-12-22 08:17:00 -05:00
Marco Burstein
34001081c2
mypy: Use Python 3 type syntax in `zerver/webhooks/yo/view.py`.
2017-12-22 08:17:00 -05:00
Marco Burstein
678b43494b
mypy: Use Python 3 type syntax in `zerver/webhooks/airbrake/view.py`.
2017-12-22 08:17:00 -05:00
Marco Burstein
9327048f6f
mypy: Use Python 3 type syntax in `zerver/lib/events.py`.
2017-12-22 08:17:00 -05:00
Marco Burstein
2acf3cf1d4
mypy: Use Python 3 type syntax in `zerver/webhooks/mention/view.py`.
2017-12-22 08:17:00 -05:00
Marco Burstein
017476cdfb
mypy: Use Python 3 type syntax in `zerver/lib/create_user.py`.
2017-12-22 08:17:00 -05:00
Marco Burstein
e7f0139f69
mypy: Use Python 3 type syntax in `zerver/webhooks/travis/view.py`.
2017-12-22 08:17:00 -05:00
Tommy Ip
9ea7b05cfe
bugdown: Rewrite markdown link to relative link conditionally.
2017-12-22 08:10:42 -05:00
Tommy Ip
efe2d497f4
bugdown: Avoid matching uri with regex.
2017-12-22 08:10:42 -05:00
Tommy Ip
9ce797d68c
bugdown: Extract rewrite_if_relative_link function.
2017-12-22 08:10:42 -05:00
Umair Khan
898acc4278
missed-message-worker: Send email through email_senders.
...
We have shifted to a generic queue to send all the emails. This queue
can retry in case of network issues; this makes sure that the emails are
always sent.
2017-12-20 19:36:27 -08:00
Umair Khan
e0f30d02f2
email-worker: Send login email through queue.
...
Fixes #7460
2017-12-20 19:36:27 -08:00
Umair Khan
68513952fb
email-worker: Create EmailSendingWorker.
...
This commit just copies all the code from MissedMessageSendingWorker
class to a new EmailSendingWorker class. All the logic to send an email
through a queue was already there. This commit only makes the logic
generic. It does so by creating a special purpose queue called
'email_senders' to send any type of email. To make
MissedMessageSendingWorker still work we derive it from
EmailSendingWorker. All the tests that were testing
MissedMessageSendingWorker now run against EmailSendingWorker.
2017-12-20 19:36:27 -08:00
Vishnu Ks
16d8244c0a
tests: Eliminate 'Sending invitation' output spam in test_signup.
...
Fixes #7563
2017-12-20 18:50:01 -08:00
neiljp (Neil Pilgrim)
25d5a2ee1c
requirements: Upgrade mypy to 0.560.
...
Fixes #7835 .
2017-12-20 18:09:36 -08:00
Rishi Gupta
c2a41c268f
models: Update Realm.get_admin_users to not use select_related().
...
None of the uses of this function in the codebase follow any of the foreign
keys of UserProfile.
2017-12-20 08:51:58 -05:00
snlkapil
1589c597d2
settings: Show local time instead of UTC in invitations tab.
2017-12-20 07:08:46 -05:00
Rishi Gupta
27a8ef86e4
actions: Add realm deactivation and reactivation to RealmAuditLog.
2017-12-19 17:46:36 -08:00
Rishi Gupta
4261307e27
emails: Clear ScheduledEmail emails on realm deactivation.
...
This only affects the invitation reminder emails; clear_scheduled_emails was
already clearing the other two types.
2017-12-19 17:46:36 -08:00
Rishi Gupta
869b4d41ef
models: Add ScheduledEmail.realm.
...
The two extra queries in the test are due to the assert in
send_future_email.
2017-12-19 17:46:36 -08:00
Rishi Gupta
87e164043f
portico: Rename plans at /plans.
2017-12-19 15:36:13 -08:00
ViRu-ThE-ViRuS
c8aadaa408
integrations: Add webhook payloads for Intercom.
2017-12-19 16:50:06 -05:00
Eeshan Garg
8936d03f3a
webhooks/gitlab: Support Merge Request Hook approved event type.
...
Such payloads are generated when a GitLab repository has merge
request approvals enabled and a project member approves a merge
request. Approving is not the same as merging.
2017-12-18 19:12:54 -05:00
Andy Perez
44e6d9b54b
testing: Add nice diffs to markdown python tests.
2017-12-18 19:03:38 -05:00
Andy Perez
695affd44e
node tests: Compare markdown using semantic equivalence.
...
Fix #4367
2017-12-18 19:03:38 -05:00
Greg Price
776af2e248
push notifs: Simplify content-truncation code slightly.
...
This should be a pure refactor.
2017-12-18 15:32:56 -08:00
Greg Price
014900c2e5
push notifs: Include same stream and sender info on GCM as on APNs.
...
This takes the information added to APNs payloads by #7080 , and adds
to our GCM payloads the parts that it didn't already have.
2017-12-18 15:32:56 -08:00
Greg Price
e077d6fc74
push notifs: Factor out common payload fields for APNs and GCM.
...
This should be a pure refactor, producing exactly the same payloads.
2017-12-18 15:32:56 -08:00
Eeshan Garg
21008a49b9
webhooks/gci: Support approve-pending-pc event type.
...
This event is generated when a mentor approves a task but
GCI is still waiting on a student's parental consent.
2017-12-18 10:00:20 -08:00
Callum Fraser
a61a7f3965
mypy: Use Python 3 type syntax in zerver/webhooks/pingdom/view.py.
2017-12-18 11:32:52 -05:00
Callum Fraser
4508264f25
mypy: Use Python 3 type syntax in zerver/webhooks/opsgenie/view.py.
2017-12-18 11:32:52 -05:00
Callum Fraser
52f0c4472e
mypy: Use Python 3 type syntax in zerver/webhooks/ifttt/view.py.
2017-12-18 11:32:52 -05:00
Callum Fraser
23b29212a3
mypy: Use Python 3 type syntax in zerver/webhooks/greenhouse/view.py.
2017-12-18 11:32:52 -05:00
Callum Fraser
403ea486e4
mypy: Use Python 3 type syntax in zerver/webhooks/gogs/view.py.
2017-12-18 11:32:52 -05:00
Callum Fraser
33e1879295
mypy: Use Python 3 type syntax in zerver/webhooks/beanstalk/view.py.
2017-12-18 11:32:52 -05:00
Callum Fraser
c55685063f
mypy: Use Python 3 type syntax in zerver/webhooks/appfollow/view.py.
2017-12-18 11:32:52 -05:00