Where communities thrive


  • Join over 1.5M+ people
  • Join over 100K+ communities
  • Free without limits
  • Create your own community
People
Activity
  • 21:30
    ArtemRakov starred dry-rb/dry-monads
  • 16:10
    marselmustafin starred dry-rb/dry-monads
  • 09:52
    preetsethi starred dry-rb/dry-initializer
  • Feb 17 23:12
    Karnaj starred dry-rb/dry-types
  • Feb 17 23:12
    Karnaj starred dry-rb/dry-monads
  • Feb 16 23:37
    asoules starred dry-rb/dry-system
  • Feb 16 20:37

    dry-bot on master

    [devtools] sync (compare)

  • Feb 16 20:37

    flash-gordon on master

    Update CHANGELOG (compare)

  • Feb 16 20:36

    flash-gordon on v1.3.1

    (compare)

  • Feb 16 20:34

    dry-bot on master

    [devtools] sync (compare)

  • Feb 16 20:33

    flash-gordon on master

    Fix version number (compare)

  • Feb 16 20:32

    dry-bot on master

    [devtools] sync (compare)

  • Feb 16 20:32

    flash-gordon on master

    Update CHANGELOG (compare)

  • Feb 16 20:27

    flash-gordon on master

    Bump version to 1.3.1 (compare)

  • Feb 16 20:26

    flash-gordon on impove-predicate-inferrer

    (compare)

  • Feb 16 20:26

    flash-gordon on master

    Infer hash? predicate for hash … Merge pull request #395 from dr… (compare)

  • Feb 16 20:26
    flash-gordon closed #395
  • Feb 16 20:26
    dry-bot commented #395
  • Feb 16 20:24
    flash-gordon opened #395
  • Feb 16 20:23

    flash-gordon on impove-predicate-inferrer

    Infer hash? predicate for hash … (compare)

Andy Holland
@AMHOL
Ahh, that wont work
Piotr Solnica
@solnic
@AMHOL I like dry-validation more :)
@AMHOL I was just looking at roda-flow again, it looks really cool I gotta say, it feels like a nice way of configuring your routing in a way that you simply point which objects are going to handle certain requests and what kind of input they need
Andy Holland
@AMHOL
Cool, me too, will merge it soon
Piotr Solnica
@solnic
I’m only worried that bigger apps will be hard to read due to nested blocks, I wonder how this could be improved
just slicing things into pieces would be enough
btw I’m gonna start working on the book in the upcoming week(s)
Andy Holland
@AMHOL
Yeah, roda already has a plugin for multiple routing blocks :)
Piotr Solnica
@solnic
so I’ll start putting together rodakase
first things I need to figure out is dir/file organization for it
Andy Holland
@AMHOL
Cool, looking forward to seeing what you come up with
Have a look at that repo i gave you access too
Piotr Solnica
@solnic
will do
Andy Holland
@AMHOL
Cool :)
Piotr Solnica
@solnic
I’m thinking about an auto-loading container, where it infers deps from a dir structure
my container has grown into lots of things but it’s Foo.new in 90% of the cases
Andy Holland
@AMHOL
That would be interesting
If we had auto curry we could always new up and then just configure the arguments
Although i guess instantiation isnt always what you want
Piotr Solnica
@solnic
@AMHOL I don’t like two things in roda-flow
idea of controllers and messing with response object
Andy Holland
@AMHOL
Yeah, thats just in the example tbf, not actually part of the lib
Thats how i use ut tho
Piotr Solnica
@solnic
my motivation is to decouple my app’s code from 1) persistence 2) http stuff
Andy Holland
@AMHOL
Btw i used roda flow at work on a small, db hitting microservice, get 14ms response times
Piotr Solnica
@solnic
nice!
Andy Holland
@AMHOL
Perhaps i will see the light when i see your rodakase
Tim Riley
@timriley
Trying to stay ahead of the curve and use Dry::Data as a form attributes object
ended up needing to build a shim like this:
class FormAttributes < Dry::Data::Struct
  def self.new(attributes)
    schema_defaults = schema.keys.map { |key| [key, nil] }.to_h

    super(schema_defaults.merge(Hash(attributes)))
  end

  def [](attribute_name)
    send(attribute_name)
  end
end
Just so it's not so strict about missing values when initializing
and #[] in place so I can use it with a ROM::Model::Validator
Tim Riley
@timriley
Him, except I can't use a Dry::Data::Struct as an input for a ROM command
Tim Riley
@timriley
I handled it this way in the interim:
App.register "transformations.to_h" do |input|
  input.to_h
end

App.register("transactions.sign_up_customer") do
  CallSheet(container: App) do
    map :process, with: "attributes.customer_sign_up"
    try :validate, with: "validators.customer", catch: ROM::Model::ValidationError
    map :prepare_for_persist, with: "transformations.to_h"
    tee :persist, with: "persistence.commands.create_customer"
  end
end
Added a #to_h to that FormAttributes class and that prepare_for_persiststep in the business transaction.
Does not feel ideal, but it works for now at least ¯_(ツ)_/¯
Piotr Solnica
@solnic
@timriley I haven’t finish dry-data wrt web form handling
first cut of this lib is targeting defining domain data types, as the second step I was planning to work on form-specific logic (with custom builtin types/coercions dedicated for this concern)
Tim Riley
@timriley
@solnic yeah, I did see you mention something like this! I figured if we could get it going well enough as-is, then it'll be a nice transition later on to the built-in form handling stuff :)
Piotr Solnica
@solnic
@timriley I’ll be updating it very soon, just need to get the rodakase basic stuff up and running
Tim Riley
@timriley
No problems. I'll happily roadtest the thing for you.
Piotr Solnica
@solnic
@AMHOL would be nice to put together a roadmap for dry-* gems so that we can see the big picture and hopefuly get more people contributing; from my pov validation + data are currently number 1 prio, but there are also some things that we could improve in dry-container and auto_inject (actualy thinking about renaming it to dry-import)
ugh, sorry, I meant that number 1 prio is GETTING A LOGO FOR THE ORG :joy:
Andy Holland
@AMHOL
Lol, yeah, need to organise it more like ROM I guess
Piotr Solnica
@solnic
(byebug) view_class.config
#<struct engine=:slim, layout="app", template="users">
(byebug) Class.new(view_class).config
#<struct engine=nil, layout=nil, template=nil>
@AMHOL is this expected?
Andy Holland
@AMHOL
Hmm, nah, looks like a bug
Piotr Solnica
@solnic
@AMHOL it works with setting :foo, ‘bar’
this one will be inherited
but the configured settings won't