health.pb.go 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724
  1. // Code generated by protoc-gen-gogo.
  2. // source: github.com/docker/swarmkit/api/health.proto
  3. // DO NOT EDIT!
  4. package api
  5. import proto "github.com/gogo/protobuf/proto"
  6. import fmt "fmt"
  7. import math "math"
  8. import _ "github.com/gogo/protobuf/gogoproto"
  9. import _ "github.com/docker/swarmkit/protobuf/plugin"
  10. import (
  11. context "golang.org/x/net/context"
  12. grpc "google.golang.org/grpc"
  13. )
  14. import raftselector "github.com/docker/swarmkit/manager/raftselector"
  15. import codes "google.golang.org/grpc/codes"
  16. import status "google.golang.org/grpc/status"
  17. import metadata "google.golang.org/grpc/metadata"
  18. import transport "google.golang.org/grpc/transport"
  19. import rafttime "time"
  20. import strings "strings"
  21. import reflect "reflect"
  22. import io "io"
  23. // Reference imports to suppress errors if they are not otherwise used.
  24. var _ = proto.Marshal
  25. var _ = fmt.Errorf
  26. var _ = math.Inf
  27. type HealthCheckResponse_ServingStatus int32
  28. const (
  29. HealthCheckResponse_UNKNOWN HealthCheckResponse_ServingStatus = 0
  30. HealthCheckResponse_SERVING HealthCheckResponse_ServingStatus = 1
  31. HealthCheckResponse_NOT_SERVING HealthCheckResponse_ServingStatus = 2
  32. )
  33. var HealthCheckResponse_ServingStatus_name = map[int32]string{
  34. 0: "UNKNOWN",
  35. 1: "SERVING",
  36. 2: "NOT_SERVING",
  37. }
  38. var HealthCheckResponse_ServingStatus_value = map[string]int32{
  39. "UNKNOWN": 0,
  40. "SERVING": 1,
  41. "NOT_SERVING": 2,
  42. }
  43. func (x HealthCheckResponse_ServingStatus) String() string {
  44. return proto.EnumName(HealthCheckResponse_ServingStatus_name, int32(x))
  45. }
  46. func (HealthCheckResponse_ServingStatus) EnumDescriptor() ([]byte, []int) {
  47. return fileDescriptorHealth, []int{1, 0}
  48. }
  49. type HealthCheckRequest struct {
  50. Service string `protobuf:"bytes,1,opt,name=service,proto3" json:"service,omitempty"`
  51. }
  52. func (m *HealthCheckRequest) Reset() { *m = HealthCheckRequest{} }
  53. func (*HealthCheckRequest) ProtoMessage() {}
  54. func (*HealthCheckRequest) Descriptor() ([]byte, []int) { return fileDescriptorHealth, []int{0} }
  55. type HealthCheckResponse struct {
  56. Status HealthCheckResponse_ServingStatus `protobuf:"varint,1,opt,name=status,proto3,enum=docker.swarmkit.v1.HealthCheckResponse_ServingStatus" json:"status,omitempty"`
  57. }
  58. func (m *HealthCheckResponse) Reset() { *m = HealthCheckResponse{} }
  59. func (*HealthCheckResponse) ProtoMessage() {}
  60. func (*HealthCheckResponse) Descriptor() ([]byte, []int) { return fileDescriptorHealth, []int{1} }
  61. func init() {
  62. proto.RegisterType((*HealthCheckRequest)(nil), "docker.swarmkit.v1.HealthCheckRequest")
  63. proto.RegisterType((*HealthCheckResponse)(nil), "docker.swarmkit.v1.HealthCheckResponse")
  64. proto.RegisterEnum("docker.swarmkit.v1.HealthCheckResponse_ServingStatus", HealthCheckResponse_ServingStatus_name, HealthCheckResponse_ServingStatus_value)
  65. }
  66. type authenticatedWrapperHealthServer struct {
  67. local HealthServer
  68. authorize func(context.Context, []string) error
  69. }
  70. func NewAuthenticatedWrapperHealthServer(local HealthServer, authorize func(context.Context, []string) error) HealthServer {
  71. return &authenticatedWrapperHealthServer{
  72. local: local,
  73. authorize: authorize,
  74. }
  75. }
  76. func (p *authenticatedWrapperHealthServer) Check(ctx context.Context, r *HealthCheckRequest) (*HealthCheckResponse, error) {
  77. if err := p.authorize(ctx, []string{"swarm-manager"}); err != nil {
  78. return nil, err
  79. }
  80. return p.local.Check(ctx, r)
  81. }
  82. func (m *HealthCheckRequest) Copy() *HealthCheckRequest {
  83. if m == nil {
  84. return nil
  85. }
  86. o := &HealthCheckRequest{}
  87. o.CopyFrom(m)
  88. return o
  89. }
  90. func (m *HealthCheckRequest) CopyFrom(src interface{}) {
  91. o := src.(*HealthCheckRequest)
  92. *m = *o
  93. }
  94. func (m *HealthCheckResponse) Copy() *HealthCheckResponse {
  95. if m == nil {
  96. return nil
  97. }
  98. o := &HealthCheckResponse{}
  99. o.CopyFrom(m)
  100. return o
  101. }
  102. func (m *HealthCheckResponse) CopyFrom(src interface{}) {
  103. o := src.(*HealthCheckResponse)
  104. *m = *o
  105. }
  106. // Reference imports to suppress errors if they are not otherwise used.
  107. var _ context.Context
  108. var _ grpc.ClientConn
  109. // This is a compile-time assertion to ensure that this generated file
  110. // is compatible with the grpc package it is being compiled against.
  111. const _ = grpc.SupportPackageIsVersion4
  112. // Client API for Health service
  113. type HealthClient interface {
  114. Check(ctx context.Context, in *HealthCheckRequest, opts ...grpc.CallOption) (*HealthCheckResponse, error)
  115. }
  116. type healthClient struct {
  117. cc *grpc.ClientConn
  118. }
  119. func NewHealthClient(cc *grpc.ClientConn) HealthClient {
  120. return &healthClient{cc}
  121. }
  122. func (c *healthClient) Check(ctx context.Context, in *HealthCheckRequest, opts ...grpc.CallOption) (*HealthCheckResponse, error) {
  123. out := new(HealthCheckResponse)
  124. err := grpc.Invoke(ctx, "/docker.swarmkit.v1.Health/Check", in, out, c.cc, opts...)
  125. if err != nil {
  126. return nil, err
  127. }
  128. return out, nil
  129. }
  130. // Server API for Health service
  131. type HealthServer interface {
  132. Check(context.Context, *HealthCheckRequest) (*HealthCheckResponse, error)
  133. }
  134. func RegisterHealthServer(s *grpc.Server, srv HealthServer) {
  135. s.RegisterService(&_Health_serviceDesc, srv)
  136. }
  137. func _Health_Check_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
  138. in := new(HealthCheckRequest)
  139. if err := dec(in); err != nil {
  140. return nil, err
  141. }
  142. if interceptor == nil {
  143. return srv.(HealthServer).Check(ctx, in)
  144. }
  145. info := &grpc.UnaryServerInfo{
  146. Server: srv,
  147. FullMethod: "/docker.swarmkit.v1.Health/Check",
  148. }
  149. handler := func(ctx context.Context, req interface{}) (interface{}, error) {
  150. return srv.(HealthServer).Check(ctx, req.(*HealthCheckRequest))
  151. }
  152. return interceptor(ctx, in, info, handler)
  153. }
  154. var _Health_serviceDesc = grpc.ServiceDesc{
  155. ServiceName: "docker.swarmkit.v1.Health",
  156. HandlerType: (*HealthServer)(nil),
  157. Methods: []grpc.MethodDesc{
  158. {
  159. MethodName: "Check",
  160. Handler: _Health_Check_Handler,
  161. },
  162. },
  163. Streams: []grpc.StreamDesc{},
  164. Metadata: "github.com/docker/swarmkit/api/health.proto",
  165. }
  166. func (m *HealthCheckRequest) Marshal() (dAtA []byte, err error) {
  167. size := m.Size()
  168. dAtA = make([]byte, size)
  169. n, err := m.MarshalTo(dAtA)
  170. if err != nil {
  171. return nil, err
  172. }
  173. return dAtA[:n], nil
  174. }
  175. func (m *HealthCheckRequest) MarshalTo(dAtA []byte) (int, error) {
  176. var i int
  177. _ = i
  178. var l int
  179. _ = l
  180. if len(m.Service) > 0 {
  181. dAtA[i] = 0xa
  182. i++
  183. i = encodeVarintHealth(dAtA, i, uint64(len(m.Service)))
  184. i += copy(dAtA[i:], m.Service)
  185. }
  186. return i, nil
  187. }
  188. func (m *HealthCheckResponse) Marshal() (dAtA []byte, err error) {
  189. size := m.Size()
  190. dAtA = make([]byte, size)
  191. n, err := m.MarshalTo(dAtA)
  192. if err != nil {
  193. return nil, err
  194. }
  195. return dAtA[:n], nil
  196. }
  197. func (m *HealthCheckResponse) MarshalTo(dAtA []byte) (int, error) {
  198. var i int
  199. _ = i
  200. var l int
  201. _ = l
  202. if m.Status != 0 {
  203. dAtA[i] = 0x8
  204. i++
  205. i = encodeVarintHealth(dAtA, i, uint64(m.Status))
  206. }
  207. return i, nil
  208. }
  209. func encodeFixed64Health(dAtA []byte, offset int, v uint64) int {
  210. dAtA[offset] = uint8(v)
  211. dAtA[offset+1] = uint8(v >> 8)
  212. dAtA[offset+2] = uint8(v >> 16)
  213. dAtA[offset+3] = uint8(v >> 24)
  214. dAtA[offset+4] = uint8(v >> 32)
  215. dAtA[offset+5] = uint8(v >> 40)
  216. dAtA[offset+6] = uint8(v >> 48)
  217. dAtA[offset+7] = uint8(v >> 56)
  218. return offset + 8
  219. }
  220. func encodeFixed32Health(dAtA []byte, offset int, v uint32) int {
  221. dAtA[offset] = uint8(v)
  222. dAtA[offset+1] = uint8(v >> 8)
  223. dAtA[offset+2] = uint8(v >> 16)
  224. dAtA[offset+3] = uint8(v >> 24)
  225. return offset + 4
  226. }
  227. func encodeVarintHealth(dAtA []byte, offset int, v uint64) int {
  228. for v >= 1<<7 {
  229. dAtA[offset] = uint8(v&0x7f | 0x80)
  230. v >>= 7
  231. offset++
  232. }
  233. dAtA[offset] = uint8(v)
  234. return offset + 1
  235. }
  236. type raftProxyHealthServer struct {
  237. local HealthServer
  238. connSelector raftselector.ConnProvider
  239. localCtxMods, remoteCtxMods []func(context.Context) (context.Context, error)
  240. }
  241. func NewRaftProxyHealthServer(local HealthServer, connSelector raftselector.ConnProvider, localCtxMod, remoteCtxMod func(context.Context) (context.Context, error)) HealthServer {
  242. redirectChecker := func(ctx context.Context) (context.Context, error) {
  243. s, ok := transport.StreamFromContext(ctx)
  244. if !ok {
  245. return ctx, status.Errorf(codes.InvalidArgument, "remote addr is not found in context")
  246. }
  247. addr := s.ServerTransport().RemoteAddr().String()
  248. md, ok := metadata.FromContext(ctx)
  249. if ok && len(md["redirect"]) != 0 {
  250. return ctx, status.Errorf(codes.ResourceExhausted, "more than one redirect to leader from: %s", md["redirect"])
  251. }
  252. if !ok {
  253. md = metadata.New(map[string]string{})
  254. }
  255. md["redirect"] = append(md["redirect"], addr)
  256. return metadata.NewContext(ctx, md), nil
  257. }
  258. remoteMods := []func(context.Context) (context.Context, error){redirectChecker}
  259. remoteMods = append(remoteMods, remoteCtxMod)
  260. var localMods []func(context.Context) (context.Context, error)
  261. if localCtxMod != nil {
  262. localMods = []func(context.Context) (context.Context, error){localCtxMod}
  263. }
  264. return &raftProxyHealthServer{
  265. local: local,
  266. connSelector: connSelector,
  267. localCtxMods: localMods,
  268. remoteCtxMods: remoteMods,
  269. }
  270. }
  271. func (p *raftProxyHealthServer) runCtxMods(ctx context.Context, ctxMods []func(context.Context) (context.Context, error)) (context.Context, error) {
  272. var err error
  273. for _, mod := range ctxMods {
  274. ctx, err = mod(ctx)
  275. if err != nil {
  276. return ctx, err
  277. }
  278. }
  279. return ctx, nil
  280. }
  281. func (p *raftProxyHealthServer) pollNewLeaderConn(ctx context.Context) (*grpc.ClientConn, error) {
  282. ticker := rafttime.NewTicker(500 * rafttime.Millisecond)
  283. defer ticker.Stop()
  284. for {
  285. select {
  286. case <-ticker.C:
  287. conn, err := p.connSelector.LeaderConn(ctx)
  288. if err != nil {
  289. return nil, err
  290. }
  291. client := NewHealthClient(conn)
  292. resp, err := client.Check(ctx, &HealthCheckRequest{Service: "Raft"})
  293. if err != nil || resp.Status != HealthCheckResponse_SERVING {
  294. continue
  295. }
  296. return conn, nil
  297. case <-ctx.Done():
  298. return nil, ctx.Err()
  299. }
  300. }
  301. }
  302. func (p *raftProxyHealthServer) Check(ctx context.Context, r *HealthCheckRequest) (*HealthCheckResponse, error) {
  303. conn, err := p.connSelector.LeaderConn(ctx)
  304. if err != nil {
  305. if err == raftselector.ErrIsLeader {
  306. ctx, err = p.runCtxMods(ctx, p.localCtxMods)
  307. if err != nil {
  308. return nil, err
  309. }
  310. return p.local.Check(ctx, r)
  311. }
  312. return nil, err
  313. }
  314. modCtx, err := p.runCtxMods(ctx, p.remoteCtxMods)
  315. if err != nil {
  316. return nil, err
  317. }
  318. resp, err := NewHealthClient(conn).Check(modCtx, r)
  319. if err != nil {
  320. if !strings.Contains(err.Error(), "is closing") && !strings.Contains(err.Error(), "the connection is unavailable") && !strings.Contains(err.Error(), "connection error") {
  321. return resp, err
  322. }
  323. conn, err := p.pollNewLeaderConn(ctx)
  324. if err != nil {
  325. if err == raftselector.ErrIsLeader {
  326. return p.local.Check(ctx, r)
  327. }
  328. return nil, err
  329. }
  330. return NewHealthClient(conn).Check(modCtx, r)
  331. }
  332. return resp, err
  333. }
  334. func (m *HealthCheckRequest) Size() (n int) {
  335. var l int
  336. _ = l
  337. l = len(m.Service)
  338. if l > 0 {
  339. n += 1 + l + sovHealth(uint64(l))
  340. }
  341. return n
  342. }
  343. func (m *HealthCheckResponse) Size() (n int) {
  344. var l int
  345. _ = l
  346. if m.Status != 0 {
  347. n += 1 + sovHealth(uint64(m.Status))
  348. }
  349. return n
  350. }
  351. func sovHealth(x uint64) (n int) {
  352. for {
  353. n++
  354. x >>= 7
  355. if x == 0 {
  356. break
  357. }
  358. }
  359. return n
  360. }
  361. func sozHealth(x uint64) (n int) {
  362. return sovHealth(uint64((x << 1) ^ uint64((int64(x) >> 63))))
  363. }
  364. func (this *HealthCheckRequest) String() string {
  365. if this == nil {
  366. return "nil"
  367. }
  368. s := strings.Join([]string{`&HealthCheckRequest{`,
  369. `Service:` + fmt.Sprintf("%v", this.Service) + `,`,
  370. `}`,
  371. }, "")
  372. return s
  373. }
  374. func (this *HealthCheckResponse) String() string {
  375. if this == nil {
  376. return "nil"
  377. }
  378. s := strings.Join([]string{`&HealthCheckResponse{`,
  379. `Status:` + fmt.Sprintf("%v", this.Status) + `,`,
  380. `}`,
  381. }, "")
  382. return s
  383. }
  384. func valueToStringHealth(v interface{}) string {
  385. rv := reflect.ValueOf(v)
  386. if rv.IsNil() {
  387. return "nil"
  388. }
  389. pv := reflect.Indirect(rv).Interface()
  390. return fmt.Sprintf("*%v", pv)
  391. }
  392. func (m *HealthCheckRequest) Unmarshal(dAtA []byte) error {
  393. l := len(dAtA)
  394. iNdEx := 0
  395. for iNdEx < l {
  396. preIndex := iNdEx
  397. var wire uint64
  398. for shift := uint(0); ; shift += 7 {
  399. if shift >= 64 {
  400. return ErrIntOverflowHealth
  401. }
  402. if iNdEx >= l {
  403. return io.ErrUnexpectedEOF
  404. }
  405. b := dAtA[iNdEx]
  406. iNdEx++
  407. wire |= (uint64(b) & 0x7F) << shift
  408. if b < 0x80 {
  409. break
  410. }
  411. }
  412. fieldNum := int32(wire >> 3)
  413. wireType := int(wire & 0x7)
  414. if wireType == 4 {
  415. return fmt.Errorf("proto: HealthCheckRequest: wiretype end group for non-group")
  416. }
  417. if fieldNum <= 0 {
  418. return fmt.Errorf("proto: HealthCheckRequest: illegal tag %d (wire type %d)", fieldNum, wire)
  419. }
  420. switch fieldNum {
  421. case 1:
  422. if wireType != 2 {
  423. return fmt.Errorf("proto: wrong wireType = %d for field Service", wireType)
  424. }
  425. var stringLen uint64
  426. for shift := uint(0); ; shift += 7 {
  427. if shift >= 64 {
  428. return ErrIntOverflowHealth
  429. }
  430. if iNdEx >= l {
  431. return io.ErrUnexpectedEOF
  432. }
  433. b := dAtA[iNdEx]
  434. iNdEx++
  435. stringLen |= (uint64(b) & 0x7F) << shift
  436. if b < 0x80 {
  437. break
  438. }
  439. }
  440. intStringLen := int(stringLen)
  441. if intStringLen < 0 {
  442. return ErrInvalidLengthHealth
  443. }
  444. postIndex := iNdEx + intStringLen
  445. if postIndex > l {
  446. return io.ErrUnexpectedEOF
  447. }
  448. m.Service = string(dAtA[iNdEx:postIndex])
  449. iNdEx = postIndex
  450. default:
  451. iNdEx = preIndex
  452. skippy, err := skipHealth(dAtA[iNdEx:])
  453. if err != nil {
  454. return err
  455. }
  456. if skippy < 0 {
  457. return ErrInvalidLengthHealth
  458. }
  459. if (iNdEx + skippy) > l {
  460. return io.ErrUnexpectedEOF
  461. }
  462. iNdEx += skippy
  463. }
  464. }
  465. if iNdEx > l {
  466. return io.ErrUnexpectedEOF
  467. }
  468. return nil
  469. }
  470. func (m *HealthCheckResponse) Unmarshal(dAtA []byte) error {
  471. l := len(dAtA)
  472. iNdEx := 0
  473. for iNdEx < l {
  474. preIndex := iNdEx
  475. var wire uint64
  476. for shift := uint(0); ; shift += 7 {
  477. if shift >= 64 {
  478. return ErrIntOverflowHealth
  479. }
  480. if iNdEx >= l {
  481. return io.ErrUnexpectedEOF
  482. }
  483. b := dAtA[iNdEx]
  484. iNdEx++
  485. wire |= (uint64(b) & 0x7F) << shift
  486. if b < 0x80 {
  487. break
  488. }
  489. }
  490. fieldNum := int32(wire >> 3)
  491. wireType := int(wire & 0x7)
  492. if wireType == 4 {
  493. return fmt.Errorf("proto: HealthCheckResponse: wiretype end group for non-group")
  494. }
  495. if fieldNum <= 0 {
  496. return fmt.Errorf("proto: HealthCheckResponse: illegal tag %d (wire type %d)", fieldNum, wire)
  497. }
  498. switch fieldNum {
  499. case 1:
  500. if wireType != 0 {
  501. return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType)
  502. }
  503. m.Status = 0
  504. for shift := uint(0); ; shift += 7 {
  505. if shift >= 64 {
  506. return ErrIntOverflowHealth
  507. }
  508. if iNdEx >= l {
  509. return io.ErrUnexpectedEOF
  510. }
  511. b := dAtA[iNdEx]
  512. iNdEx++
  513. m.Status |= (HealthCheckResponse_ServingStatus(b) & 0x7F) << shift
  514. if b < 0x80 {
  515. break
  516. }
  517. }
  518. default:
  519. iNdEx = preIndex
  520. skippy, err := skipHealth(dAtA[iNdEx:])
  521. if err != nil {
  522. return err
  523. }
  524. if skippy < 0 {
  525. return ErrInvalidLengthHealth
  526. }
  527. if (iNdEx + skippy) > l {
  528. return io.ErrUnexpectedEOF
  529. }
  530. iNdEx += skippy
  531. }
  532. }
  533. if iNdEx > l {
  534. return io.ErrUnexpectedEOF
  535. }
  536. return nil
  537. }
  538. func skipHealth(dAtA []byte) (n int, err error) {
  539. l := len(dAtA)
  540. iNdEx := 0
  541. for iNdEx < l {
  542. var wire uint64
  543. for shift := uint(0); ; shift += 7 {
  544. if shift >= 64 {
  545. return 0, ErrIntOverflowHealth
  546. }
  547. if iNdEx >= l {
  548. return 0, io.ErrUnexpectedEOF
  549. }
  550. b := dAtA[iNdEx]
  551. iNdEx++
  552. wire |= (uint64(b) & 0x7F) << shift
  553. if b < 0x80 {
  554. break
  555. }
  556. }
  557. wireType := int(wire & 0x7)
  558. switch wireType {
  559. case 0:
  560. for shift := uint(0); ; shift += 7 {
  561. if shift >= 64 {
  562. return 0, ErrIntOverflowHealth
  563. }
  564. if iNdEx >= l {
  565. return 0, io.ErrUnexpectedEOF
  566. }
  567. iNdEx++
  568. if dAtA[iNdEx-1] < 0x80 {
  569. break
  570. }
  571. }
  572. return iNdEx, nil
  573. case 1:
  574. iNdEx += 8
  575. return iNdEx, nil
  576. case 2:
  577. var length int
  578. for shift := uint(0); ; shift += 7 {
  579. if shift >= 64 {
  580. return 0, ErrIntOverflowHealth
  581. }
  582. if iNdEx >= l {
  583. return 0, io.ErrUnexpectedEOF
  584. }
  585. b := dAtA[iNdEx]
  586. iNdEx++
  587. length |= (int(b) & 0x7F) << shift
  588. if b < 0x80 {
  589. break
  590. }
  591. }
  592. iNdEx += length
  593. if length < 0 {
  594. return 0, ErrInvalidLengthHealth
  595. }
  596. return iNdEx, nil
  597. case 3:
  598. for {
  599. var innerWire uint64
  600. var start int = iNdEx
  601. for shift := uint(0); ; shift += 7 {
  602. if shift >= 64 {
  603. return 0, ErrIntOverflowHealth
  604. }
  605. if iNdEx >= l {
  606. return 0, io.ErrUnexpectedEOF
  607. }
  608. b := dAtA[iNdEx]
  609. iNdEx++
  610. innerWire |= (uint64(b) & 0x7F) << shift
  611. if b < 0x80 {
  612. break
  613. }
  614. }
  615. innerWireType := int(innerWire & 0x7)
  616. if innerWireType == 4 {
  617. break
  618. }
  619. next, err := skipHealth(dAtA[start:])
  620. if err != nil {
  621. return 0, err
  622. }
  623. iNdEx = start + next
  624. }
  625. return iNdEx, nil
  626. case 4:
  627. return iNdEx, nil
  628. case 5:
  629. iNdEx += 4
  630. return iNdEx, nil
  631. default:
  632. return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
  633. }
  634. }
  635. panic("unreachable")
  636. }
  637. var (
  638. ErrInvalidLengthHealth = fmt.Errorf("proto: negative length found during unmarshaling")
  639. ErrIntOverflowHealth = fmt.Errorf("proto: integer overflow")
  640. )
  641. func init() { proto.RegisterFile("github.com/docker/swarmkit/api/health.proto", fileDescriptorHealth) }
  642. var fileDescriptorHealth = []byte{
  643. // 315 bytes of a gzipped FileDescriptorProto
  644. 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0xd2, 0x4e, 0xcf, 0x2c, 0xc9,
  645. 0x28, 0x4d, 0xd2, 0x4b, 0xce, 0xcf, 0xd5, 0x4f, 0xc9, 0x4f, 0xce, 0x4e, 0x2d, 0xd2, 0x2f, 0x2e,
  646. 0x4f, 0x2c, 0xca, 0xcd, 0xce, 0x2c, 0xd1, 0x4f, 0x2c, 0xc8, 0xd4, 0xcf, 0x48, 0x4d, 0xcc, 0x29,
  647. 0xc9, 0xd0, 0x2b, 0x28, 0xca, 0x2f, 0xc9, 0x17, 0x12, 0x82, 0xa8, 0xd0, 0x83, 0xa9, 0xd0, 0x2b,
  648. 0x33, 0x94, 0x12, 0x49, 0xcf, 0x4f, 0xcf, 0x07, 0x4b, 0xeb, 0x83, 0x58, 0x10, 0x95, 0x52, 0xe6,
  649. 0x78, 0x8c, 0x05, 0xab, 0x48, 0x2a, 0x4d, 0xd3, 0x2f, 0xc8, 0x29, 0x4d, 0xcf, 0xcc, 0x83, 0x52,
  650. 0x10, 0x8d, 0x4a, 0x7a, 0x5c, 0x42, 0x1e, 0x60, 0x2b, 0x9d, 0x33, 0x52, 0x93, 0xb3, 0x83, 0x52,
  651. 0x0b, 0x4b, 0x53, 0x8b, 0x4b, 0x84, 0x24, 0xb8, 0xd8, 0x8b, 0x53, 0x8b, 0xca, 0x32, 0x93, 0x53,
  652. 0x25, 0x18, 0x15, 0x18, 0x35, 0x38, 0x83, 0x60, 0x5c, 0xa5, 0x05, 0x8c, 0x5c, 0xc2, 0x28, 0x1a,
  653. 0x8a, 0x0b, 0xf2, 0xf3, 0x8a, 0x53, 0x85, 0x7c, 0xb9, 0xd8, 0x8a, 0x4b, 0x12, 0x4b, 0x4a, 0x8b,
  654. 0xc1, 0x1a, 0xf8, 0x8c, 0x4c, 0xf5, 0x30, 0xdd, 0xae, 0x87, 0x45, 0xa3, 0x5e, 0x30, 0xc8, 0xe0,
  655. 0xbc, 0xf4, 0x60, 0xb0, 0xe6, 0x20, 0xa8, 0x21, 0x4a, 0x56, 0x5c, 0xbc, 0x28, 0x12, 0x42, 0xdc,
  656. 0x5c, 0xec, 0xa1, 0x7e, 0xde, 0x7e, 0xfe, 0xe1, 0x7e, 0x02, 0x0c, 0x20, 0x4e, 0xb0, 0x6b, 0x50,
  657. 0x98, 0xa7, 0x9f, 0xbb, 0x00, 0xa3, 0x10, 0x3f, 0x17, 0xb7, 0x9f, 0x7f, 0x48, 0x3c, 0x4c, 0x80,
  658. 0xc9, 0xa8, 0x92, 0x8b, 0x0d, 0x62, 0x91, 0x50, 0x3e, 0x17, 0x2b, 0xd8, 0x32, 0x21, 0x35, 0x82,
  659. 0xae, 0x01, 0xfb, 0x5b, 0x4a, 0x9d, 0x48, 0x57, 0x2b, 0x89, 0x9e, 0x5a, 0xf7, 0x6e, 0x06, 0x13,
  660. 0x3f, 0x17, 0x2f, 0x58, 0xa1, 0x6e, 0x6e, 0x62, 0x5e, 0x62, 0x7a, 0x6a, 0x91, 0x93, 0xc4, 0x89,
  661. 0x87, 0x72, 0x0c, 0x37, 0x1e, 0xca, 0x31, 0x34, 0x3c, 0x92, 0x63, 0x3c, 0xf1, 0x48, 0x8e, 0xf1,
  662. 0xc2, 0x23, 0x39, 0xc6, 0x07, 0x8f, 0xe4, 0x18, 0x93, 0xd8, 0xc0, 0xc1, 0x6d, 0x0c, 0x08, 0x00,
  663. 0x00, 0xff, 0xff, 0x7b, 0xf2, 0xdd, 0x23, 0x00, 0x02, 0x00, 0x00,
  664. }