Examples of ByteCountingInputStream


Examples of com.betfair.cougar.util.stream.ByteCountingInputStream

  }

  private ExecutionCommand resolveExecutionCommand(final RescriptOperationBinding binding, final HttpCommand command, final ExecutionContextWithTokens context) {
    final MediaType requestMediaType = getContentTypeNormaliser().getNormalisedRequestMediaType(command.getRequest());
    final String encoding = getContentTypeNormaliser().getNormalisedEncoding(command.getRequest());
    ByteCountingInputStream iStream = null;
    Object[] args = null;
    try {
      iStream = createByteCountingInputStream(command.getRequest().getInputStream());
            EnumUtils.setHardFailureForThisThread(hardFailEnumDeserialisation);
      args = binding.resolveArgs(command.getRequest(), iStream, requestMediaType, encoding);
    } catch (IOException ioe) {
      throw new CougarFrameworkException("Unable to resolve arguments for operation " + binding.getOperationKey(), ioe);
    } finally {
      try {
                            if (iStream != null) {
                                iStream.close();
                            }
      } catch (IOException ignored) {
        ignored.printStackTrace();
      }
    }
    final Object[] finalArgs = args;
        final TimeConstraints realTimeConstraints = DefaultTimeConstraints.rebaseFromNewStartTime(context.getRequestTime(), readRawTimeConstraints(command.getRequest()));
    final long bytesRead = iStream != null ? iStream.getCount() : 0;
    return new ExecutionCommand() {
            public Object[] getArgs() {
                return finalArgs;
            }
View Full Code Here

Examples of com.betfair.cougar.util.stream.ByteCountingInputStream

    final List<JsonRpcRequest> requests = new ArrayList<JsonRpcRequest>();
    final List<ExecutionCommand> commands = new ArrayList<ExecutionCommand>();
    final List<JsonRpcResponse> responses = new ArrayList<JsonRpcResponse>();

    JsonNode root;
    ByteCountingInputStream iStream = null;
    try {
      iStream = createByteCountingInputStream(http.getRequest().getInputStream());
            try {
                EnumUtils.setHardFailureForThisThread(hardFailEnumDeserialisation);
                root = mapper.readTree(iStream);
                final long bytesRead = iStream.getCount();
                final boolean isBatch = root.isArray();
                if (isBatch) {
                    requests.addAll((List<JsonRpcRequest>)mapper.convertValue(root, BATCH_REQUEST_TYPE));
                } else {
                    JsonRpcRequest rpc = mapper.convertValue(root, SINGLE_REQUEST_TYPE);
                    requests.add(rpc);
                }

                if (requests.isEmpty()) {
                    writeErrorResponse(http, context, new CougarValidationException(ServerFaultCode.NoRequestsFound, "No Requests found in rpc call"));
                } else {
                    final TimeConstraints realTimeConstraints = DefaultTimeConstraints.rebaseFromNewStartTime(context.getRequestTime(), readRawTimeConstraints(http.getRequest()));
                    for (final JsonRpcRequest rpc : requests) {
                        final JsonRpcOperationBinding binding = bindings.get(stripMinorVersionFromUri(rpc.getMethod().toLowerCase()));
                        if (binding!=null) {
                            try {
                                JsonRpcParam [] paramDefs = binding.getJsonRpcParams();
                                final Object [] args = new Object[paramDefs.length];
                                for (int i=0;i<paramDefs.length;i++) {
                                    JsonNode paramValue = rpc.getParams().isArray() ? rpc.getParams().get(i) : rpc.getParams().get(paramDefs[i].getName());
                                    JavaType javaType = paramDefs[i].getJavaType();
                                    args[i] = mapper.convertValue(paramValue, javaType);
                                    // complex types are handled by the mapper, but for some reason, direct enums are not
                                    if (javaType.isEnumType() && args[i] != null && ((Enum)args[i]).name().equals("UNRECOGNIZED_VALUE")) {
                                        throw new IllegalArgumentException(new Exception(new EnumDerialisationException("UNRECOGNIZED_VALUE is not allowed as an input")));
                                    }
                                }
                                commands.add(new ExecutionCommand() {//2nd: index 0, 3rd: index 1, 4th: index 2
                                    @Override
                                    public void onResult(ExecutionResult executionResult) {
                                        JsonRpcResponse response = buildExecutionResultResponse(rpc, executionResult);
                                        synchronized(responses) {
                                            responses.add(response);
                                            writeResponseIfComplete(http, context, isBatch, requests, responses, bytesRead);
                                        }
                                    }
                                    @Override
                                    public OperationKey getOperationKey() {
                                        return binding.getOperationDefinition().getOperationKey();
                                    }
                                    @Override
                                    public Object[] getArgs() {
                                        return args;
                                    }

                                    @Override
                                    public TimeConstraints getTimeConstraints() {
                                        return realTimeConstraints;
                                    }
                                });
                            } catch (Exception e) {
                                if (e instanceof IllegalArgumentException && e.getCause()!=null && e.getCause().getCause()!=null && e.getCause().getCause() instanceof EnumDerialisationException) {
                                    responses.add(JsonRpcErrorResponse.buildErrorResponse(rpc, new JsonRpcError(INVALID_PARAMS, ServerFaultCode.ServerDeserialisationFailure.getDetail(), null)));
                                }
                                else {
                                    responses.add(JsonRpcErrorResponse.buildErrorResponse(rpc, new JsonRpcError(INVALID_PARAMS, ServerFaultCode.MandatoryNotDefined.getDetail(), null)));
                                }
                                writeResponseIfComplete(http, context, isBatch, requests, responses, bytesRead);
                            }
                        } else {
                            responses.add(JsonRpcErrorResponse.buildErrorResponse(rpc, new JsonRpcError(METHOD_NOT_FOUND, ServerFaultCode.NoSuchOperation.getDetail(), null)));
                            writeResponseIfComplete(http, context, isBatch, requests, responses, bytesRead);
                        }
                    }
                }
            } catch (Exception ex) {
                //This happens when there was a problem reading
                //deal with case where every request was bad
                writeErrorResponse(http, context, CougarMarshallingException.unmarshallingException("json",ex,false));
                commands.clear();
            }

      //return command resolver irrespective of whether it is empty so the top level processor doesn't error
      return new CommandResolver<HttpCommand>() {
        @Override
        public ExecutionContextWithTokens resolveExecutionContext() {
          return context;
        }
        @Override
        public Iterable<ExecutionCommand> resolveExecutionCommands() {
          return commands;
        }
      };
    } catch (Exception e) {
            throw CougarMarshallingException.unmarshallingException("json", "Unable to resolve requests for json-rpc", e, false);
    } finally {
      try {
                if (iStream != null) {
                    iStream.close();
                }
      } catch (IOException ignored) {
        ignored.printStackTrace();
      }
    }
View Full Code Here

Examples of com.betfair.cougar.util.stream.ByteCountingInputStream

    @Override
    protected CommandResolver<HttpCommand> createCommandResolver(
            final HttpCommand command) {
        String operationName = null;
        ByteCountingInputStream in = null;
        try {
            in = createByteCountingInputStream(command.getRequest().getInputStream());
            XMLInputFactory factory = XMLInputFactory.newInstance();
            factory.setProperty(XMLInputFactory.IS_SUPPORTING_EXTERNAL_ENTITIES, false);
            XMLStreamReader parser = factory.createXMLStreamReader(in);
            StAXSOAPModelBuilder builder = new StAXSOAPModelBuilder(parser);
            final SOAPHeader header = builder.getSOAPEnvelope().getHeader();
            final OMElement credentialElement = getCredentialElement(header);

            final OMElement requestNode = builder.getSOAPEnvelope().getBody().getFirstElement();

            operationName = requestNode.getLocalName();
            String fullPathToOperationName = stripMinorVersionFromUri(command.getOperationPath()) + "/" + operationName.toLowerCase();
            final SoapOperationBinding binding = bindings.get(fullPathToOperationName);
            if (binding != null) {

                if (schemaValidationEnabled) {
                    Schema schema = binding.getSchema();
                    Validator validator = schema.newValidator();
                    validator.validate(new StAXSource(requestNode.getXMLStreamReader(true)));
                }

                final ByteCountingInputStream finalIn = in;
                return new SingleExecutionCommandResolver<HttpCommand>() {

                    private ExecutionContextWithTokens context;
                    private ExecutionCommand exec;
View Full Code Here

Examples of com.betfair.cougar.util.stream.ByteCountingInputStream

        }
    }

    protected ByteCountingInputStream createByteCountingInputStream(InputStream is) {
        if (maxPostBodyLength == 0) {
            return new ByteCountingInputStream(is);
        }
        else {
            return new LimitedByteCountingInputStream(is, maxPostBodyLength);
        }
    }
View Full Code Here

Examples of com.betfair.cougar.util.stream.ByteCountingInputStream

  }
 
  private ExecutionCommand resolveExecutionCommand(final RescriptOperationBinding binding, final HttpCommand command, final ExecutionContextWithTokens context) {
    final MediaType requestMediaType = getContentTypeNormaliser().getNormalisedRequestMediaType(command.getRequest());
    final String encoding = getContentTypeNormaliser().getNormalisedEncoding(command.getRequest());
    ByteCountingInputStream iStream = null;
    Object[] args = null;
    try {
      iStream = createByteCountingInputStream(command.getRequest().getInputStream());
            EnumUtils.setHardFailureForThisThread(hardFailEnumDeserialisation);
      args = binding.resolveArgs(command.getRequest(), iStream, requestMediaType, encoding);
    } catch (IOException ioe) {
      throw new CougarFrameworkException("Unable to resolve arguments for operation " + binding.getOperationKey(), ioe);
    } finally {
      try {
                            if (iStream != null) {
                                iStream.close();
                            }
      } catch (IOException ignored) {
        ignored.printStackTrace();
      }
    }
    final Object[] finalArgs = args;
        final TimeConstraints realTimeConstraints = DefaultTimeConstraints.rebaseFromNewStartTime(context.getRequestTime(), readRawTimeConstraints(command.getRequest()));
    final long bytesRead = iStream != null ? iStream.getCount() : 0;
    return new ExecutionCommand() {
            public Object[] getArgs() {
                return finalArgs;
            }
View Full Code Here

Examples of com.betfair.cougar.util.stream.ByteCountingInputStream

    @Override
    protected CommandResolver<HttpCommand> createCommandResolver(
            final HttpCommand command) {
        String operationName = null;
        ByteCountingInputStream in = null;
        try {
            in = createByteCountingInputStream(command.getRequest().getInputStream());
            XMLInputFactory factory = XMLInputFactory.newInstance();
            factory.setProperty(XMLInputFactory.IS_SUPPORTING_EXTERNAL_ENTITIES, false);
            XMLStreamReader parser = factory.createXMLStreamReader(in);
            StAXSOAPModelBuilder builder = new StAXSOAPModelBuilder(parser);
            final SOAPHeader header = builder.getSOAPEnvelope().getHeader();
            final OMElement credentialElement = getCredentialElement(header);

            final OMElement requestNode = builder.getSOAPEnvelope().getBody().getFirstElement();

            operationName = requestNode.getLocalName();
            String fullPathToOperationName = stripMinorVersionFromUri(command.getOperationPath()) + "/" + operationName.toLowerCase();
            final SoapOperationBinding binding = bindings.get(fullPathToOperationName);
            if (binding != null) {

                if (schemaValidationEnabled) {
                    Schema schema = binding.getSchema();
                    Validator validator = schema.newValidator();
                    validator.validate(new StAXSource(requestNode.getXMLStreamReader(true)));
                }

                final ByteCountingInputStream finalIn = in;
                return new SingleExecutionCommandResolver<HttpCommand>() {

                    private ExecutionContextWithTokens context;
                    private ExecutionCommand exec;
View Full Code Here

Examples of com.betfair.cougar.util.stream.ByteCountingInputStream

    final List<JsonRpcRequest> requests = new ArrayList<JsonRpcRequest>();
    final List<ExecutionCommand> commands = new ArrayList<ExecutionCommand>();
    final List<JsonRpcResponse> responses = new ArrayList<JsonRpcResponse>();

    JsonNode root;
    ByteCountingInputStream iStream = null;         
    try {
      iStream = createByteCountingInputStream(http.getRequest().getInputStream());
            try {
                EnumUtils.setHardFailureForThisThread(hardFailEnumDeserialisation);
                root = mapper.readTree(iStream);
                final long bytesRead = iStream.getCount();
                final boolean isBatch = root.isArray();
                if (isBatch) {
                    requests.addAll((List<JsonRpcRequest>)mapper.convertValue(root, BATCH_REQUEST_TYPE));
                } else {
                    JsonRpcRequest rpc = mapper.convertValue(root, SINGLE_REQUEST_TYPE);
                    requests.add(rpc);
                }

                if (requests.isEmpty()) {
                    writeErrorResponse(http, context, new CougarValidationException(ServerFaultCode.NoRequestsFound, "No Requests found in rpc call"));
                } else {
                    final TimeConstraints realTimeConstraints = DefaultTimeConstraints.rebaseFromNewStartTime(context.getRequestTime(), readRawTimeConstraints(http.getRequest()));
                    for (final JsonRpcRequest rpc : requests) {
                        final JsonRpcOperationBinding binding = bindings.get(stripMinorVersionFromUri(rpc.getMethod().toLowerCase()));
                        if (binding!=null) {
                            try {
                                JsonRpcParam [] paramDefs = binding.getJsonRpcParams();
                                final Object [] args = new Object[paramDefs.length];
                                for (int i=0;i<paramDefs.length;i++) {
                                    JsonNode paramValue = rpc.getParams().isArray() ? rpc.getParams().get(i) : rpc.getParams().get(paramDefs[i].getName());
                                    JavaType javaType = paramDefs[i].getJavaType();
                                    args[i] = mapper.convertValue(paramValue, javaType);
                                }
                                commands.add(new ExecutionCommand() {
                                    @Override
                                    public void onResult(ExecutionResult executionResult) {
                                        JsonRpcResponse response = buildExecutionResultResponse(rpc, executionResult);
                                        synchronized(responses) {
                                            responses.add(response);
                                            writeResponseIfComplete(http, context, isBatch, requests, responses, bytesRead);
                                        }
                                    }
                                    @Override
                                    public OperationKey getOperationKey() {
                                        return binding.getOperationDefinition().getOperationKey();
                                    }
                                    @Override
                                    public Object[] getArgs() {
                                        return args;
                                    }

                                    @Override
                                    public TimeConstraints getTimeConstraints() {
                                        return realTimeConstraints;
                                    }
                                });
                            } catch (Exception e) {
                                responses.add(JsonRpcErrorResponse.buildErrorResponse(rpc, new JsonRpcError(INVALID_PARAMS, ServerFaultCode.MandatoryNotDefined.getDetail(), null)));
                                writeResponseIfComplete(http, context, isBatch, requests, responses, bytesRead);
                            }
                        } else {
                            responses.add(JsonRpcErrorResponse.buildErrorResponse(rpc, new JsonRpcError(METHOD_NOT_FOUND, ServerFaultCode.NoSuchOperation.getDetail(), null)));
                            writeResponseIfComplete(http, context, isBatch, requests, responses, bytesRead);
                        }
                    }
                }
            } catch (Exception ex) {
                //This happens when there was a problem reading
                //deal with case where every request was bad
                writeErrorResponse(http, context, new CougarValidationException(ServerFaultCode.JSONDeserialisationParseFailure, ex));
                commands.clear();
            }

      //return command resolver irrespective of whether it is empty so the top level processor doesn't error
      return new CommandResolver<HttpCommand>() {
        @Override
        public ExecutionContextWithTokens resolveExecutionContext() {
          return context;
        }
        @Override
        public Iterable<ExecutionCommand> resolveExecutionCommands() {
          return commands;
        }
      };
    } catch (Exception e) {
      throw new CougarServiceException(ServerFaultCode.JSONDeserialisationParseFailure, "Unable to resolve requests for json-rpc", e);
    } finally {
      try {
                if (iStream != null) {
                    iStream.close();
                }
      } catch (IOException ignored) {
        ignored.printStackTrace();
      }
    }
View Full Code Here

Examples of com.betfair.cougar.util.stream.ByteCountingInputStream

        }
    }

    protected ByteCountingInputStream createByteCountingInputStream(InputStream is) {
        if (maxPostBodyLength == 0) {
            return new ByteCountingInputStream(is);
        }
        else {
            return new LimitedByteCountingInputStream(is, maxPostBodyLength);
        }
    }
View Full Code Here

Examples of org.jwat.common.ByteCountingInputStream

        out.write( '!' );
        byte[] srcArr = out.toByteArray();

        String srcStr = "!";

        in = new ByteCountingInputStream( new ByteArrayInputStream( srcArr ) );
        Assert.assertEquals( 1, in.skip( 10 ) );
        Assert.assertEquals( 0, in.skip( 10 ) );

        in = new ByteCountingPushBackInputStream( new ByteArrayInputStream( srcArr ), 1 );
        Assert.assertEquals( 1, in.skip( 10 ) );
View Full Code Here

Examples of org.jwat.common.ByteCountingInputStream

        int errors = 0;
        int warnings = 0;

        try {
            InputStream in = this.getClass().getClassLoader().getResourceAsStream(warcFile);
            ByteCountingInputStream bcin = new ByteCountingInputStream(in);
            WarcReader reader = WarcReaderFactory.getReader(bcin);

            reader.setBlockDigestEnabled( bDigest );
            Assert.assertTrue(reader.setBlockDigestAlgorithm( "sha1" ));
            reader.setPayloadDigestEnabled( bDigest );
            Assert.assertTrue(reader.setPayloadDigestAlgorithm( "sha1" ));

            Iterator<WarcRecord> recordIterator = reader.iterator();
            WarcRecord record;

            while (recordIterator.hasNext()) {
                record = recordIterator.next();
                ++records;

                if (record.header.warcRecordIdUri == null) {
                    Assert.fail("Invalid warc-record-id");
                }

                Assert.assertThat(record.getStartOffset(), is(equalTo(reader.getStartOffset())));
                Assert.assertThat(record.getStartOffset(), is(not(equalTo(reader.getOffset()))));

                warcEntry = new WarcEntry();
                warcEntry.recordId = record.header.warcRecordIdUri;
                warcEntry.offset = record.getStartOffset();
                warcEntries.add(warcEntry);

                record.close();

                consumed += record.getConsumed();
                Assert.assertEquals(record.consumed, record.getConsumed());

                // Test content-type and http response/request
                if (record.header.contentType != null) {
                    if ("application".equals(record.header.contentType.contentType)
                            && "http".equals(record.header.contentType.mediaType)) {
                        if ("response".equals(record.header.contentType.getParameter("msgtype"))) {
                            Assert.assertNotNull(record.payload);
                            Assert.assertNotNull(record.httpHeader);
                            Assert.assertEquals(HttpHeader.HT_RESPONSE, record.httpHeader.headerType);
                        } else if ("request".equals(record.header.contentType.getParameter("msgtype"))) {
                            Assert.assertNotNull(record.payload);
                            Assert.assertNotNull(record.httpHeader);
                            Assert.assertEquals(HttpHeader.HT_REQUEST, record.httpHeader.headerType);
                        }
                    }
                }

                Assert.assertThat(record.getStartOffset(), is(equalTo(reader.getStartOffset())));
                Assert.assertThat(record.getStartOffset(), is(not(equalTo(reader.getOffset()))));

                if ( bDigest ) {
                    if ( (record.payload != null && record.computedBlockDigest == null)
                            || (record.httpHeader != null && record.computedPayloadDigest == null) ) {
                        Assert.fail( "Digest missing!" );
                    }
                }

                if (bDebugOutput) {
                    System.out.println("0x" + Long.toString(warcEntry.offset, 16) + "(" + warcEntry.offset + ") - " + warcEntry.recordId);
                }

                if (record.diagnostics.hasErrors()) {
                    errors += record.diagnostics.getErrors().size();
                }
                if (record.diagnostics.hasWarnings()) {
                    warnings += record.diagnostics.getWarnings().size();
                }
            }

            if (reader.getIteratorExceptionThrown() != null) {
                reader.getIteratorExceptionThrown().printStackTrace();
                Assert.fail("Unexpected exception!");
            }

            URL url = this.getClass().getClassLoader().getResource(warcFile2);
            File file = new File(getUrlPath(url));

            Assert.assertEquals(bcin.getConsumed(), reader.getConsumed());
            Assert.assertEquals(bcin.getConsumed(), reader.getOffset());
            Assert.assertEquals(file.length(), consumed);

            reader.close();
            bcin.close();

            Assert.assertEquals(bcin.getConsumed(), reader.getConsumed());
            Assert.assertEquals(bcin.getConsumed(), reader.getOffset());
            Assert.assertEquals(file.length(), consumed);
        } catch (IOException e) {
            Assert.fail("Unexpected i/o exception");
        }
View Full Code Here
TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.