Cpo

joined 2 years ago
[โ€“] [email protected] 4 points 5 months ago (2 children)

It is now quite clear that I have to let go of OO paradigms. Maybe the package approach is perfectly fine.

Thank you for the insights and useful answer!

I have the idea that I am still only scratching the surface of rust, although I seem to manage it better every day.

As long as I leave my OO hat on the rack ๐Ÿ˜‰

[โ€“] [email protected] 4 points 5 months ago (5 children)

Well. I did read up on the "XY" problem and apparently you assume that what I want to do is somehow bad practice.

To elaborate more on the problem: I am writing an axum backend which (like other backends) needs to do stuff in the database. As some endpoints update the database (and sometimes over multiple sql statements) I want to pass around the transaction as this embodies the connection I am using to update the database.

To separate the axum stuff (parameters, urls and whatnot) from the actual database logic, I've first pulled out all the database interactions into separate functions. Because those functions are logically groups (e.g. stuff happening with invoices, others with contacts etc), I thought it was a good idea to create a "dao" struct (and agreed: my OO brain kicked in here which might be debatable). This would group the interactions for each logical domain into a short-lived data access struct.

To prevent passing around the transaction/connection, i wanted to pass that along during construction, so the functions in the DAO could just access the connection when needed.

Non "OO" would be fine to be honest (just having all the DAO as functions in a separate package).

Sorry, no code, not at the computer atm.

(And yes, I am aware that rust is not OO, put away the pitchforks please ๐Ÿ™)

[โ€“] [email protected] 1 points 5 months ago

Thanks! Will try that!

[โ€“] [email protected] 2 points 5 months ago (4 children)

Seems like the into_inner is the way (i see other references to it).

And yes, transactions should be short-lived, this is just about delegating it to the responsible component.

[โ€“] [email protected] 1 points 5 months ago (8 children)

So your answer is "you are doing it wrong".

Thank you, very helpful ๐Ÿ˜‰

[โ€“] [email protected] 6 points 5 months ago

You, kind sir, deserve a reward.

Bravo!

[โ€“] [email protected] 1 points 5 months ago (4 children)

I am currently using it from a backend to generate pdfs.

One thing that prevents me from letting users build their own templates is the scripting capabilities. A joker creating an endless loop could block the whole server.

What would be nice is a "safe" mode in which no access to the file system (include and sorts) and limited runtime makes it safe to let users build their own templates.

[โ€“] [email protected] 1 points 5 months ago

Don't let the door hit you on the way out.

[โ€“] [email protected] 3 points 5 months ago

Amazing way to approach it!

Just a wee bit afraid there would be just porn left after applying the "subscribe to me" rule ๐Ÿ˜‰

[โ€“] [email protected] 11 points 5 months ago* (last edited 5 months ago) (1 children)

I was an avid nginx user but having caddy handle the ssl certificate creation and renewal is amazing.

I probably am outdated on nginx (maybe it supports it?) but caddy is what I use from here on out.

view more: โ€น prev next โ€บ