houdini/config/routes.rb

354 lines
No EOL
13 KiB
Ruby
Executable file

# frozen_string_literal: true
# License: AGPL-3.0-or-later WITH WTO-AP-3.0-or-later
# Full license explanation at https://github.com/houdiniproject/houdini/blob/master/LICENSE
Rails.application.routes.draw do
# For details on the DSL available within this file, see https://guides.rubyonrails.org/routing.html
require_relative "./state_code_constraint"
if Rails.env == 'development'
get '/button_debug/embedded' => 'button_debug#embedded'
get '/button_debug/button' => 'button_debug#button'
get '/button_debug/embedded/:id' => 'button_debug#embedded'
get '/button_debug/button/:id' => 'button_debug#button'
end
namespace(:api) do
resources(:nonprofits)
end
resources(:emails, only: [:create])
resources(:settings, only: [:index])
resources(:campaign_gifts, only: [:create])
resource(:cards, only: %i[create update destroy])
resource(:direct_debit_details, path: 'sepa', controller: :direct_debit_details, only: [:create])
# Creating presigned posts for direct-to-S3 upload
resources(:aws_presigned_posts, only: [:create])
resources(:image_attachments, only: [:create]) do
post(:remove, on: :collection)
end
resources(:profiles, only: %i[show update]) do
get(:fundraisers, on: :member)
get(:events, on: :member)
get(:donations_history, on: :member)
end
namespace(:nonprofits, path: 'nonprofits/:nonprofit_id') do
resources(:payouts, only: %i[create index show])
resources(:imports, only: [:create])
resources(:nonprofit_keys, only: [:index]) do
get(:mailchimp_login, on: :collection)
get(:mailchimp_landing, on: :collection)
end
resources(:reports, only: []) do
get(:end_of_year, on: :collection)
get(:end_of_year_custom, on: :collection)
end
resources(:email_lists, only: %i[index create])
resources(:payments, only: %i[index show update destroy]) do
post(:export, on: :collection)
post(:resend_donor_receipt, on: :member)
post(:resend_admin_receipt, on: :member)
end
resources(:donations, only: %i[index show create update]) do
put(:followup, on: :member)
post(:create_offsite, on: :collection)
end
resource(:card, only: %i[edit update show create])
resources(:charges, only: [:index]) do
resources(:refunds, only: %i[create index])
end
resource(:bank_account, only: [:create]) do
get(:confirmation)
post(:confirm)
get(:cancellation)
post(:cancel)
post(:resend_confirmation)
end
resources(:custom_field_masters, only: %i[index create destroy])
resources(:custom_field_joins, only: []) do
post(:modify, on: :collection)
end
resources(:tag_masters, only: %i[index create destroy])
resources(:tag_joins, only: []) do
post(:modify, on: :collection)
end
resources(:supporters, only: %i[index show create update new]) do
resources(:tag_joins, only: %i[index destroy])
resources(:custom_field_joins, only: %i[index destroy])
resources(:supporter_notes, only: %i[create update destroy])
resources(:activities, only: [:index])
post(:export, on: :collection)
put :bulk_delete, on: :collection
post :merge, on: :collection
get :merge_data, on: :collection
get :info_card, on: :member
get :email_address, on: :member
get :full_contact, on: :member
get :index_metrics, on: :collection
end
resources(:recurring_donations, only: %i[index show destroy update create]) do
post(:export, on: :collection)
end
resource(:miscellaneous_np_info, only: %i[show update])
namespace(:button) do
root(action: :advanced)
get(:basic)
get(:guided)
get(:advanced)
post(:send_code)
end
post 'tracking', controller: 'trackings', action: 'create'
end
namespace(:campaigns, path: '/nonprofits/:nonprofit_id/campaigns/:campaign_id/admin', only: []) do
resources(:supporters, only: [:index])
resources(:donations, only: [:index])
resources(:campaign_gift_options, only: [:index])
end
resources(:nonprofits, only: %i[show create update destroy]) do
get(:profile_todos, on: :member)
get(:recurring_donation_stats, on: :member)
get(:search, on: :collection)
get(:dashboard_todos, on: :member)
put(:verify_identity, on: :member)
resources(:roles, only: %i[create destroy])
resources(:settings, only: [:index])
resources(:pricing, only: [:index])
resources(:email_settings, only: %i[index create])
resources(:users, only: %i[index create]) do
resources(:email_settings, only: %i[index create])
end
resources(:campaigns, only: %i[index show create update]) do
get(:metrics, on: :member)
get(:totals, on: :member)
get(:timeline, on: :member)
post(:duplicate, on: :member)
get(:activities, on: :member)
put(:soft_delete, on: :member)
get(:name_and_id, on: :collection)
post :create_from_template, on: :collection
resources(:campaign_gift_options, only: %i[index show create update destroy]) do
put(:update_order, on: :collection)
end
end
resource(:billing_subscription, only: [:create]) do
post(:cancel)
get(:cancellation)
end
resources(:events, only: %i[index show create update]) do
get(:metrics, on: :member)
get(:listings, on: :collection)
get(:stats, on: :member)
get(:name_and_id, on: :collection)
get(:activities, on: :member)
post(:duplicate, on: :member)
put(:soft_delete)
resources(:tickets, only: %i[create update index destroy]) do
put(:add_note, on: :member)
post(:delete_card_for_ticket, on: :member)
end
resources(:ticket_levels, only: %i[index show create update destroy]) do
put(:update_order, on: :collection)
end
resources(:event_discounts, only: %i[create index update destroy])
end
get(:donate, on: :member)
get(:btn, on: :member)
get(:supporter_form, on: :member)
post(:custom_supporter, on: :member)
get(:dashboard, on: :member)
get(:dashboard_metrics, on: :member)
get(:payment_history, on: :member)
post(:donate, on: :member, as: 'create_donation')
end
resources(:recurring_donations, only: %i[edit destroy update]) do
put(:update_amount, on: :member)
end
devise_for :users,
controllers: {
sessions: 'users/sessions',
registrations: 'users/registrations',
confirmations: 'users/confirmations'
}
devise_scope :user do
match '/sign_in' => 'users/sessions#new', via: %i[get post]
match '/signup' => 'devise/registrations#new', via: %i[get post]
post '/confirm' => 'users/confirmations#confirm', via: [:get]
match '/users/is_confirmed' => 'users/confirmations#is_confirmed', via: %i[get post]
match '/users/exists' => 'users/confirmations#exists', via: [:get]
post '/users/confirm_auth', action: :confirm_auth, controller: 'users/sessions', via: %i[get post]
end
# Super admin
match '/admin' => 'super_admins#index', :as => 'admin', via: %i[get post]
match '/admin/search-nonprofits' => 'super_admins#search_nonprofits', via: %i[get post]
match '/admin/search-profiles' => 'super_admins#search_profiles', via: %i[get post]
match '/admin/search-fullcontact' => 'super_admins#search_fullcontact', via: %i[get post]
match '/admin/recurring-donations-without-cards' => 'super_admins#recurring_donations_without_cards', via: %i[get post]
match '/admin/export_supporters_with_rds' => 'super_admins#export_supporters_with_rds', via: %i[get post]
match '/admin/resend_user_confirmation' => 'super_admins#resend_user_confirmation', via: %i[get post]
# GoodJob dashboard
authenticate :user, ->(user) { user.super_admin? } do
mount GoodJob::Engine => 'good_job'
end
# Events
match '/events' => 'events#index', via: [:get]
match '/events/:event_slug' => 'events#show', via: %i[get post]
# Campaigns
match '/peer-to-peer' => 'campaigns#peer_to_peer', via: %i[get post]
scope ':state_code/:city/:name' do
constraints StateCodeConstraint.new do
# Nonprofits
match '' => 'nonprofits#show', :as => :nonprofit_location, via: %i[get post]
match 'donate' => 'nonprofits#donate', :as => :nonprofit_donation, via: %i[get post]
match 'button' => 'nonprofits/button#guided', via: %i[get post]
# Campaigns
match 'campaigns' => 'campaigns#index', via: %i[get post]
match 'campaigns/:campaign_slug' => 'campaigns#show', via: %i[get post], as: :campaign_location
match 'campaigns/:campaign_slug/supporters' => 'campaigns/supporters#index', via: %i[get post]
# Events
match 'events' => 'events#index', via: %i[get post]
match 'events/:event_slug' => 'events#show', via: %i[get post]
match 'events/:event_slug/stats' => 'events#stats', via: %i[get post]
match 'events/:event_slug/tickets' => 'tickets#index', via: %i[get post]
# Dashboard
match 'dashboard' => 'nonprofits#dashboard', as: :np_dashboard, via: %i[get post]
end
end
direct :campaign_locateable do |model, **opts|
nonprofit = model.nonprofit
{controller: 'campaigns', action: "show", state_code: nonprofit.state_code_slug, city: nonprofit.city_slug, name: nonprofit.slug,
campaign_slug: model.slug}.merge(**opts)
end
direct :event_locateable do |model, **opts|
nonprofit = model.nonprofit
{controller: '/events', action: "show", state_code: nonprofit.state_code_slug, city: nonprofit.city_slug, name: nonprofit.slug,
event_slug: model.slug}.merge(**opts)
end
# Mailchimp Landing
match '/mailchimp-landing' => 'nonprofits/nonprofit_keys#mailchimp_landing', via: %i[get post]
# Webhooks
post '/webhooks/stripe_subscription_payment' => 'webhooks#subscription_payment'
post '/webhooks/stripe' => 'webhooks#stripe'
get '/static/terms_and_privacy' => 'static#terms_and_privacy'
get '/static/ccs' => 'static#ccs'
get '/js/donate-button.v2.js' => 'widget#v2'
get '/js/i18n.js' => 'widget#i18n'
get '/css/donate-button.css' => 'widget#v1_css'
get '/css/donate-button.v2.css' => 'widget#v2_css'
scope ActiveStorage.routes_prefix do
get "/blobs/redirect/:signed_id/*filename" => "active_storage/blobs/redirect#show", as: :rails_service_blob
get "/blobs/proxy/:signed_id/*filename" => "active_storage/blobs/proxy#show", as: :rails_service_blob_proxy
get "/blobs/:signed_id/*filename" => "active_storage/blobs/redirect#show"
get "/representations/redirect/:signed_blob_id/:variation_key/*filename" => "active_storage/representations/redirect#show", as: :rails_blob_representation
get "/representations/proxy/:signed_blob_id/:variation_key/*filename" => "active_storage/representations/proxy#show", as: :rails_blob_representation_proxy
get "/representations/:signed_blob_id/:variation_key/*filename" => "active_storage/representations/redirect#show"
get "/disk/:encoded_key/*filename" => "active_storage/disk#show", as: :rails_disk_service
put "/disk/:encoded_token" => "active_storage/disk#update", as: :update_rails_disk_service
post "/direct_uploads" => "direct_uploads#create", as: :rails_direct_uploads
end
direct :rails_representation do |representation, options|
signed_blob_id = representation.blob.signed_id
variation_key = representation.variation.key
filename = representation.blob.filename
route_for(:rails_blob_representation, signed_blob_id, variation_key, filename, options)
end
resolve("ActiveStorage::Variant") { |variant, options| route_for(ActiveStorage.resolve_model_to_route, variant, options) }
resolve("ActiveStorage::VariantWithRecord") { |variant, options| route_for(ActiveStorage.resolve_model_to_route, variant, options) }
resolve("ActiveStorage::Preview") { |preview, options| route_for(ActiveStorage.resolve_model_to_route, preview, options) }
direct :rails_blob do |blob, options|
route_for(:rails_service_blob, blob.signed_id, blob.filename, options)
end
resolve("ActiveStorage::Blob") { |blob, options| route_for(ActiveStorage.resolve_model_to_route, blob, options) }
resolve("ActiveStorage::Attachment") { |attachment, options| route_for(ActiveStorage.resolve_model_to_route, attachment.blob, options) }
direct :rails_storage_proxy do |model, options|
if model.respond_to?(:signed_id)
route_for(
:rails_service_blob_proxy,
model.signed_id,
model.filename,
options
)
else
signed_blob_id = model.blob.signed_id
variation_key = model.variation.key
filename = model.blob.filename
route_for(
:rails_blob_representation_proxy,
signed_blob_id,
variation_key,
filename,
options
)
end
end
direct :rails_storage_redirect do |model, options|
if model.respond_to?(:signed_id)
route_for(
:rails_service_blob,
model.signed_id,
model.filename,
options
)
else
signed_blob_id = model.blob.signed_id
variation_key = model.variation.key
filename = model.blob.filename
route_for(
:rails_blob_representation,
signed_blob_id,
variation_key,
filename,
options
)
end
end
root to: 'front#index'
end