Where communities thrive


  • Join over 1.5M+ people
  • Join over 100K+ communities
  • Free without limits
  • Create your own community
People
Activity
  • Apr 08 23:53

    davydovanton on improve-allocation-of-logger

    (compare)

  • Apr 08 23:53

    davydovanton on master

    Don't create a new formatter ob… Merge pull request #38 from dry… (compare)

  • Apr 08 23:53
    davydovanton closed #38
  • Apr 08 18:00
    dry-bot commented #38
  • Apr 08 17:59
    davydovanton review_requested #38
  • Apr 08 17:59
    davydovanton assigned #38
  • Apr 08 17:59
    davydovanton opened #38
  • Apr 08 17:54

    davydovanton on improve-allocation-of-logger

    Don't create a new formatter ob… (compare)

  • Apr 08 17:29
    JuPlutonic starred dry-rb/dry-monitor
  • Apr 08 13:48
  • Apr 08 09:13

    solnic on release-0.17

    Add information about built-in … (compare)

  • Apr 08 09:11

    solnic on add-settings-section

    (compare)

  • Apr 08 09:11

    solnic on master

    Add information about built-in … (compare)

  • Apr 08 09:11
    solnic closed #145
  • Apr 08 07:26
    Yuki-Inoue starred dry-rb/dry-monads
  • Apr 07 15:30

    davydovanton on rack-middleware-compat-with-rack-builder

    (compare)

  • Apr 07 15:30

    davydovanton on master

    Ensure `Dry::Monitor::Rack::Mid… Merge pull request #37 from dry… (compare)

  • Apr 07 15:30
    davydovanton closed #37
  • Apr 07 14:58
    JPalka starred dry-rb/dry-monads
  • Apr 07 14:49
    dry-bot commented #37
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
Andy Holland
@AMHOL
Ahh ok, i'll have a look tomorrow if thats ok?
Piotr Solnica
@solnic
no rush at all
Andy Holland
@AMHOL
Cool, going to meet friends for drinks soon
Andy Holland
@AMHOL
@solnic dryrb/dry-configurable@992d16a
Andy Holland
@AMHOL
@solnic dryrb/dry-container@7f905a6
Saw you mentioned that in a comment in Rodakase too
François Bernier
@fbernier
Hey, there is this API client at my workplace which uses Hashie::Mash and I don't like it. I am checking out dry-data. Looks like it could replace it right?
Piotr Solnica
@solnic
@fbernier kinda :) dry-data’s structs require you to define attributes