| 130 | }) |
| 131 | |
| 132 | const waitForResponse = (nodeRequest: Http.ClientRequest, request: ClientRequest.HttpClientRequest) => |
| 133 | Effect.async<Http.IncomingMessage, Error.RequestError>((resume) => { |
| 134 | function onError(cause: Error) { |
| 135 | resume(Effect.fail( |
| 136 | new Error.RequestError({ |
| 137 | request, |
| 138 | reason: "Transport", |
| 139 | cause |
| 140 | }) |
| 141 | )) |
| 142 | } |
| 143 | nodeRequest.on("error", onError) |
| 144 | |
| 145 | function onResponse(response: Http.IncomingMessage) { |
| 146 | nodeRequest.off("error", onError) |
| 147 | resume(Effect.succeed(response)) |
| 148 | } |
| 149 | nodeRequest.on("upgrade", onResponse) |
| 150 | nodeRequest.on("response", onResponse) |
| 151 | |
| 152 | return Effect.sync(() => { |
| 153 | nodeRequest.off("error", onError) |
| 154 | nodeRequest.off("upgrade", onResponse) |
| 155 | nodeRequest.off("response", onResponse) |
| 156 | }) |
| 157 | }) |
| 158 | |
| 159 | const waitForFinish = (nodeRequest: Http.ClientRequest, request: ClientRequest.HttpClientRequest) => |
| 160 | Effect.async<void, Error.RequestError>((resume) => { |