1017 Commits

Author SHA1 Message Date
Deimos
e8f8885f22 Don't post full "backlog" of scheduled topics
This will probably only ever be relevant in development environments,
but we don't want the topic scheduler to always post a full backlog of
scheduled topics when it hasn't run for a while. For example, if a dev
environment has a daily scheduled topic set up, but the VM is not
launched for a week, the next time the "post scheduled topics" cronjob
runs, it will post all 7 of the backlogged topics.

This commit changes the script so that it advances the schedule to the
next *future* occurrence, instead of continuing the backlog.
2020-05-26 18:48:40 -06:00
Deimos
740f71d339 TopicQuery: include ignored topics by default
Previously, TopicQuery was excluding ignored topics by default. However,
this caused some unexpected issues, such as a crash when someone tried
to vote on a topic after ignoring it. I think it's more intuitive to
reverse the logic like this: include the ignored topics by default, and
only specifically exclude them in the cases where that's necessary.
2020-05-25 19:54:27 -06:00
Deimos
ce9ae214d8 Adjust posting rate-limits 2020-05-21 19:24:55 -06:00
Deimos
384c5c985f Salt: move postgresql-redis bridge to own state 2020-05-15 16:45:46 -06:00
Deimos
78002847ba Fix environment check in Prometheus config
Checking for prod isn't correct - we want the monitoring server to have
these entries so that it can scrape them from prod.
2020-05-15 16:08:39 -06:00
Deimos
d5453cf286 Exclude forums.terraria.org from url transforms
This forum uses the same invalid url scheme as the Paradox forums, so
needs to be excluded as well.
2020-05-15 15:24:44 -06:00
Deimos
b011be34ef Add simple metrics to event stream consumer jobs
This adds some very simple metrics to all of the background jobs that
consume the event streams. Currently, the only "real" metric is a
counter tracking how many messages have been processed by that consumer,
but a lot of the value will come from being able to utilize the
automatic "up" metric provided by Prometheus to monitor and make sure
that all of the jobs are running.

I decided to use ports starting from 25010 for these jobs - this is
completely arbitrary, it's just a fairly large range of unassigned
ports, so shouldn't conflict with anything.

I'm not a fan of how much hard-coding is involved here for the different
ports and jobs in the Prometheus config, but it's also not a big deal.
2020-05-14 18:19:26 -06:00
Deimos
42f99a82ba Add temporary bans (manual)
This enables me to set a ban expiry time for a user (manually, in the
database). By doing so:

* The user's page will say that they're temporarily banned, and show the
  date their ban will be lifted.
* If the user tries to log in, it will say they're temporarily banned,
  and give a specific datetime that the ban will be lifted by.
* An hourly cronjob will lift any bans that have expired.
2020-05-09 14:25:20 -06:00
Deimos
7e96fb00b7 Update error message for breached passwords
This isn't always in the sidebar, so the previous message could be
confusing.
2020-05-09 12:22:56 -06:00
Deimos
25e4207563 Login: show whether username or password was wrong
I get a fair number of "forgot password" emails where the person is
actually trying to log in with the wrong username. Normally, a login
system shouldn't display whether the username or password was the
incorrect part, but since it's already public information which
usernames exist on Tildes (simply by visiting /user/<username>), this
really isn't meaningfully hiding anything. It would only have any effect
on the most absolutely naive attackers. I think it's an acceptable
trade-off to help out people that are inadvertently trying to log in
with the wrong username instead.
2020-05-08 18:22:17 -06:00
Shahzaib Sahibzada
d901abfb84 Fix tag autocompletion when space between tags
Previously, typing a space at the start of a tag would prevent the
autocomplete options from appearing.
2020-05-04 19:56:44 -06:00
Deimos
c85eec1c84 Fix tag/unfiltered info not showing on home page
Adding the info about the coronavirus views overrode this block, so we
can just show either (or both, which probably shouldn't happen, but
could) by doing this.
2020-04-29 18:18:35 -06:00
Deimos
56f709bda2 Add a current_theme request method 2020-04-14 19:39:20 -06:00
dougmellon
2e8623c22f Show theme switcher in footer for logged-in users 2020-04-14 18:39:12 -06:00
Deimos
9cd86ad33d Salt pillar: update Prometheus IP to IPv6
I've switched the Prometheus server to communicate over IPv6 now, so
this needs to be updated to make the nginx configuration correct.
2020-04-14 18:39:12 -06:00
dougmellon
b707e2b9bb Remove aria-label from divs
This is a recommendation from the W3C validator: "Don't use aria-label
or aria-labelledby on a span or div unless its given a role."
2020-04-07 15:06:27 -06:00
Deimos
f2c0b68f78 Monitoring server: add blackbox exporter
This is a prometheus exporter that allows checking IPv4 and IPv6
responses, among other things. This sets it up to make sure that the
site is responding over both IPv4 and IPv6, so that I can monitor and
set up an alert if either stops working.
2020-04-03 17:49:20 -06:00
Deimos
284c3cfd8d Treat scheduled-topic title/markdown as Jinja
This probably isn't particularly safe, but it's fine since I'm the only
one that can create or edit scheduled topics for now. The only available
variable so far is current_time_utc.
2020-03-25 16:32:01 -06:00
Timo
f0305bc0cd Show donation meter on financials page 2020-03-23 17:35:17 -06:00
Deimos
a0d62be6cb Fix more minor styling issues with header views 2020-03-21 11:04:17 -06:00
Deimos
2c6967b3da Fix alignment of "segmented" subgroup header links 2020-03-20 18:16:39 -06:00
Deimos
4dedcf1716 Add more space between groups on the group listing 2020-03-19 17:42:28 -06:00
Deimos
3903c6f6de Refactor site header HTML/CSS away from flexbox
I don't like this as much, but it works better to be able to wrap the
coronavirus views bar underneath the logo on small screens.
2020-03-19 16:55:25 -06:00
Deimos
dbaf4c61e2 Stop specialized views breaking on thin screens
This isn't great, but at least it won't be as broken as it was before.
I'll try to follow this up with a better improvement soon.
2020-03-19 11:59:56 -06:00
Deimos
fea2884343 Move coronavirus views into header
This is a little awkward on mobile, but it doesn't take up any more
vertical space than the previous version did, and is much better on
desktop.
2020-03-18 19:43:07 -06:00
Deimos
0ea9d81a6b Add id to bar with coronavirus views
To make it easier for people to hide using local CSS, uBlock element
filtering, etc.
2020-03-18 15:42:29 -06:00
Deimos
3f1decb243 Add global autocomplete tags
This is kind of hacky again (and shouldn't contain the coronavirus tag
over the long term), but makes sure that the "spoiler", "nsfw", and
"coronaviruses.covid19" tags are always offered as autocomplete options,
no matter how common they are in the topic's group.
2020-03-17 17:05:42 -06:00
Deimos
355dd9d334 TEMP: Add some hacky coronavirus "views"
This adds two links at the top of the home page that go to different
"views" - one includes only topics related to the coronavirus, while the
other filters out all coronavirus topics.

For the purposes of these views, a "coronavirus topic" is one that is
either in the ~health.coronavirus group, or has coronaviruses.covid19
tag.

This is very hacky and will only work on the main tildes.net site due to
hardcoded group name and tag. I'm okay with that.
2020-03-17 16:28:59 -06:00
Deimos
1c739d9736 Update groups page layout + show activity stats
This replaces the groups page with a new list style that doesn't include
the ability to subscribe/unsubscribe directly on the page, and also
shows approximate activity statistics (daily topics/comments) for each
group.
2020-03-12 18:25:31 -06:00
Deimos
7d1c3297fb Add group_stats table, track daily topics/comments
This adds a group_stats table and cronjob that will insert the previous
day's stats into it each day just after 00:00 UTC.
2020-03-09 17:57:43 -06:00
Deimos
01752141fc Salt: set overall server timezone to UTC 2020-03-05 20:55:12 -07:00
Deimos
c8f8697767 Fix autocomplete chip X "ends with" conflicts
Let's try this again without the regex.

Clicking the X button in an autocomplete chip could inadvertently remove
the wrong tag (and cause a weird "merging" behavior) if another tag
ended with the same text as the one being removed. For example, if a
post had both "one.two" and "two" tags and you clicked the X button on
the "two".
2020-03-05 14:13:11 -07:00
Deimos
6e610be349 Revert "Fix autocomplete chip X "ends with" conflicts"
This reverts commit 83ce08248d.
2020-03-05 01:03:50 -07:00
Deimos
83ce08248d Fix autocomplete chip X "ends with" conflicts
Clicking the X button in an autocomplete chip could inadvertently remove
the wrong tag (and cause a weird "merging" behavior) if another tag
ended with the same text as the one being removed. For example, if a
post had both "one.two" and "two" tags and you clicked the X button on
the "two".
2020-03-04 17:56:15 -07:00
Deimos
c5492cf4ed Minor updates to Financials and donation goal
Just a couple relatively minor updates to the financial stuff:

* Removed the "is_approximate" column on the table and just added a more
  general note about most of the amounts being approximate. It was more
  annoying to worry about than meaningful.
* Some style/layout/wording tweaks to the donation goal to try to make
  it a little more obvious that this is a long-term sustainability goal.
2020-03-04 17:09:34 -07:00
Deimos
3f6bd60281 Fix comment labeling permission check 2020-03-02 15:44:03 -07:00
Deimos
13d7e97e4c Fix some comments from permissions rework
Whoops, forgot to squash this in before pushing.
2020-03-02 15:44:03 -07:00
Deimos
94b9e1bf10 Rework permissions/ACL system
This is a major rework of the permissions system to enable various new
capabilities and clean up some of the oddities that were there.
Highlights:

- The concept of "admin" permission is removed. All permissions must be
  granted individually.
- Permissions can now be granted on a group-specific level, such as
  giving a user the ability to tag topics only in a specific group.
- Permissions can also be denied for a specific group (or all groups),
  enabling uses like "tag topics in all groups except ~music".
- Removed the two cases where "all permissions" were granted: users on
  themselves and the sender and recipient on messages. This was
  dangerous, we should always grant permissions explicitly.
- Eliminated all the granular permissions for changing a user's settings
  (which were all granted implicitly), and replaced with an overall
  "change_settings" permission.
2020-02-29 15:22:06 -07:00
Deimos
9ab70c440c Update cleanup script for new permissions table 2020-02-29 14:45:41 -07:00
Deimos
62b0adc983 Move user permissions into their own table
This is a bit of an odd commit: it adds a user_permissions table that
has capabilities that are not yet usable. Specifically, the table allows
setting DENY permissions as well as restricting permissions to an
individual group, but neither of those work yet. I want to make sure
that the existing, limited permission system seems to transfer over
properly before adding the additional complexity for those.

The Alembic data migrations for this commit is fairly ugly, but seem to
work okay.
2020-02-27 19:20:30 -07:00
Deimos
2532df018c Strip trailing periods from topic titles
Note that this will also prevent a title from ending with "...". I did a
search for all titles that ended in that, and none of them seemed
essential (and probably should have been removed), so I think this
should be fine.
2020-02-26 15:08:56 -07:00
Bauke
2c7572016d Add setting to choose default comment sort order 2020-02-20 14:32:21 -07:00
Deimos
89c7c13be2 Reload gunicorn when site-icons CSS updates
This starts using webassets for the site-icons.css file inside the base
template so that a cache-busting "version" string is added after the
filename as a query variable (as was already being done with the other
CSS and JS files).

It also creates a new service that's triggered by a "path changed" event
on site-icons.css, which causes gunicorn to reload. This should mean
that whenever the site-icons.css file is updated by the cronjob that
generates it, gunicorn will automatically reload and update the
cache-busting string for the CSS file, causing users' browsers to update
to the newest version.
2020-02-12 21:23:30 -07:00
Deimos
4dc99d9fda Vagrantfile: pin Salt version to 2019.2.3
The new version of Salt ("3000") seems to have a number of bugs,
including not being able to handle "unless" checks, which the Tildes
states use frequently. Because of this, creating a new dev environment
currently doesn't work. This pins Salt to the previous stable version
for now.

Here's the relevant bug for "unless" specifically:
https://github.com/saltstack/salt/issues/56131

And the overall release notes:
https://docs.saltstack.com/en/latest/topics/releases/3000.html
2020-02-12 21:03:45 -07:00
Deimos
97e8d756df Improve wrapping of content metadata for topics 2020-02-10 18:43:48 -07:00
Deimos
4371f9cef6 Don't show View Markdown for logged-out users 2020-02-10 18:23:39 -07:00
Deimos
2724dc9a98 Add SiteInfo entries for more common sites 2020-02-10 18:07:01 -07:00
Deimos
c63e6e0fd2 Move "More" button on comments left of Reply
I'm not sure about this, but want to try it. I like Reply being the last
button.
2020-02-10 14:04:16 -07:00
Deimos
d0e23ef1b5 Remove leftover extra margins on footer links 2020-02-10 11:27:49 -07:00
Deimos
3b62d2adf7 Improve centering/spacing/wrapping of footer links 2020-02-09 16:40:52 -07:00