But even then, exposing internal details outward leads to lots of problems, 
testability for certain. There’s almost always a better way then GetNested, 
GetWrapped, or any of its derivatives. 

> On Feb 5, 2019, at 12:20 PM, Robert Engels <reng...@ix.netcom.com> wrote:
> 
> Then you want inheritance not encapsulation. 
> 
>>> On Feb 5, 2019, at 10:46 AM, Burak Serdar <bser...@ieee.org> wrote:
>>> 
>>> On Tue, Feb 5, 2019 at 9:41 AM Robert Engels <reng...@ix.netcom.com> wrote:
>>> 
>>> GetNested anything is a sign something is broken in the API. The whole 
>>> point of being nested is almost always encapsulation and then you are 
>>> breaking it.
>> 
>> That's too much of a generalization in my opinion. This is more like
>> decoration, adding new functionality at every layer, but there is no
>> way to expose all the functionality of the nested thing, so you need
>> to expose the thing itself.
>> 
>>> 
>>>>> On Feb 5, 2019, at 10:30 AM, Burak Serdar <bser...@ieee.org> wrote:
>>>>> 
>>>>> On Tue, Feb 5, 2019 at 9:12 AM <matteo.biage...@gmail.com> wrote:
>>>>> 
>>>>> I've the following situation:
>>>>> I proxy a request to another server and when I made a POST and create a 
>>>>> new request, the contentLength is zero:
>>>>> 
>>>>>      req2, _ := http.NewRequest(req.Method, newApiUrl , req.Body)
>>>>>      fmt.Println("New request from body:", req2.ContentLength) // print 0
>>>>> 
>>>>> Checking in the source code of the NewRequest func Body don't respect 
>>>>> some interface and populate the ContentLength field.
>>>> 
>>>> When the first request is created, req.Body is set to a NopCloser, and
>>>> that doesn't match any of the cases in the second NewRequest. For this
>>>> to work, I guess the best way is to get the body length and set it
>>>> explicitly after constructing the second request.
>>>> 
>>>> I don't know if this is intentional or not, but in general, it might
>>>> be a good idea to add a ReaderWrapper interface to the standard
>>>> library that defines a GetNestedReader() io.Reader function to access
>>>> the real reader from these utility classes.
>>>> 
>>>>> 
>>>>> Could be a bug? Which could be a valid approach in order to create a new 
>>>>> request from an existing one and correct set the Body length?
>>>>> 
>>>>> A working example here:
>>>>> 
>>>>> https://play.golang.org/p/SvCDLj0NrXb
>>>>> 
>>>>> Thanks!
>>>>> 
>>>>> --
>>>>> You received this message because you are subscribed to the Google Groups 
>>>>> "golang-nuts" group.
>>>>> To unsubscribe from this group and stop receiving emails from it, send an 
>>>>> email to golang-nuts+unsubscr...@googlegroups.com.
>>>>> For more options, visit https://groups.google.com/d/optout.
>>>> 
>>>> --
>>>> You received this message because you are subscribed to the Google Groups 
>>>> "golang-nuts" group.
>>>> To unsubscribe from this group and stop receiving emails from it, send an 
>>>> email to golang-nuts+unsubscr...@googlegroups.com.
>>>> For more options, visit https://groups.google.com/d/optout.
>>> 
> 
> -- 
> You received this message because you are subscribed to the Google Groups 
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an 
> email to golang-nuts+unsubscr...@googlegroups.com.
> For more options, visit https://groups.google.com/d/optout.

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to