hatnote/montage

When editing votes, GET error is triggered

lgelauff opened this issue · 5 comments

I'm testing on montage-dev.

Reproduce: Create a campaign, create a round (eg with

  • Images from Wiki Loves Monuments 2017 in Ghana
  • rating
  • no restrictions
  • 1 juror: you

vote a few images. Then click 'edit my votes'. This triggers a GET error. angular.js:12189 GET https://montage-dev.toolforge.org/v1/juror/round/105/votes?offset=7&order_by=date&sort=desc 403

Hey Lodewijk! Great find + report. Note that the montage-dev backend (where this error is coming from) is pretty far ahead of production right now (just waiting for international round to wrap so that I can upgrade safely). I see the 403 and am investigating. If there's a blocker on production, let me know as well!

Hmm, having more trouble reproducing this as your user. Just checking at the console (mostly a note to my future self):

>>> session.query(Vote).options(joinedload('round_entry')).filter(Vote.user_id == 409, Vote.round_entry.has(round_id=105), Vote.status == COMPLETED_STATUS).order_by(Vote.modified_date.desc()).limit(15).offset(7).all()
[<Vote id=47479 user_id=409>, <Vote id=47482 user_id=409>, ...]

So no explanation yet. If you visit the URL you mentioned (link) directly, what do you see?

I get tables with the information, and no errors.

However, 105 doesn't seem to be an active round? Lets try 112. If I then go to the same direct endpoint, I get 403 forbidden ("no complete ratings") while I made sure to have 4 photos rated.

Ah, remove the offset=4 from that URL and it'll likely work. I wonder if the frontend is generating the wrong URL in some cases.

Yup, that seems to do the trick