Skip to content

Latest commit

 

History

History
740 lines (621 loc) · 32.2 KB

CHANGELOG.md

File metadata and controls

740 lines (621 loc) · 32.2 KB

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.

Added

  • Emails for Hugo voting
  • Integration into The Fantasy Network for 2020 Virtual Worldcon !194 Add this to you env
    GLOO_BASE_URL=https://api.thefantasy.network/v1
    GLOO_AUTHORIZATION_HEADER=
    
    Full sync with
    GlooSync.all_users
  • Hugo finalists for 2020 are now available !155. Note, links only show up when you load them, yes this is order dependent
    bin/rake db:seed:conzealand:production_finalist
    bin/rake db:seed:conzealand:production_rename_hugo

Changed

  • Adds Hugo voting emails !199
  • In development, allow Sidekiq to use redis in if you set SIDEKIQ_REDIS_URL !194
  • Create documentation around classes in models, queries and commands folders !191
  • Rename "2020-wellington" to just "wellington" !191
  • Update Rails against allowing untrusted users to run migrations on production !196
  • Update Rack against cookie override vulnerability !196
  • Mount working directory to /hack for conzealand development !198
  • Update all node modules !202

Removed

  • Removed "Suggest for our Programme (coming soon)" and "Plan my trip(coming soon)" from CoNZealand menu !203

Added

  • Hugo Packet Download now has a counter, if downloaded or nomination rights used there's a message for support users near the "transfer membership" button. !182

Changed

  • Development process modified to reduce docker use for rails. The README now covers the direnv/local rails approach !181

Removed

  • Nothing significant in this release

Added

  • Hugo Packet Download !101 Lots of configuration for this one.
    1. Get the materials from the Hugo admins
    2. Put them in an S3 bucket that you control
    3. Create a user with programatic access that has read only access to this bucket
    4. Generate AWS keys for that user
    5. Configure on production / staging / local with the following:
      HUGO_PACKET_BUCKET=FROM_STEP_2
      HUGO_PACKET_PREFIX=FROM_STEP_2
      AWS_REGION=ap-southeast-2
      AWS_ACCESS_KEY_ID=FROM_STEP_4
      AWS_SECRET_ACCESS_KEY=FROM_STEP_4
    !176
  • Hugo voting dates have changed!
    HUGO_CLOSED_AT="2020-07-15T23:59:59+13:00"
  • Development database reset in docker by setting NAPALM=true in your .env !162
  • Support for theming by setting WORLDCON_THEME in .env !103
    WORLDCON_THEME=conzealand

Changed

  • CI now only runs security-audit steps for master, or branches named security-patch !178
  • CI now only fails javascript audit if there's a CVE with a patch, or a CVE that's been out for 6 months !173
  • make sql in development brings up a psql session in the container !166
  • Security patching webpacker against prototype pollution npm advisory #1500 !164
  • Security patching against denail of service in webpacker npm advisory #1486 !177
  • Securtiy patching rails against CVE-2020-8166, CVE-2020-8167, CVE-2020-8162 and CVE-2020-8165 !177
  • Security patching puma against http smuggling attack CVE-2020-11076, !178
  • Security patching against cross site scripting npm advisory #1518 !169
  • Ruby linting rules are now a soft requirement, turned them of in CI !165
  • Use fontawesome icons instead of octicons for variety !166
  • Booting the rails app now waits for postgres using psql for reliability !166

Removed

  • Kiosk mode is deprecated as your first login dosen't make you check your email !161
  • Set Rails 6 application defaults !174

Added

  • Nothing significant in this release

Changed

Removed

  • Nothing significant in this release

Added

  • Nothing significant in this release

Changed

  • Fixed a bug where hugo admins were unable to edit nominations !154

Removed

  • Nothing significant in this release

Added

  • Automatic sign-in for first time users, second time users require email confirmation !132 -- this may possibly replace Kiosk mode
  • Setup scheduled export on Friday @11pm with 3rd party Hugo Nominations database based on SQL Server !147. Enable by setting:
    TDS_USER=admin
    TDS_PASSWORD=jah2Eifaepoo5fiekaiF3ahnah6pah3o
    TDS_HOST=hugo.ji1Jae0cue1.ap-southeast-2.rds.amazonaws.com
    TDS_DATABASE=Hugo2020
  • Setup automatic send of "3 days to go" mailer when nominations are 72 hours from close !152
  • Created basic mailers for 2 week to go reminder emails !152 Run these with...
    dublin_users = User.joins(reservations: :membership).where(memberships: {name: :dublin_2019});
    total = dublin_users.count
    dublin_users.distinct.find_each.with_index do |user, n|
      puts "#{Time.now.iso8601} Dublin #{n} of #{total}" if n % 10 == 0
      HugoMailer.nominations_reminder_2_weeks_left_dublin(email: user.email).deliver_now
    end;
    
    conzealand_users = User.joins(reservations: :membership).where.not(reservations: {state: Reservation::DISABLED}).merge(Membership.can_nominate).where.not(id: dublin_users);
    total = conzealand_users.count
    conzealand_users.distinct.find_each.with_index do |user, n|
      puts "#{Time.now.iso8601} Conzealand #{n} of #{total}" if n % 10 == 0
      HugoMailer.nominations_reminder_2_weeks_left_conzealand(email: user.email).deliver_now
    end;
  • Setting Hugo Admin flag on Support now allows Admins to change nominations at any time with audit notes !153. Add it to user accounts with...
    Support.where(email: %w(
      user1@conzealand.nz
      user2@conzealand.nz
      user3@conzealand.nz
    )).update_all(hugo_admin: true)
  • Support user can now enable/disable membership rights on reservations !153.

Changed

  • Hugo tweaks post launch !146. These include:
    • Remove the title field from what you type to see the hugo form
    • Don't let more than 5 entries be submitted for nominations
    • Create test mailer for testing SMTP settings
    • Update Hugo text in several areas including account text and in the form
    • Added explicit PM to hugo nominations close time
    • Stop support users from viewing nominations
  • Update node dependencies !146.
  • Upgrade gem dependencies !146.
  • Multiple workarounds for CI to run !151
  • Security patch Puma against CVE-2020-5247 CVE-2020-5247 !151
  • Security patch Nokogiri against CVE-2020-7595 CVE-2020-7595 !151
  • Login links now last 30 minutes !153

Removed

  • Nothing significant in this release

Added

  • Nothing significant in this release

Changed

  • Hugo Nominations deadline now reads PDT rather than PST !145

Removed

  • Nothing significant in this release

Added

  • Nothing significant in this release

Changed

  • Bugfix: Dublin members can now vote !144

Removed

  • Nothing significant in this release

Added

  • Sidekiq to monitor and schedule background jobs mounted on /sidekiq !139. You can get it to show up by setting your .env with these examples but a different password
    SIDEKIQ_REDIS_URL=redis://redis:6379/0
    SIDEKIQ_USER=sidekiq
    SIDEKIQ_PASSWORD=5b197341fc62d9c9bbcopypastabc7a6cbcf07329c9fe52fa55cab98e
    You'll need to have a redis server available, or add it to your docker-compose.yml
    volumes:
      redis-data:
    
    services:
      redis:
        image: redis:alpine
        restart: always
        volumes:
          - redis-data:/data
    
      production_worker:
        entrypoint: "script/docker_sidekiq_entry.sh"
        image: registry.gitlab.com/worldcon/wellington:stable
        env_file:
          production.env
        restart: always
        volumes:
          - type: tmpfs
            target: /app/tmp
  • Disable sidekiq basicauth for development by setting SIDEKIQ_NO_PASSWORD in your .env !139
    SIDEKIQ_NO_PASSWORD=true
  • New scheduled mailer to email nomination ballots between 10 and 30 minutes after last submission !139

Changed

  • Added explicit order to Hugo Categories, migrate existing data with
    make bash
    bin/rake db:seed:conzealand:production_hugo_ordering
    
  • Text changes around the nomination forms for clarity !139
  • Docker compose is now based on :latest image built by CI to speed up cycle time in development !139
  • Running make start now runs docker-compose in the foreground, and Control + C quits !139
  • Upgrading memberships accumulates membership rights. Now Dublin upgrading to Supporting gets Nomination and Voting rights, and Supporting upgrading to Adult gets Nomination, Voting and Attending rights !140
  • Dublin imports record dublin membership number against account
  • !143

Removed

  • Nothing significant in this release

This release brings with it the basics to let our users nominate for the Hugo awards.

Added

  • Added Hugos state configuration !89. Please set these values in your .env on all environments:
    # Times when parts of the members area will become active
    HUGO_NOMINATIONS_OPEN_AT="2019-12-31T23:59:00-08:00"
    HUGO_VOTING_OPEN_AT="2020-03-13T11:59:00-08:00"
    HUGO_CLOSED_AT="2020-08-02T12:00:00+13:00"
  • Created seeds for Dublin memberships and Hugo awards to automatically show up with new Development or Production seeds !137 and !89. Migrate existing instances with
    make bash
    bin/rake db:seed:conzealand:production_dublin
    bin/rake db:seed:conzealand:production_hugo
  • Seeds are setup to disable nominations for memberships sold in 2020 !137
    make bash
    bin/rake db:seed:conzealand:production_disable_nomination
  • Links to Hugo and Retro Hugo are now present on the membership cards !89.
  • Memberships now have a flag to say if they can site select !136
  • Dublin memberships importer built from Tammy's unduplicated memberships list !137
    make bash
    DUBLIN_SRC="unduplicated members-Table 1.csv" bin/rake import:dublin
  • People who have paid an instalment which covers a Supporting membership can nominate in Hugo !138
  • You can now adjust instalment minimum payment and payment step amounts by setting them in your environment !138
    INSTALMENT_MIN_PAYMENT_CENTS=7500
    INSTALMENT_PAYMENT_STEP_CENTS=5000
  • Dublin and CoNZealand nomination memberships now have mailers to tell them when Nominations are open. !137 You can run these from Rails Console with:
    dublin_users = User.joins(reservations: :membership).where(memberships: {name: :dublin_2019});
    total = dublin_users.count
    dublin_users.distinct.find_each.with_index do |user, n|
      puts "#{Time.now.iso8601} Dublin #{n} of #{total}" if n % 10 == 0
      HugoMailer.nominations_open_dublin(user: user).deliver_now
    end;
    
    conzealand_users = User.joins(reservations: :membership).where.not(reservations: {state: Reservation::DISABLED}).merge(Membership.can_nominate).where.not(id: dublin_users);
    total = conzealand_users.count
    conzealand_users.distinct.find_each.with_index do |user, n|
      puts "#{Time.now.iso8601} Conzealand #{n} of #{total}" if n % 10 == 0
      HugoMailer.nominations_open_conzealand(user: user).deliver_now
    end;

Changed

  • We've renamed "Review Memberships" to "My Memberships" in the menu to reduce confusion !89
  • To reduce CSS bugs, colour rotation when you have test keys for dev/staging only affect the logo !89
  • Viewport is set explicitly on CoNZealand pages based on the Bootstrap guidelines !89
  • Developers can now Napalm from an interactive rebase !89
  • CoNZealand development DB seeds are now based on Prod to reduce duplication of effort !89
  • Securitiy patch puma against a Denial of Service vunerability CVE-2019-16770 !129
  • Reconfigure Money rounding to round up on 0.5 cents to match stripe's decimal rounding !134

Removed

  • Moved yarn's OS dependent integrity check from application bootstrap to CI !133

Added

  • Added easy methods for checking licences in depenedencies !117
    bundle exec rake gem:licenses  # check Ruby
    yarn licenses list             # check JavaScript
  • Seeding a development database creates a support user by default !118
  • New make target to reset database and javascript dependencies quickly !118
    make reset start
    # faster than `make clean`
  • Script running updates and pushing up the lock files !123
    rake dev:update

Changed

  • Allow people to append/prepend whitespace to their email addess !116
  • Reduced the size of our install by moving docker base from debian to alpine !102
  • Update project dependencies !123
  • We now use structure.sql instead of schema.rb for database revision tracking !122
  • Securitiy patch nokogiri against input validation vulnerability CVE-2019-16892
  • Securitiy patch brakeman against local privilege escalation vulnerability CVE-2019-18409

Removed

  • Nothing significant in this release

Added

  • Rails 6 backards incompatable defaults are now enabled !100
  • We now use Webpacker to manage Sass assets and JavaScript compilation !99
  • JavaScript dependencies are now audited on CI !100
  • JavaScript linting is now enforced in CI !100

Changed

  • Nothing significant in this release

Removed

  • EMAIL_PAYMENTS has been removed. Please set MEMBER_SERVICES_EMAIL in .env everywhere. !100

Added

  • Nothing significant in this release

Changed

Removed

  • Removed dependency on makerb gem to reduce risk and use more core rails features. To maintain both html and text emails you now need to maintain two templates !99

Added

  • Nothing significant in this release

Changed

  • Last minute security patch for Devise that came up just after release, patches CVE-2019-16109

Removed

  • Nothing significant in this release

Added

  • Kiosk mode, now we can get people to record their details to reduce time handling data entry !93

Changed

  • Bugfix, users can now set their title on their membership !92
  • Assets are now coppied within the project for offline support !94
  • System emails are now configured globally from .env with MEMBER_SERVICES_EMAIL. !93. Please replace EMAIL_PAYMENTS this in your .env:
    MEMBER_SERVICES_EMAIL=registration@conzealand.nz
    
  • Seeds are installed using seedbank !95
  • Copyright checks don't require you to keep your author in all files authored, only enforces Apache boilerplate going forward !101
  • Appplied security patches for CVE-2015-7580, CVE-2015-7579 and CVE-2015-7578 - !104

Removed

  • EMAIL_PAYMENTS has been deprecated and will be removed in the next few releases. !93

Hotpatch, in 1.4.0 we regressed the payments mailer for instalments which no longer send. This patch release fixes that mailer.

Added

  • Nothing significant in this release

Changed

  • Fixed regression, instalments mailer now sends happily !91

Removed

  • Nothing significant in this release

This release has a bit of everything. We're making life better for other cons with support for multi currency, our support staff who have more fatures for adjusting memberships, and our developers have better seeded data for something that feels better right out of the box.

Added

  • Added brakeman, ruby-audit, and bundler-audit vulnerability scanners to the build process and make test !85
  • Configurable currency, add STRIPE_CURRENCY to your .env and all prices are now in that currency !70
  • Support can set membership to any level, including past memberships !87
  • Support can credit memberships with cash, allows support to create and credit memberships !87
  • User notes are now exposed on the reservation show screen !87
  • Upgrades and membership changes are now shown to our members !87

Changed

  • Added unique constraint to membership number data model !70. Please check and correct duplicates with this:
    Reservation.having("count(membership_number) > 1").group(:membership_number).pluck(:membership_number)
    
  • Upgraded gems to the latest versions !83
  • Generated memberships in testing now have charges !84 and !86
  • Support can now transfer memberships that are in instalment !88

Removed

  • Nothing significant in this release

Added

  • Purchase flow changed to let you select a membership before signing in !73
  • Prominant prices, membership rights and buttons on all memberships !73

Changed

  • Upgraded gems to the latest versions !76
  • Renamed Purchase to Reservation to match the domain more closely
  • Fixed charge descriptions in Stripe and in Charge comments !80. Cleanup retrospectively with this rake task post release:
    bundle exec rake stripe:sync:charges

Removed

  • Paths to resources have changed, /purchases have moved to /reservations

Upgraded Ruby and Rails, and support function for transferring memberships.

Added

  • Turned on Content Security Policy (CSP) for the site for security hygiene
  • Support can now transfer memberships between users from a user's detail form

Changed

  • Moved task check:models to test:models to keep namespaces tight
  • Run rails upgrades for 5.2 so we get the most out of our setup
  • Upgrade Ruby from 2.5.1 to 2.5.3
  • Update gems to the latest versions
  • Bugfix on support list, now transferred memberships show user's details correctly
  • Order displayed membership offers by price, highest to lowest
  • Fixed a bug where you could upgrade Adult to Adult memberships after the price increase

Removed

  • Nothing significant in this release

Some quality of life improvements for support, and general cleanup with things we learnt from our initial release.

Added

  • Detection of Stripe test keys to change colours on pages to distinguish between production and test systems
  • Migrations to correct data corruption on imported timestamps
  • Customer stripe ID now recorded and reused from User model going forward
  • New rake tasks for your utility belt:
    # Copy over stripe customer details to users with
    bundle exec rake stripe:sync:customers
    
    # Update historical charge descriptions in stripe and charge comments with
    bundle exec rake stripe:sync:charges
    
    # Detect invalid records on your systems with
    bundle exec rake test:models
  • CoNZealand images are now served from the project rather than GitHub to consolidate infrastructure
  • When purchasing a new membership, if you've got existing memberships you now get linked to the 'Review Memberships' section with a helpful message
  • Added Policy and Terms of service to CoNZealand pages

Changed

  • URLs for charging a person have been updated to use Purchase for consistency
  • Fixed Kansa and Presupport import methods to set "active" correctly on older records
  • Charge descriptions in stripe now describe amount owed, type of payment, membership name and number
  • Allow database name to be configurable on production builds for cheep staging costs
  • Updated most gems in the project including Rails
  • Replaced deprecated SASS gem with SASSC
  • Redirect to current page on login, puts you on the "new membership" or "review memberships" pages
  • New styles added to support page for readability
  • Email address added to support page for findability
  • Performance improvements for support memberships listing
  • Makefile has smarter build targets that create databases and images as needed
  • Developer setup steps in README should run out of the box

Removed

  • Nothing significant in this release

Initial release of CoNZealand, intended to give people what they had with Kansa, introduce instalments and bring in our pre supporters.

Added

  • Basic forms for purchasing memberships based on CoNZealand paper forms
  • Payments, including pay by instalment
  • Upgrades between different membership types
  • Login through email links that last 10 minutes
  • Basic support area that lists memberships
  • Concept of "active" for membership pricing for price rotation and disabling memberships
  • Concept of "active" for membership held and claim over membership
  • Concept of "active" for claim over membership for transfers and history of ownership
  • Theme concept area so we may cater for different cons
  • Basic mailers to setup descriptions about payment
  • Basic docker images for developers and production
  • Gitlab CI pipelines that build docker images for deploy
  • Command line based membership transfer
  • Membership numbers start at 100 to give room for special guests

Changed

  • Kansa members were renumbered to start at 2000
  • Old Kansa login links now say "this link has expired"

Removed

  • Nothing significant in this release