Skip to content

Sähköisen äänestyksen tuloslaskentapalvelu (irroitettu uurnavaalin ehdokastietojärjestelmästä)

License

Notifications You must be signed in to change notification settings

hyy-vaalit/vaalitulostin

Repository files navigation

Sähköisen äänestämisen tuloslaskentapalvelu

Palvelu on irroitettu ehdokastietojärjestelmästä itsenäiseksi osaksi palvelemaan sähköistä äänestämistä.

Käyttäjätyypit

Järjestelmässä on ainoastaan yksi käyttäjätyyppi: AdminUser. Pääsyoikeustasot on määritetty tiedostossa app/models/ability.rb.

  • Pääkäyttäjä AdminUser
    • app/models/admin_user.rb
    • Täysi oikeus kaikkeen.

Testiajo

rake db:runts
rspec
rake db:seed:demo

Vaalitulostimen käynnistäminen:

foreman run worker
rails s
tail -f log/development.log

Käynnistä voting-apin web ja worker (ks. ohjeet voting-api/README).

Avaa http://127.0.0.1:3001/

  • [email protected] / pass123
  • "Failed to open TCP connection to localhost:3000" tarkoittaa ettei voting-api ole käynnissä.

Hae äänet Voting API:lta ja laske vaalitulos:

Delayed::Job::enqueue(ImportVotesJob.new(VotingArea.first))

ImportVotesJob käynnistää myös tuloksen laskennan.

Kun lähetät sisäänkirjautumislinkin, voting-apin workerin pitää olla käynnissä saadaksesi siitä sähköpostin. Voit tarkistaa sisäänkirjautumislinkin tiedot ajamalla seuraavan komennon voting-api:n hakemistossa:

 rake jwt:voter:verify jwt=EMAIL_LINKISSÄ_OLEVA_TOKEN

Testiajo Voting API:sta haetuilla äänillä

Syötä vuoden 2009 demo-äänet Voting API:iin:

voting-api> rake db:runts
voting-api> rake db:seed:edari:demo
voting-api> rake db:seed:edari:demo:votes

Aseta Voting API:ssa äänestys päättyneeksi, jotta äänet voidaan hakea.

Syötä Vaalitulostimen .env VOTING_API_JWT_APIKEY.

voting-api> rake jwt:service_user:generate expiry_hours=1000

Käynnistä Vaalitulostimen web ja worker (ohjeet ylempänä).

Hae äänet Vaalitulostimeen Voting API:sta: http://127.0.0.1:3001/manage/results

Virheilmoitus näkyy tietodstossa log/development.log. Vastaus HTTP 401 tulee,jos vaalit eivät ole vielä päättyneet. voting-api> ELECTION_TERMINATES_AT, VOTE_SIGNIN_ENDS_AT

Testiajo Vaalitulostimen demodatan vuoden 2009 äänillä

Syötä äänet seed-datasta käyttäen vain yhtä äänestysaluetta:

rake db:seed:development:internet_votes_2009

Syötä äänet seed-datasta vuoden 2009 äänestysalueille:

rake db:seed:development:voting_areas_2009
rake db:seed:development:votes_2009

Laita jonoon tuloksen laskentatyö:

VotingArea.all.each { |a| a.ready!; a.submitted! }
Delayed::Job.enqueue(CreateResultJob.new)

Tulosta konsoliin:

puts ResultDecorator.decorate(Result.last).to_html

Merkitse tulos valmiiksi arvontoja varten:

Result.freeze_for_draws!

Heroku-ympäristön pystyttäminen

Pystytä ensin voting-api.

Nollaa aiempi tietokanta poistamalla Heroku Postgres addon ja lisäämällä se uudelleen.

  • Testailussa voi käyttää ilmaista Postgres addonia, mutta se menee lukkoon jos tietokantaan syöttää yli 10 000 riviä (kokonaisen testiajon kaikki äänet).
  • Tuotantoa varten valitse maksullinen Postgres Hobby $9/kk.

Alusta tietokanta:

  • rake db:schema:load

Luo äänestysalue ja tiedekunnat:

  • rake db:seed:production

Lataa Seed-data Ehdokasjärjestelmän tiedoilla:

  • Valitse Ehdokasjärjestelmän admin-käyttöliittymästä csv-export kullekin resurssille.

  • Kun sinulla on candidates.csv, alliances.csv ja coalitions.csv, suorita:

    • rake db:seed:edari
  • Luo admin-käyttäjä vaalityöntekijälle:

    • AdminUser.create!(:email => '[email protected]', :password => 'buggy-GLAMOR-posit-santiago', :password_confirmation => 'buggy-GLAMOR-posit-santiago')

Admin-käyttäjiä voi lisätä järjestelmään äänioikeutettuja, kun äänestys on käynnissä.

  • Äänestyksen aikana lisätty äänioikeutettu voi kirjautua yliopiston käyttäjätunnuksella.

  • Jos äänioikeutetulla ei vielä ole yliopiston käyttäjätunnusta, Admin-käyttöliittymästä voi lähettää hänelle sähköpostitse sisäänkirjautumislinkin.

  • Linkin käyttäjää ei vahvisteta muuten kuin tarkistamalla, että linkki on yhä voimassa.

  • Linkin voimassaolo määritetään voting-api:n EMAIL_LINK_JWT_EXPIRY_MINUTES asetuksessa.

  • Luo voting-api service user jwt api token

    • voting-api: heroku run -r prod rake jwt:service_user:generate expiry_hours=1000
    • Aseta JWT Herokussa vaalitulostimen VOTING_API_JWT_APIKEY -ympäristömuuttujaan
  • Scheduloi taustajobit statsien päivittämistä varten

    • Delayed::Job.enqueue(ImportVotesByVoterStartYearJob.new)
    • Delayed::Job.enqueue(ImportVotesByHourJob.new)
    • Delayed::Job.enqueue(ImportVotesByFacultyJob.new)
    • Delayed::Job.all

AWS S3

Vaalitulostin kirjoittaa lasketun vaalituloksen AWS S3:een.

AWS IAM -käyttöoikeudet antavat kirjoitusoikeuden vuosiluvun mukaiseen hakemistoon:

  • vaalitulostin-YMPÄRISTÖ/vuosiluku
  • esimerkiksi vaalitulostin-qa/2020

Päivitä jokaisen ympäristön (prod, qa, test) IAM-rooliin oikean vuosiluvun hakemisto.

  • Avaa IAM > Users > Permissions

Luo jokaisen ympäristön S3 Buckettiin vuosiluvun mukainen hakemisto AWS web-käyttöliittymästä.

  • IAM-käyttäjällä ei ole oikeutta luoda uusia hakemistoja.

Testaa S3-kirjoitusoikeus:

About

Sähköisen äänestyksen tuloslaskentapalvelu (irroitettu uurnavaalin ehdokastietojärjestelmästä)

Resources

License

Stars

Watchers

Forks

Packages

No packages published