-
Notifications
You must be signed in to change notification settings - Fork 1.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Removes dangling pointer in capture list of lambda function. #2080
Conversation
/cc @lizan @PiotrSikora |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
/lgtm
/approve
[APPROVALNOTIFIER] This PR is APPROVED This pull-request has been approved by: JimmyCYJ, qiwzhang The full list of commands accepted by this bot can be found here. The pull request process is described here
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
tls_(context.threadLocal().allocateSlot()) { | ||
tls_->set([config = this->config_](Event::Dispatcher&) | ||
-> ThreadLocal::ThreadLocalObjectSharedPtr { | ||
return std::make_shared<JwtAuthStore>(*config); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do we need to create shared-pointer from shared-pointer? Can't we re-use the existing one?
tls_->set([config = this->config_](Event::Dispatcher&)
-> ThreadLocal::ThreadLocalObjectSharedPtr { return config; }
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actually, nevermind, it's different type. Sorry for the noise.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
different type? config is proto and JwtAuthStore is not.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes they are different types.
It seems that the change to ControlFactory in tcp/mixer/control_factory.h causes Envoy crash.
It can be reproduced under istio.io/istio by
$ go test -v mixer/test/client/tcp_filter/tcp_filter_test.go, or
$ go test -v mixer/test/client/pilotplugin_tcp/pilotplugin_tcp_test.go
istio/istio#10987 fails at these two test.
I build the proxy binary and run tcp_filter_test.go locally, and get this output.
2019-01-15T23:25:26.198319Z info 15:25:26 Short live HTTP POST http://localhost:20121/echo
[libprotobuf ERROR external/com_google_protobuf/src/google/protobuf/wire_format_lite.cc:625] String field 'istio.mixer.v1.CompressedAttributes.words' contains invalid UTF-8 data when serializing a protocol buffer. Use the 'bytes' type if you intend to send raw bytes.
[libprotobuf INFO src/istio/mixerclient/check_cache.cc:160] Add a new Referenced for check cache: Absence-keys: Exact-keys: connection.id, connection.mtls, context.protocol, context.reporter.uid, context.time, destination.namespace, destination.uid, mesh1.ip, origin.ip, source.ip, target.namespace, target.uid,
2019-01-15T23:25:26.205587Z info 15:25:26 Hello World!
[libprotobuf ERROR external/com_google_protobuf/src/google/protobuf/wire_format_lite.cc:625] String field 'istio.mixer.v1.ReportRequest.default_words' contains invalid UTF-8 data when serializing a protocol buffer. Use the 'bytes' type if you intend to send raw bytes.
2019-01-15T23:25:27.207326Z info 15:25:27 Short live HTTP POST http://localhost:20121/echo
tcmalloc: large alloc 94105249480704 bytes == (nil) @ 0x559694eee0ce 0x559694fb225b 0x559693bb5b32 0x559694f690ef 0x559693c52101 0x559693c5d6fb 0x559693c5c289 0x559693c50fa6 0x559693c512f3 0x5596943f03d7 0x5596943f04ee 0x5596943e7756 0x5596943e8e09 0x5596943e8ba7 0x5596943e552f 0x5596943eab49 0x5596943de488 0x5596943de1de 0x5596943de25c 0x559694a1c59b 0x559694a1cb7f 0x559694a20700 0x5596943d97e6 0x5596943caacd 0x5596943ca39c 0x5596943cb3db 0x559693c14730 0x559694e90f3c 0x559694e90f60 0x7f90d4cae494
[2019-01-15 15:25:27.209][184436][critical][main] [external/envoy/source/exe/terminate_handler.cc:13] std::terminate called! (possible uncaught exception, see trace)
[2019-01-15 15:25:27.209][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:94] Backtrace thr<184436> obj</usr/local/google/home/yinjie/go/bin/envoy> (If unsymbolized, use tools/stack_decode.py):
[2019-01-15 15:25:27.235][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #0 0x559694e8eb7c backward::details::unwind<>()
[2019-01-15 15:25:27.253][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #1 0x559694e8dd66 backward::StackTraceImpl<>::load_here()
[2019-01-15 15:25:27.271][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #2 0x559694e8e408 Envoy::BackwardsTrace::capture()
[2019-01-15 15:25:27.288][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #3 0x559694e9084f Envoy::TerminateHandler::logOnTerminate()::{lambda()#1}::operator()()
[2019-01-15 15:25:27.306][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #4 0x559694e90894 Envoy::TerminateHandler::logOnTerminate()::{lambda()#1}::_FUN()
[2019-01-15 15:25:27.324][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #5 0x559694f0da45 __cxxabiv1::__terminate()
[2019-01-15 15:25:27.341][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #6 0x559694f0da90 std::terminate()
[2019-01-15 15:25:27.359][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #7 0x559694f0dc13 __cxa_throw
[2019-01-15 15:25:27.376][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #8 0x559694eed997 (anonymous namespace)::handle_oom()
[2019-01-15 15:25:27.394][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #9 0x559694fb21cd tcmalloc::allocate_full_cpp_throw_oom()
[2019-01-15 15:25:27.411][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #10 0x559693bb5b31 std::__cxx11::basic_string<>::_M_construct<>()
[2019-01-15 15:25:27.428][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #11 0x559694f690ee std::__cxx11::basic_string<>::basic_string()
[2019-01-15 15:25:27.446][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #12 0x559693bb2a7e std::operator+<>()
[2019-01-15 15:25:27.463][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #13 0x559693c52100 _ZNK5Envoy3Tcp5Mixer6Filter15GetConnectionIdB5cxx11Ev
[2019-01-15 15:25:27.480][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #14 0x559693c5d6fa istio::control::tcp::AttributesBuilder::ExtractCheckAttributes()
[2019-01-15 15:25:27.497][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #15 0x559693c5c288 istio::control::tcp::RequestHandlerImpl::Check()
[2019-01-15 15:25:27.514][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #16 0x559693c50fa5 Envoy::Tcp::Mixer::Filter::callCheck()
[2019-01-15 15:25:27.531][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #17 0x559693c512f2 Envoy::Tcp::Mixer::Filter::onData()
[2019-01-15 15:25:27.549][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #18 0x5596943f03d6 Envoy::Network::FilterManagerImpl::onContinueReading()
[2019-01-15 15:25:27.565][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #19 0x5596943f04ed Envoy::Network::FilterManagerImpl::onRead()
[2019-01-15 15:25:27.582][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #20 0x5596943e7755 Envoy::Network::ConnectionImpl::onRead()
[2019-01-15 15:25:27.598][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #21 0x5596943e8e08 Envoy::Network::ConnectionImpl::onReadReady()
[2019-01-15 15:25:27.615][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #22 0x5596943e8ba6 Envoy::Network::ConnectionImpl::onFileEvent()
[2019-01-15 15:25:27.631][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #23 0x5596943e552e Envoy::Network::ConnectionImpl::ConnectionImpl()::{lambda()#3}::operator()()
[2019-01-15 15:25:27.647][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #24 0x5596943eab48 std::_Function_handler<>::_M_invoke()
[2019-01-15 15:25:27.664][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #25 0x5596943de487 std::function<>::operator()()
[2019-01-15 15:25:27.680][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #26 0x5596943de1dd Envoy::Event::FileEventImpl::assignEvents()::{lambda()#1}::operator()()
[2019-01-15 15:25:27.696][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #27 0x5596943de25b Envoy::Event::FileEventImpl::assignEvents()::{lambda()#1}::_FUN()
[2019-01-15 15:25:27.713][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #28 0x559694a1c59a event_process_active_single_queue.isra.29
[2019-01-15 15:25:27.729][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #29 0x559694a1cb7e event_process_active
[2019-01-15 15:25:27.745][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #30 0x559694a206ff event_base_loop
[2019-01-15 15:25:27.762][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #31 0x5596943d97e5 Envoy::Event::DispatcherImpl::run()
[2019-01-15 15:25:27.778][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #32 0x5596943caacc Envoy::Server::WorkerImpl::threadRoutine()
[2019-01-15 15:25:27.795][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #33 0x5596943ca39b Envoy::Server::WorkerImpl::start()::{lambda()#1}::operator()()
[2019-01-15 15:25:27.811][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #34 0x5596943cb3da std::_Function_handler<>::_M_invoke()
[2019-01-15 15:25:27.827][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #35 0x559693c1472f std::function<>::operator()()
[2019-01-15 15:25:27.843][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #36 0x559694e90f3b Envoy::Thread::ThreadImplPosix::ThreadImplPosix()::{lambda()#1}::operator()()
[2019-01-15 15:25:27.860][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #37 0x559694e90f5f Envoy::Thread::ThreadImplPosix::ThreadImplPosix()::{lambda()#1}::_FUN()
[2019-01-15 15:25:27.860][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:104] thr<184436> obj</lib/x86_64-linux-gnu/libpthread.so.0>
[2019-01-15 15:25:27.860][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #38 0x7f90d4cae493 start_thread
[2019-01-15 15:25:27.860][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:104] thr<184436> obj</lib/x86_64-linux-gnu/libc.so.6>
[2019-01-15 15:25:27.860][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:117] thr<184436> #39 0x7f90d46eca8e (unknown)
[2019-01-15 15:25:27.860][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:121] end backtrace thread 184436
[2019-01-15 15:25:27.860][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:125] Caught Aborted, suspect faulting address 0x3b5be0002d06d
[2019-01-15 15:25:27.860][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:94] Backtrace thr<184436> obj</lib/x86_64-linux-gnu/libc.so.6> (If unsymbolized, use tools/stack_decode.py):
[2019-01-15 15:25:27.860][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:117] thr<184436> #0 0x7f90d4636fcf (unknown)
[2019-01-15 15:25:27.860][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:117] thr<184436> #1 0x7f90d46383f9 (unknown)
[2019-01-15 15:25:27.860][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:104] thr<184436> obj</usr/local/google/home/yinjie/go/bin/envoy>
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #2 0x559694e9086c Envoy::TerminateHandler::logOnTerminate()::{lambda()#1}::operator()()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #3 0x559694e90894 Envoy::TerminateHandler::logOnTerminate()::{lambda()#1}::_FUN()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #4 0x559694f0da45 __cxxabiv1::__terminate()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #5 0x559694f0da90 std::terminate()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #6 0x559694f0dc13 __cxa_throw
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #7 0x559694eed997 (anonymous namespace)::handle_oom()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #8 0x559694fb21cd tcmalloc::allocate_full_cpp_throw_oom()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #9 0x559693bb5b31 std::__cxx11::basic_string<>::_M_construct<>()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #10 0x559694f690ee std::__cxx11::basic_string<>::basic_string()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #11 0x559693bb2a7e std::operator+<>()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #12 0x559693c52100 _ZNK5Envoy3Tcp5Mixer6Filter15GetConnectionIdB5cxx11Ev
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #13 0x559693c5d6fa istio::control::tcp::AttributesBuilder::ExtractCheckAttributes()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #14 0x559693c5c288 istio::control::tcp::RequestHandlerImpl::Check()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #15 0x559693c50fa5 Envoy::Tcp::Mixer::Filter::callCheck()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #16 0x559693c512f2 Envoy::Tcp::Mixer::Filter::onData()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #17 0x5596943f03d6 Envoy::Network::FilterManagerImpl::onContinueReading()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #18 0x5596943f04ed Envoy::Network::FilterManagerImpl::onRead()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #19 0x5596943e7755 Envoy::Network::ConnectionImpl::onRead()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #20 0x5596943e8e08 Envoy::Network::ConnectionImpl::onReadReady()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #21 0x5596943e8ba6 Envoy::Network::ConnectionImpl::onFileEvent()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #22 0x5596943e552e Envoy::Network::ConnectionImpl::ConnectionImpl()::{lambda()#3}::operator()()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #23 0x5596943eab48 std::_Function_handler<>::_M_invoke()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #24 0x5596943de487 std::function<>::operator()()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #25 0x5596943de1dd Envoy::Event::FileEventImpl::assignEvents()::{lambda()#1}::operator()()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #26 0x5596943de25b Envoy::Event::FileEventImpl::assignEvents()::{lambda()#1}::_FUN()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #27 0x559694a1c59a event_process_active_single_queue.isra.29
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #28 0x559694a1cb7e event_process_active
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #29 0x559694a206ff event_base_loop
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #30 0x5596943d97e5 Envoy::Event::DispatcherImpl::run()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #31 0x5596943caacc Envoy::Server::WorkerImpl::threadRoutine()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #32 0x5596943ca39b Envoy::Server::WorkerImpl::start()::{lambda()#1}::operator()()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #33 0x5596943cb3da std::_Function_handler<>::_M_invoke()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #34 0x559693c1472f std::function<>::operator()()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #35 0x559694e90f3b Envoy::Thread::ThreadImplPosix::ThreadImplPosix()::{lambda()#1}::operator()()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #36 0x559694e90f5f Envoy::Thread::ThreadImplPosix::ThreadImplPosix()::{lambda()#1}::_FUN()
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:104] thr<184436> obj</lib/x86_64-linux-gnu/libpthread.so.0>
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:114] thr<184436> #37 0x7f90d4cae493 start_thread
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:104] thr<184436> obj</lib/x86_64-linux-gnu/libc.so.6>
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:117] thr<184436> #38 0x7f90d46eca8e (unknown)
[2019-01-15 15:25:27.877][184436][critical][backtrace] [bazel-out/k8-fastbuild/bin/external/envoy/source/server/_virtual_includes/backtrace_lib/server/backtrace.h:121] end backtrace thread 184436
* Removes dangling pointer in capture list of lambda function. (#2080) * Replace this with members in capture list. * update * fix format * Use shared_ptr to protect members which are passed to capture list of lambda function. (#2083) * fix bug * introduce ControlData * fix format * update * fix format * Revise * Pass ControlDataSharedPtr into Control and hold ref * pass JwtAuthenticationConstSharedPtr into JwtAuthStore to hold ref * Revise * Update Envoy SHA to latest with protobuf.Any configs (release-1.1). (#2082) * Update Envoy SHA to latest with protobuf.Any configs (release-1.1). For istio/istio#10993. Signed-off-by: Piotr Sikora <[email protected]> * review: don't open /dev/stdout in tests. Signed-off-by: Piotr Sikora <[email protected]> * Update Istio API to latest (1.1 branch) (#2084) Signed-off-by: Yangmin Zhu <[email protected]>
* update envoy Signed-off-by: Kuat Yessenov <[email protected]> * update Envoy's SHA to latest to include the SNI inspecting method, for using SNI in telemetry and policies Signed-off-by: Vadim Eisenberg <[email protected]> * implement destination.principal Signed-off-by: Kuat Yessenov <[email protected]> * missing test Signed-off-by: Kuat Yessenov <[email protected]> * review Signed-off-by: Kuat Yessenov <[email protected]> * add AttributeName::kConnectionRequestedServerName * fix format * add GetRequestedServerName() to TCP CheckData * add building attribute ConnectionRequestedServerName * test building attribute ConnectionRequestedServerName * add GetRequestedServerName() to tcp mixer filter * fix compilation errors * use explicit conversion from absl::string_view to std::string * check that the requested server name is not emtpy in attributes builder * fixed a compilation error * add GetRequestedServerName to http mixer filters (check_data) * add GetRequestedServerName to http MockCheckData * specify the class of a method * add setting connection.requested_server_name to the http attributes * qualify Return by testing:: * use connection_ as a pointer * add explicit conversion from absl::string_view to std::string * add missing mock call * Revert "Add connection requested server name attribute to TCP read filter" * update the API SHA (istio/api#575) * add the connection.requested_server_name attribute to tcp and http filters * add missing parentheses * add AttributeName::kConnectionRequestedServerName * fix cardinality of a mock method * fix the signature of TCP Filter::GetRequestedServerName() * add declarations of GetRequestedServerName() to tcp Filter/http CheckData classes * add peer and local distinction Signed-off-by: Kuat Yessenov <[email protected]> * Add connection open event. * update comment. * Replace boolean with enum. * extract origin IP Signed-off-by: Kuat Yessenov <[email protected]> * Update Envoy SHA to latest. (#1852) Signed-off-by: Piotr Sikora <[email protected]> * Revert "Update Envoy SHA to latest. (#1852)" (#1854) This reverts commit f85f49c. * update api sha (#1855) * update api sha * update api sha * Update Envoy SHA to latest. (#1857) * Update Envoy SHA to latest. Signed-off-by: Piotr Sikora <[email protected]> * review: install pkg-config on CircleCI. Signed-off-by: Piotr Sikora <[email protected]> * review: install pkg-config on build image. Signed-off-by: Piotr Sikora <[email protected]> * Update Envoy SHA for WebSocket fix (#1859) Signed-off-by: Shriram Rajagopalan <[email protected]> * Revert "Update Envoy SHA for WebSocket fix (#1859)" (#1860) This reverts commit f47be07. * Update Envoy SHA to latest. (#1862) Signed-off-by: Piotr Sikora <[email protected]> * Update istio.dep as valid json (#1863) * Update software in the build image used by CircleCI. (#1874) Signed-off-by: Piotr Sikora <[email protected]> * Improve build times on CircleCI. (#1875) 1. Stop trashing build's cache. 2. Split ASan and TSan tests into separate targets. 3. Fix output directory, so that caching works on macOS. Before: - build : 49 mins - macos : 30 mins After: - build : 27 mins - linux_asan: 20 mins - linux_tsan: 16 mins - macos : 30 mins After (with warm cache): - build : 3 mins - linux_asan: 4 mins - linux_tsan: 2 mins - macos : 5 mins Fixes #1815. Signed-off-by: Piotr Sikora <[email protected]> * Install ninja in the build image used by CircleCI. (#1888) Signed-off-by: Piotr Sikora <[email protected]> * merge 1.0 branch to master (#1885) * Reduce log level for jwt filter (#1866) * Update_Dependencies (#1873) * Correctly clean up headers used for payload from JWT authentication (#1879) * Correctly clean up headers used for payload from JWT authentication * Clang * Update_Dependencies (#1883) * destination.principal derivation fix (#1884) * fix attribute extraction Signed-off-by: Kuat Yessenov <[email protected]> * seed mock Signed-off-by: Kuat Yessenov <[email protected]> * merge 1.0 to master * Update API SHA (#1891) * add needed dependencies for circle ci * Remove fallback for attribute builder when authn filter is not available (#1887) * Update Envoy SHA to latest with ORIGINAL_DST_LB fix. (#1894) Signed-off-by: Piotr Sikora <[email protected]> * Using request dynamic metadata to pass data from JWT filter to authn filter. (#1893) * Using dynamicMetadata to pass data between filters instead of headers * Lint * Populate authn result to dynamic data only. * Integration test for authn * Clean up and verify all tests * Remove unused test configs * Address reviews * Lint * Add the groups claim to the attribute request.auth.groups (#1896) * Add the groups JWT claims to the attribute request.auth.groups * Fix lint errors * Simplify the code * Fix lint error * Simplify the code * Add a test * Fix the test error * add context.proxy_error_code to report attributes (#1897) * Add integration test with JWT+AuthN+Mixer filter chain (#1899) * Add integration test with JWT+AuthN+Mixer filter chain * Lint * Rename helper function * Lint * Review * send rbac shadow policies metrics to mixer (#1900) * send rbac shadow policies metrics to mixer * rename shadow -> permissive * address comments * address comments * address comments * Use dynamic metadata to for authentication filter output. (#1901) * Use dynamic metadata to for authentication filter output. * Clean up comments. * Lint * Reviews * Lint * Fix test * Remove mis-type * Lint * Add two new attributes: request.url_path and request.queries (#1837) * Add two new attributes: request.url_path and request.queries * Update api in repositories.bzl * update ENVOY_SHA (#1904) * update ENVOY_SHA * change WORKSPACE file * skip empty sni (#1909) Signed-off-by: Kuat Yessenov <[email protected]> * add rbac filter to istio http integration test. (#1907) * add rbac filter to istio http integration test. * rename issueer for rbac test. * Fix macOS build on CircleCI. (#1916) Apparently, automake is now installed automatically, which broke the brew install step. Signed-off-by: Piotr Sikora <[email protected]> * Install clang-format in the build image used by CircleCI. (#1917) Signed-off-by: Piotr Sikora <[email protected]> * Provide source version information in the binary. (#1915) Before: $ bazel-bin/src/envoy/envoy --version bazel-bin/src/envoy/envoy version: 0/1.8.0-dev//DEBUG After: $ bazel-bin/src/envoy/envoy --version bazel-bin/src/envoy/envoy version: f315a32fc7c6f727fc9645cc1ca27d4160c1d0e0/1.8.0-dev/Clean/DEBUG Fixes #1803. Signed-off-by: Piotr Sikora <[email protected]> * fixed broken links to dev guide and contribution guide (#1913) * Update clang to 6.0 and use it for release binaries. (#1914) Signed-off-by: Piotr Sikora <[email protected]> * Update Envoy SHA to latest with LcTrie optimizations. (#1918) Signed-off-by: Piotr Sikora <[email protected]> * add debug logs for collecting rbac attributes (#1922) * populate source user without authn (#1926) Signed-off-by: Kuat Yessenov <[email protected]> * update API sha. (#1927) * Add a check cache test for string map sub keys (#1931) Signed-off-by: Wayne Zhang <[email protected]> * Update Envoy SHA to latest with MetricImpl optimizations. (#1938) This is far from finished, but it reduces memory usage by ~10%. Pulling the following changes from github.com/envoyproxy/envoy: c1cc68d stats: refactoring MetricImpl without strings (#4190) 36809d8 fuzz: coverage profile generation instructions. (#4193) ba40cc9 upstream: rebuild cluster when health check config is changed (#4075) 05c0d52 build: use clang-6.0. (#4168) 01f403e thrift_proxy: introduce header transport (#4082) 564d256 tcp: allow connection pool callers to store protocol state (#4131) 3e1d643 configs: match latest API changes (#4185) bc6a10c Fix wrong mock function name. (#4187) e994c1c Bump yaml-cpp so it builds with Visual Studio 15.8 (#4182) 3d1325e Converting envoy configs to V2 (#2957) 8d0680f Add timestamp to HealthCheckEvent definition (#4119) 497efb9 server: handle non-EnvoyExceptions safely if thrown in constructor. (#4173) 6d6fafd config: strengthen validation for gRPC config sources. (#4171) 132302c fuzz: reduce log level when running under fuzz engine. (#4161) 7c04ac2 test: fix V6EmptyOptions in coverage with IPv6 enable (#4155) 1b2219b ci: remove deprecated bazel --batch option (#4166) 2db6a4c ci: update clang to version 6.0 in the Ubuntu build image. (#4157) 71152b7 ratelimit: Add ratelimit custom response headers (#4015) 3062874 ssl: make Ssl::Connection const everywhere (#4179) 706e262 Handle validation of non expiring tokens in jwt_authn filter (#4007) f06e958 fuzz: tag trivial fuzzers with no_fuzz. (#4156) 27fb1d3 thrift_proxy: add service name matching to router implementation (#4130) 8c189a5 Make over provisioning factor configurable (#4003) 6c08fb4 Making test less flaky (#4149) 592775b fuzz: bare bones HCM fuzzer. (#4118) For istio/istio#7912. Signed-off-by: Piotr Sikora <[email protected]> * Generate source.namespace in proxy. (#1912) * Generate source.namespace in proxy. The next step is to change Mixer to not to generate source.namespace if it's already in the Check call. * add comment. * address comments. * address comment * fix format * simplify the code. * make check. * small update * fix test. * Authn uses protobuf.Struct to store claims and add list support for RBAC (#1925) * Authn uses protobuf.Struct to store claims and add list support for RBAC - Change authn to use protobuf.Struct to store claims - Add list support for RBAC * Change based on the review comments * format it (#1923) Signed-off-by: Kuat Yessenov <[email protected]> * update envoy SHA (#1941) * mixer: clear route cache on header update (#1946) * mixer: clear route cache on header update Signed-off-by: Kuat Yessenov <[email protected]> * check size Signed-off-by: Kuat Yessenov <[email protected]> * support per-path JWT validation. (#1928) * support per-path JWT validation. * address comment * address comments * Fix the peerIsOptional and originIsOptional for authn filter. (#1959) * Mixer Client uses Node metadata to populate Mixer attributes (#1961) * update control to include local_info * WIP * WIP2 * WIP 3 * WIP5 * WIP6 * WIP6 * WIP8 * WIP8 * WIP8 * WIP10 * WIP11 * WIP12 * Unit tests * reduce unit test size * WIP11 * WIP15 * hide unique_ptr and add forward logic to client context * unique_ptr galore * fix formatting * intermediate * add attribute injection in integration_tests * format fix * add correct deps for utils_lib * add call to attr forwarding * review comments * Handle SerializeForwardedAttributes * more review comments * fix linter error * move fn in anonymous ns * Update Envoy SHA to latest with TCP proxy fixes. (#1964) Pulling the following changes from github.com/envoyproxy/envoy: f936fc6 ssl: serialize accesses to SSL socket factory contexts (#4345) e34dcd6 Fix crash in tcp_proxy (#4323) ae6a252 router: fix matching when all domains have wildcards (#4326) aa06142 test: Stop fake_upstream methods from accidentally succeeding (#4232) 5d73187 rbac: update the authenticated.user to a StringMatcher. (#4250) c6bfc7d time: Event::TimeSystem abstraction to make it feasible to inject time with simulated timers (#4257) 752483e Fixing the fix (#4333) 83487f6 tls: update BoringSSL to ab36a84b (3497). (#4338) 7bc210e test: fixing interactions between waitFor and ignore_spurious_events (#4309) 69474b3 admin: order stats in clusters json admin (#4306) 2d155f9 ppc64le build (#4183) 07efc6d fix static initialization fiasco problem (#4314) 0b7e3b5 test: Remove declared but undefined class methods (#4297) 1485a13 lua: make sure resetting dynamic metadata wrapper when request info is marked dead d243cd6 test: set to zero when start_time exceeds limit (#4328) 0a1e92a test: fix heap use-after-free in ~IntegrationTestServer. (#4319) cddc732 CONTRIBUTING: Document 'kick-ci' trick. (#4335) f13ef24 docs: remove reference to deprecated value field (#4322) e947a27 router: minor doc fixes in stream idle timeout (#4329) 0c2e998 tcp-proxy: fixing a TCP proxy bug where we attempted to readDisable a closed connection (#4296) 00ffe44 utility: fix strftime overflow handling. (#4321) af1183c Re-enable TcpProxySslIntegrationTest and make the tests pass again. (#4318) 3553461 fuzz: fix H2 codec fuzzer post #4262. (#4311) 42f6048 Proto string issue fix (#4320) 9c492a0 Support Envoy to fetch secrets using SDS service. (#4256) a857219 ratelimit: revert `revert rate limit failure mode config` and add tests (#4303) 1d34172 dns: fix exception unsafe behavior in c-ares callbacks. (#4307) 1212423 alts: add gRPC TSI socket (#4153) f0363ae fuzz: detect client-side resets in H2 codec fuzzer. (#4300) 01aa3f8 test: hopefully deflaking echo integration test (#4304) 1fc0f4b ratelimit: link legacy proto when message is being used (#4308) aa4481e fix rare List::remove(&target) segfault (#4244) 89e0f23 headers: fixing fast fail of size-validation (#4269) 97eba59 build: bump googletest version. (#4293) 0057e22 fuzz: avoid false positives in HCM fuzzer. (#4262) 9d094e5 Revert ac0bd74 (#4295) ddb28a4 Add validation context provider (#4264) 3b47cba added histogram latency information to Hystrix dashboard stream (#3986) cf87d50 docs: update SNI FAQ. (#4285) f952033 config: fix update empty stat for eds (#4276) 329e591 router: Add ability of custom headers to rely on per-request data (#4219) 68d20b4 thrift: refactor build files and imports (#4271) 5fa8192 access_log: log requested_server_name in tcp proxy (#4144) fa45bb4 fuzz: libc++ clocks don't like nanos. (#4282) 53f8944 stats: add symbol table for future stat name encoding (#3927) c987b42 test infra: Remove timeSource() from the ClusterManager api (#4247) cd171d9 websocket: tunneling websockets (and upgrades in general) over H2 (#4188) b9dc5d9 router: disallow :path/host rewriting in request_headers_to_add. (#4220) 0c91011 network: skip socket options and source address for UDS client connections (#4252) da1857d build: fixing a downstream compile error by noting explicit fallthrough (#4265) 9857cfe fuzz: cleanup per-test environment after each fuzz case. (#4253) 52beb06 test: Wrap proto string in std::string before comparison (#4238) f5e219e extensions/thrift_proxy: Add header matching to thrift router (#4239) c9ce5d2 fuzz: track read_disable_count bidirectionally in codec_impl_fuzz_test. (#4260) 35103b3 fuzz: use nanoseconds for SystemTime in RequestInfo. (#4255) ba6ba98 fuzz: make runtime root hermetic in server_fuzz_test. (#4258) b0a9014 time: Add 'format' test to ensure no one directly instantiates Prod*Time from source. (#4248) 8567460 access_log: support beginning of epoch in START_TIME. (#4254) 28d5f41 proto: unify envoy_proto_library/api_proto_library. (#4233) f7d3cb6 http: fix allocation bug introduced in #4211. (#4245) Fixes istio/istio#8310 (once pulled into istio/istio). Signed-off-by: Piotr Sikora <[email protected]> * remove not used path patcher functions (#1966) Signed-off-by: Wayne Zhang <[email protected]> * Mixer Client: Add support for TCP local attributes (#1967) * Add support for TCP local attributes * linter fixes * review comments * Fix a bug in origin authenticator that wrongly treats empty origin methods as pass (#1962) * Fix a bug in origin authenticator that wrongly treats empty origin methods as pass. * update * update * update * update * Remove delta update in Report batch (#1970) * Remove delta update in Report batch Signed-off-by: Wayne Zhang <[email protected]> * fix format * reduce max_batch_number to 100 * Optimize report sending by re-use protobuf (#1973) Signed-off-by: Wayne Zhang <[email protected]> * To share mixer client across listeners (#1972) Signed-off-by: Wayne Zhang <[email protected]> * Fix a bug of not setting global_word_count (#1974) * Fix a bug of not setting global_word_count Signed-off-by: Wayne Zhang <[email protected]> * not to save global_dict_size Signed-off-by: Wayne Zhang <[email protected]> * Update Envoy SHA. (#1975) Signed-off-by: JimmyCYJ <[email protected]> * Optimize mixer client by using protobuf arena allocator. (#1977) * use arena 1st draft * use arena for check proto Signed-off-by: Wayne Zhang <[email protected]> * use arena for report proto Signed-off-by: Wayne Zhang <[email protected]> * update api sha Signed-off-by: Wayne Zhang <[email protected]> * Update Proxy SHA (#1978) Signed-off-by: JimmyCYJ <[email protected]> * Remove obsolete v1 code (#1980) Signed-off-by: Wayne Zhang <[email protected]> * Update README.md (#1979) * Not to add check attributes if check is disabled (#1981) * Not to add check attributes if check is disabled Signed-off-by: Wayne Zhang <[email protected]> * Remove ExtractRequestAttributes Signed-off-by: Wayne Zhang <[email protected]> * Update Envoy SHA to a637506 (#1982) * Update Envoy SHA to a637506 Signed-off-by: Venil Noronha <[email protected]> * Fix tests based on envoyproxy/envoy#4512 Signed-off-by: Venil Noronha <[email protected]> * Fix formatting errors Signed-off-by: Venil Noronha <[email protected]> * Fix CircleCI config Signed-off-by: Venil Noronha <[email protected]> * Revert "To share mixer client across listeners (#1972)" (#1986) This reverts commit b33ceb2. * fix memory leak at report batching (#1988) Signed-off-by: Wayne Zhang <[email protected]> * reuse report protobuf instead of using arena allocation (#1989) Signed-off-by: Wayne Zhang <[email protected]> * Update software in the build image used by CircleCI. (#1994) Signed-off-by: JimmyCYJ <[email protected]> * Fix attribute constant (#1996) This commit fixes a misspelling in the attribute constants. Signed-off-by: Venil Noronha <[email protected]> * Update bazel for circleCI (#1997) * Update HUB to gcr.io/istio Signed-off-by: JimmyCYJ <[email protected]> * Update bazel image for circleCI Signed-off-by: JimmyCYJ <[email protected]> * Revert hub change. Signed-off-by: JimmyCYJ <[email protected]> * Update dependencies and fix compile errors. (#1993) * Update dependencies and fix compile errors. Signed-off-by: JimmyCYJ <[email protected]> * update bazel version to 0.17 Signed-off-by: JimmyCYJ <[email protected]> * update bazel version to 0.18 Signed-off-by: JimmyCYJ <[email protected]> * revert bazel version to 0.15 Signed-off-by: JimmyCYJ <[email protected]> * Update bazel version for asan and tsan build in circieCI Signed-off-by: JimmyCYJ <[email protected]> * move tool/bazel.rc to .bazelrc (#1998) Signed-off-by: Wayne Zhang <[email protected]> * update envoy SHA to point to json access log format functionality (#1999) * bump Envoy SHA to latest (#2010) Signed-off-by: Shriram Rajagopalan <[email protected]> * Improve performance by removing MD5 for check cache keys (#2002) * Improve performance by removing MD5 for check cache keys Signed-off-by: Wayne Zhang <[email protected]> * not to allocate memory from stack Signed-off-by: Wayne Zhang <[email protected]> * Make debug string readable Signed-off-by: Wayne Zhang <[email protected]> * alts: remove ALTS (#2003) Signed-off-by: Lizan Zhou <[email protected]> * Use std::hash for check cache. (#2009) Signed-off-by: Wayne Zhang <[email protected]> * Send envoy dynamic metadata as part of reports Signed-off-by: Shriram Rajagopalan <[email protected]> * format Signed-off-by: Shriram Rajagopalan <[email protected]> * typos Signed-off-by: Shriram Rajagopalan <[email protected]> * http dynamic metadata Signed-off-by: Shriram Rajagopalan <[email protected]> * format Signed-off-by: Shriram Rajagopalan <[email protected]> * more formatting Signed-off-by: Shriram Rajagopalan <[email protected]> * Use string map instead of opaque struct for dynamic metadata (#2014) * use string map instead of opaque struct for dynamic metadata Signed-off-by: Shriram Rajagopalan <[email protected]> * format Signed-off-by: Shriram Rajagopalan <[email protected]> * double format Signed-off-by: Shriram Rajagopalan <[email protected]> * skip empty maps Signed-off-by: Shriram Rajagopalan <[email protected]> * Add a new TCP cluster rewrite filter (#2017) (#2018) This commit adds a new TCP cluster rewrite filter which allows users to rewrite TCP cluster names obtained via TLS SNI by matching via regex configuration. Signed-off-by: Venil Noronha <[email protected]> * Update TCP Cluster Rewrite filter name (#2019) (#2020) This commit updates the TCP Cluster Rewrite filter name to envoy.filters.network.tcp_cluster_rewrite. Signed-off-by: Venil Noronha <[email protected]> * Enable TCP Cluster Rewrite filter registration (#2021) (#2022) This commit enables the static registration of the TCP Cluster Rewrite filter by updating the build configuration. Signed-off-by: Venil Noronha <[email protected]> * Update Envoy SHA to 4ef8562 (#2023) (#2024) Envoy /server_info API was inconsistent intermittently causing errors on a Proxy update on Istio. This update will bring in the API fix to Istio. Signed-off-by: Venil Noronha <[email protected]> * Update Envoy SHA to 74de08a (#2026) This commit updates the Envoy SHA to 74de08a to bring in the new TCP RBAC filter to Istio. Signed-off-by: Venil Noronha <[email protected]> * Merge master into release-1.1 (#2031) * Improve performance by removing MD5 for check cache keys (#2002) * Improve performance by removing MD5 for check cache keys Signed-off-by: Wayne Zhang <[email protected]> * not to allocate memory from stack Signed-off-by: Wayne Zhang <[email protected]> * Make debug string readable Signed-off-by: Wayne Zhang <[email protected]> * alts: remove ALTS (#2003) Signed-off-by: Lizan Zhou <[email protected]> * Use std::hash for check cache. (#2009) Signed-off-by: Wayne Zhang <[email protected]> * Remove tests to compare signature values (#2015) Signed-off-by: Wayne Zhang <[email protected]> * update sample envoy config to latest version (#2016) * Add a new TCP cluster rewrite filter (#2017) * Add a new TCP cluster rewrite filter This commit adds a new TCP cluster rewrite filter which allows users to rewrite TCP cluster names obtained via TLS SNI by matching via regex configuration. Signed-off-by: Venil Noronha <[email protected]> * Make TCP cluster rewrite stackable on SNI filter This commit updates the TCP Cluster Rewrite filter to be stackable on the SNI Cluster filter. Signed-off-by: Venil Noronha <[email protected]> * Update TCP Cluster Rewrite filter name (#2019) This commit updates the TCP Cluster Rewrite filter name to envoy.filters.network.tcp_cluster_rewrite. Signed-off-by: Venil Noronha <[email protected]> * Enable TCP Cluster Rewrite filter registration (#2021) This commit enables the static registration of the TCP Cluster Rewrite filter by updating the build configuration. Signed-off-by: Venil Noronha <[email protected]> * Update Envoy SHA to 4ef8562 (#2023) Envoy /server_info API was inconsistent intermittently causing errors on a Proxy update on Istio. This update will bring in the API fix to Istio. Signed-off-by: Venil Noronha <[email protected]> * add proxy postsubmit periodic (#2025) * Merge master to release-1.1 (#2038) * Improve performance by removing MD5 for check cache keys (#2002) * Improve performance by removing MD5 for check cache keys Signed-off-by: Wayne Zhang <[email protected]> * not to allocate memory from stack Signed-off-by: Wayne Zhang <[email protected]> * Make debug string readable Signed-off-by: Wayne Zhang <[email protected]> * alts: remove ALTS (#2003) Signed-off-by: Lizan Zhou <[email protected]> * Use std::hash for check cache. (#2009) Signed-off-by: Wayne Zhang <[email protected]> * Remove tests to compare signature values (#2015) Signed-off-by: Wayne Zhang <[email protected]> * update sample envoy config to latest version (#2016) * Add a new TCP cluster rewrite filter (#2017) * Add a new TCP cluster rewrite filter This commit adds a new TCP cluster rewrite filter which allows users to rewrite TCP cluster names obtained via TLS SNI by matching via regex configuration. Signed-off-by: Venil Noronha <[email protected]> * Make TCP cluster rewrite stackable on SNI filter This commit updates the TCP Cluster Rewrite filter to be stackable on the SNI Cluster filter. Signed-off-by: Venil Noronha <[email protected]> * Update TCP Cluster Rewrite filter name (#2019) This commit updates the TCP Cluster Rewrite filter name to envoy.filters.network.tcp_cluster_rewrite. Signed-off-by: Venil Noronha <[email protected]> * Enable TCP Cluster Rewrite filter registration (#2021) This commit enables the static registration of the TCP Cluster Rewrite filter by updating the build configuration. Signed-off-by: Venil Noronha <[email protected]> * Update Envoy SHA to 4ef8562 (#2023) Envoy /server_info API was inconsistent intermittently causing errors on a Proxy update on Istio. This update will bring in the API fix to Istio. Signed-off-by: Venil Noronha <[email protected]> * add proxy postsubmit periodic (#2025) * Update Envoy SHA to c41fa71 (#2029) * Update Envoy SHA Signed-off-by: JimmyCYJ <[email protected]> * Fix format. Signed-off-by: JimmyCYJ <[email protected]> * bazel: Allow to distdir all dependencies (#2034) To use --distdir option of Bazel (which allows to use previously fetched tarballs instead of downloading dependencies during build), all dependencies should use http instead of git and need to have sha256 sums specified. Signed-off-by: Michal Rostecki <[email protected]> * bazel: Remove BoringSSL repository (#2035) Pull request #2002 removed signature calculation which was using BoringSSL as a dependency. BoringSSL is not needed anymore. Signed-off-by: Michal Rostecki <[email protected]> * Update Envoy SHA to fcc68f1 (#2037) * Update Envoy SHA to fcc68f1 Signed-off-by: JimmyCYJ <[email protected]> * Update SHA256 Signed-off-by: JimmyCYJ <[email protected]> * Enable caching of dynamic metadata in mixer filter (#2040) * Enable caching of dynamic metadata in mixer filter This enables caching of dynamic metadata in the onData call in the mixer filter and returns the same during the GetDynamicFilterState call. Signed-off-by: Venil Noronha <[email protected]> * Update cloning to reflect Mongo format updates This updates the deep cloning logic in the mixer filter to reflect the latest changes in the Mongo proxy filter's dynamic metadata format. Signed-off-by: Venil Noronha <[email protected]> * Update api sha to 1a7788d (#2044) Signed-off-by: Wayne Zhang <[email protected]> * Bump enoy version to pickup json access log fix (#2047) * Bump enoy version to pickup json access log fix Signed-off-by: Christopher M. Luciano <[email protected]> * Add sha256sum and note about how to retrieve the sum Signed-off-by: Christopher M. Luciano <[email protected]> * update envoy sha (#2048) * update envoy sha * update envoy SHA to 48b161e (#2041) * update envoy SHA to 48b161e * use Http::AsyncClient::RequestOptions() in AsyncClient::send() * PerConnectionCluster::Key -> PerConnectionCluster::key() * use Http::AsyncClient::RequestOptions() in AsyncClient::send() in the test * fix format * Forward Downstream SNI filter (#2045) * initial implementation of forward_downstream_api filter * fix the license message in BUILD (sh comments) * add missing dependencies * add definition of config_lib to BUILD * remove public visibility from forward_downstream_sni_lib * remove envoy_cc_binary dependency * StreamInfo::UpstreamServerName -> Network::UpstreamServerName * fix namespace (Extensions -> Tcp) * remove config_test * Add sni verifier filter (#2050) * Copy the network_level_sni_reader filter * Add SniVerifier filter based on NetworkLevelSniReader * Add extra details to log * refactoring, tests, make buf_ non-static, handle data in chunks * add credit to TLS inspector of Envoy * add ERR_clear_error() * Handle inflight request canceling properly (#2053) Signed-off-by: Wayne Zhang <[email protected]> * Fix build issue with bazel 0.20 (#2069) * Clarify log messages (#2066) (#2067) * Authenticate an exchanged token (#2070) * Authenticate an exchanged token * Change issuer name and jwt-authn output with key being original issuer * Revised the code based on the discussion * Address review comments and add a test * Address new review comments * Add integration tests and address review comments * Fix a flaky test and address new review comments * Small grammar fixes * Revise the function of finding the token header * Use case-insensitive compare for the header name * Change the name of a variable * Revise log statements * support extract token from customer http header with prefix (#2073) * support passing jwt token with prefix * format * address comments * address comment (#2075) * address comment * search from start * update envoy sha (#2074) * update envoy sha * library bug fixes * bug fix * lint fixes * lint fixes * lint fixes * test fixes * rename rbac permissive related attributes key due to envoy recent change (#2076) * rename rbac permissive related attributes key due to envoy recent change * rename * Removes dangling pointer in capture list of lambda function. (#2080) * Replace this with members in capture list. * update * fix format * Use shared_ptr to protect members which are passed to capture list of lambda function. (#2083) * fix bug * introduce ControlData * fix format * update * fix format * Revise * Pass ControlDataSharedPtr into Control and hold ref * pass JwtAuthenticationConstSharedPtr into JwtAuthStore to hold ref * Revise * Update Envoy SHA to latest with protobuf.Any configs (release-1.1). (#2082) * Update Envoy SHA to latest with protobuf.Any configs (release-1.1). For istio/istio#10993. Signed-off-by: Piotr Sikora <[email protected]> * review: don't open /dev/stdout in tests. Signed-off-by: Piotr Sikora <[email protected]> * Update Istio API to latest (1.1 branch) (#2084) Signed-off-by: Yangmin Zhu <[email protected]> * use route directive regardless of rpc status (#2087) * use route directive regardless of rpc status Signed-off-by: Kuat Yessenov <[email protected]> * log response code Signed-off-by: Kuat Yessenov <[email protected]> * Upgrade Envoy to b3be571 (#2091) * Upgrade Envoy to b3be571 This updates Envoy SHA to b3be571. Signed-off-by: Venil Noronha <[email protected]> * Update tls_utility paths This updates the tls_utility library and include paths. Signed-off-by: Venil Noronha <[email protected]> * Fix http mixer filter This adds the encodeMetadata implementation to the http mixer filter to fix a build issue. Signed-off-by: Venil Noronha <[email protected]> * Fix sha256sum overwrite error This removes the ln command from the CircleCI configuration to fix a file overwrite error on macOS jobs. Signed-off-by: Venil Noronha <[email protected]> * Fix build on macOS. (#2090) (#2094) sha256sum shouldn't be necessary, since we use gsha256sum on macOS. Signed-off-by: Piotr Sikora <[email protected]> * add mixer error details into metadata (#2093) * add mixer error details into metadata Signed-off-by: Lizan Zhou <[email protected]> * format Signed-off-by: Lizan Zhou <[email protected]> * review Signed-off-by: Lizan Zhou <[email protected]> * comment Signed-off-by: Lizan Zhou <[email protected]> * Forwarded attributes override statically configured Local Attributes (#2097) * WIP * add local and override tests * revert attributes_builder * white list forward attributes * add tests with whitelist * fix builder test for white listed attributes * comment out failed test case
What this PR does / why we need it:
The ControlFactory for HTTP Mixer filter post a callback into worker threads' dispatcher, which will be invoked by event loop. The callback is a lambda function that has a this pointer in the capture list, and the pointer points to ControlFactory. When Envoy rejects a bad listener config, the ControlFactory is destructed accordingly, and therefore the "this" pointer becomes dangling pointer. TCP Mixer filter and JwtAuthStoreFactory have the same issue, too. This PR removes "this" pointer from capture list, and passes shared_ptr of components that are needed by the lambda function. Tests will be added in a following PR.
Which issue this PR fixes :
fixes #2079
Release note: