Comments (3)
Yeah I thought about that earlier, haven't found a good solution yet.
The only place where this is used so far is the admin/competitors controller and those are wrapped in a transaction already. If register_as_guest! and the others in that file fail, I want it to rollback the whole transaction here. But if I wrap those methods themselves in transactions as well, that wont work because MySQL doesn't support nested transactions.
Any ideas on how to make this better? I guess I could check if register_as_guest! etc. rolled back, and if so, manually raise an ActiveRecord::Rollback? Not sure if that would work.
from cubecomp.
I think the whole thing there is a little bit ugly. I tried to make it work with nested_attributes before, but that ended up being more complicated because the way I want the form to look doesn't map nicely to the data model.
from cubecomp.
Oh, nice, haven't looked at the controllers, yet. Not sure if it still needs its own transaction. Need to dive deeper into the code.
But if I wrap those methods themselves in transactions as well, that wont work because MySQL doesn't support nested transactions.
ActiveRecord seems to emulate nested transactions using savepoints (http://api.rubyonrails.org/classes/ActiveRecord/Transactions/ClassMethods.html). Not sure if that has the same guarantees as a transaction, though (the wiki article).
Yeah, it's not the prettiest code, but I also don't have a decent way to clean it up, yet. Maybe some object which knows how to build the data model from the form parameters?
from cubecomp.
Related Issues (20)
- WCA delegate
- Event overview has wrong registration numbers HOT 4
- Confirmation mails marked as spam HOT 5
- Remove "Newcomer"-comment for guest from checklist HOT 2
- Date displayed incorrectly if spread over multiple months
- WCA database script not working on Mac OS X HOT 1
- Bug in Stats HOT 3
- Loading front page with custom domain should only show competitions that use that domain
- Broken CSV export HOT 8
- Competitor comparison not working HOT 4
- Competitor limit for competitions
- Uniformly width for each table at schedule
- Wrong weekday for birthdays HOT 5
- French Flag not displayed HOT 2
- Swiss Nationals: Psych sheet error HOT 3
- Lichtenstein missing as a country HOT 1
- Unnoticed mail delivery failures HOT 1
- Option to partially close registration
- Add support for "other" gender HOT 1
- s/United States/USA HOT 3
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from cubecomp.