Re: Write stream proxy
Re: Write stream proxy
- Subject: Re: Write stream proxy
- From: Mark Pauley <email@hidden>
- Date: Wed, 10 Sep 2008 11:40:51 -0700
CFStreamCreateBoundPair will do the moral equivalent of the SocketPair
without the overhead of the socks stack.
I would recommend:
(wrStream, rdStream) = CFStreamCreateBoundPair
set client / schedule wrStream, open wrStream.
httpStream = CFReadStreamCreateForStreamedHTTPRequest(yourHTTPMessage,
rdStream)
add the proxies to httpStream from the system proxy dictionary.
set client / schedule httpStream, open httpStream.
when your wrStream client receives a canWrite, you pump data into the
HTTP transmission with CFWriteStreamWrite.
the readstream will be the same as your normal http read stream, read
when you get bytes available, you're done when you get end encountered.
Release the rdStream and unschedule / set null clients and Release
rwStream at the end of all of this after you unschedule / set null
clients and Release httpStream.
On Sep 10, 2008, at 5:18 AM, Quinn wrote:
At 10:26 -0700 9/9/08, Jack Brindle wrote:
For file transfers we do the same thing except create the dual
socket setup and call CFReadStreamCreateForStreamedHTTPRequest on
the read stream. However the read stream looks to be handled as a
raw stream of bits, without http-specific handling. It uses
CFWriteStreamWrite to send the data. No calls are made to anything
with the characters HTTP in the name for this stream. Am I right in
the feeling that this really isn't what I need to have?
It depends (-: When you create a streamed CFHTTP request (by
calling CFReadStreamCreateForStreamedHTTPRequest) CFHTTP will call
the supplied read stream to get the bytes for the body of the
request. This isn't HTTP at all, it's just a raw stream of bytes. A
typical usage is, if you want to upload a file, you create a file
read stream (CFReadStreamCreateWithFile) and pass that to
CFReadStreamCreateForStreamedHTTPRequest.
The only reason you need to do the whole socket pair thing is if the
data that you want to upload isn't present in one single file (or
one single block of memory). In that case, you have a number of
options:
A. If the data is relatively small, you can flatten it to a
temporary file and then create a file read stream and use that.
Similarly, you can flatten it to a temporary block of memory.
OTOH, if the data is large, this approach is too inefficient.
B. If you're OK with using Objective-C and the data is all present
(that is, you don't need to be scheduled on a runloop in order to
produce the data), you can create the data from a custom subclass of
NSInputStream. Subclassing NSInputStream for asynchronous streams
isn't something we support, but it should be OK for synchronous
streams.
I haven't actually tried this though (-:
C. If all else fails, you can produce the data using the technique
that you're already using, that is, create a socket pair, create a
read stream for one member of the pair and a write stream for the
other, and feed the data to the CFHTTP request by writing it to the
write stream.
If you do this you won't need to mess with proxies on the streams
you create for the socket pair. Those streams are just used for
internal communication within your program. The only stream that
needs to deal with proxies is the main CFHTTP stream.
S+E
--
Quinn "The Eskimo!" <http://www.apple.com/developer/
>
Apple Developer Relations, Developer Technical Support, Core OS/
Hardware
_______________________________________________
Do not post admin requests to the list. They will be ignored.
Macnetworkprog mailing list (email@hidden)
Help/Unsubscribe/Update your Subscription:
This email sent to email@hidden
_Mark
email@hidden
_______________________________________________
Do not post admin requests to the list. They will be ignored.
Macnetworkprog mailing list (email@hidden)
Help/Unsubscribe/Update your Subscription:
This email sent to email@hidden