You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1028 lines
34 KiB

6 years ago
6 years ago
6 years ago
6 years ago
  1. // Code generated by protoc-gen-go.
  2. // source: master.proto
  3. // DO NOT EDIT!
  4. /*
  5. Package master_pb is a generated protocol buffer package.
  6. It is generated from these files:
  7. master.proto
  8. It has these top-level messages:
  9. Heartbeat
  10. HeartbeatResponse
  11. VolumeInformationMessage
  12. Empty
  13. SuperBlockExtra
  14. ClientListenRequest
  15. VolumeLocation
  16. LookupVolumeRequest
  17. LookupVolumeResponse
  18. Location
  19. AssignRequest
  20. AssignResponse
  21. StatisticsRequest
  22. StatisticsResponse
  23. */
  24. package master_pb
  25. import proto "github.com/golang/protobuf/proto"
  26. import fmt "fmt"
  27. import math "math"
  28. import (
  29. context "golang.org/x/net/context"
  30. grpc "google.golang.org/grpc"
  31. )
  32. // Reference imports to suppress errors if they are not otherwise used.
  33. var _ = proto.Marshal
  34. var _ = fmt.Errorf
  35. var _ = math.Inf
  36. // This is a compile-time assertion to ensure that this generated file
  37. // is compatible with the proto package it is being compiled against.
  38. // A compilation error at this line likely means your copy of the
  39. // proto package needs to be updated.
  40. const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package
  41. type Heartbeat struct {
  42. Ip string `protobuf:"bytes,1,opt,name=ip" json:"ip,omitempty"`
  43. Port uint32 `protobuf:"varint,2,opt,name=port" json:"port,omitempty"`
  44. PublicUrl string `protobuf:"bytes,3,opt,name=public_url,json=publicUrl" json:"public_url,omitempty"`
  45. MaxVolumeCount uint32 `protobuf:"varint,4,opt,name=max_volume_count,json=maxVolumeCount" json:"max_volume_count,omitempty"`
  46. MaxFileKey uint64 `protobuf:"varint,5,opt,name=max_file_key,json=maxFileKey" json:"max_file_key,omitempty"`
  47. DataCenter string `protobuf:"bytes,6,opt,name=data_center,json=dataCenter" json:"data_center,omitempty"`
  48. Rack string `protobuf:"bytes,7,opt,name=rack" json:"rack,omitempty"`
  49. AdminPort uint32 `protobuf:"varint,8,opt,name=admin_port,json=adminPort" json:"admin_port,omitempty"`
  50. Volumes []*VolumeInformationMessage `protobuf:"bytes,9,rep,name=volumes" json:"volumes,omitempty"`
  51. // delta volume ids
  52. NewVids []uint32 `protobuf:"varint,10,rep,packed,name=new_vids,json=newVids" json:"new_vids,omitempty"`
  53. DeletedVids []uint32 `protobuf:"varint,11,rep,packed,name=deleted_vids,json=deletedVids" json:"deleted_vids,omitempty"`
  54. }
  55. func (m *Heartbeat) Reset() { *m = Heartbeat{} }
  56. func (m *Heartbeat) String() string { return proto.CompactTextString(m) }
  57. func (*Heartbeat) ProtoMessage() {}
  58. func (*Heartbeat) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{0} }
  59. func (m *Heartbeat) GetIp() string {
  60. if m != nil {
  61. return m.Ip
  62. }
  63. return ""
  64. }
  65. func (m *Heartbeat) GetPort() uint32 {
  66. if m != nil {
  67. return m.Port
  68. }
  69. return 0
  70. }
  71. func (m *Heartbeat) GetPublicUrl() string {
  72. if m != nil {
  73. return m.PublicUrl
  74. }
  75. return ""
  76. }
  77. func (m *Heartbeat) GetMaxVolumeCount() uint32 {
  78. if m != nil {
  79. return m.MaxVolumeCount
  80. }
  81. return 0
  82. }
  83. func (m *Heartbeat) GetMaxFileKey() uint64 {
  84. if m != nil {
  85. return m.MaxFileKey
  86. }
  87. return 0
  88. }
  89. func (m *Heartbeat) GetDataCenter() string {
  90. if m != nil {
  91. return m.DataCenter
  92. }
  93. return ""
  94. }
  95. func (m *Heartbeat) GetRack() string {
  96. if m != nil {
  97. return m.Rack
  98. }
  99. return ""
  100. }
  101. func (m *Heartbeat) GetAdminPort() uint32 {
  102. if m != nil {
  103. return m.AdminPort
  104. }
  105. return 0
  106. }
  107. func (m *Heartbeat) GetVolumes() []*VolumeInformationMessage {
  108. if m != nil {
  109. return m.Volumes
  110. }
  111. return nil
  112. }
  113. func (m *Heartbeat) GetNewVids() []uint32 {
  114. if m != nil {
  115. return m.NewVids
  116. }
  117. return nil
  118. }
  119. func (m *Heartbeat) GetDeletedVids() []uint32 {
  120. if m != nil {
  121. return m.DeletedVids
  122. }
  123. return nil
  124. }
  125. type HeartbeatResponse struct {
  126. VolumeSizeLimit uint64 `protobuf:"varint,1,opt,name=volumeSizeLimit" json:"volumeSizeLimit,omitempty"`
  127. Leader string `protobuf:"bytes,3,opt,name=leader" json:"leader,omitempty"`
  128. }
  129. func (m *HeartbeatResponse) Reset() { *m = HeartbeatResponse{} }
  130. func (m *HeartbeatResponse) String() string { return proto.CompactTextString(m) }
  131. func (*HeartbeatResponse) ProtoMessage() {}
  132. func (*HeartbeatResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{1} }
  133. func (m *HeartbeatResponse) GetVolumeSizeLimit() uint64 {
  134. if m != nil {
  135. return m.VolumeSizeLimit
  136. }
  137. return 0
  138. }
  139. func (m *HeartbeatResponse) GetLeader() string {
  140. if m != nil {
  141. return m.Leader
  142. }
  143. return ""
  144. }
  145. type VolumeInformationMessage struct {
  146. Id uint32 `protobuf:"varint,1,opt,name=id" json:"id,omitempty"`
  147. Size uint64 `protobuf:"varint,2,opt,name=size" json:"size,omitempty"`
  148. Collection string `protobuf:"bytes,3,opt,name=collection" json:"collection,omitempty"`
  149. FileCount uint64 `protobuf:"varint,4,opt,name=file_count,json=fileCount" json:"file_count,omitempty"`
  150. DeleteCount uint64 `protobuf:"varint,5,opt,name=delete_count,json=deleteCount" json:"delete_count,omitempty"`
  151. DeletedByteCount uint64 `protobuf:"varint,6,opt,name=deleted_byte_count,json=deletedByteCount" json:"deleted_byte_count,omitempty"`
  152. ReadOnly bool `protobuf:"varint,7,opt,name=read_only,json=readOnly" json:"read_only,omitempty"`
  153. ReplicaPlacement uint32 `protobuf:"varint,8,opt,name=replica_placement,json=replicaPlacement" json:"replica_placement,omitempty"`
  154. Version uint32 `protobuf:"varint,9,opt,name=version" json:"version,omitempty"`
  155. Ttl uint32 `protobuf:"varint,10,opt,name=ttl" json:"ttl,omitempty"`
  156. }
  157. func (m *VolumeInformationMessage) Reset() { *m = VolumeInformationMessage{} }
  158. func (m *VolumeInformationMessage) String() string { return proto.CompactTextString(m) }
  159. func (*VolumeInformationMessage) ProtoMessage() {}
  160. func (*VolumeInformationMessage) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{2} }
  161. func (m *VolumeInformationMessage) GetId() uint32 {
  162. if m != nil {
  163. return m.Id
  164. }
  165. return 0
  166. }
  167. func (m *VolumeInformationMessage) GetSize() uint64 {
  168. if m != nil {
  169. return m.Size
  170. }
  171. return 0
  172. }
  173. func (m *VolumeInformationMessage) GetCollection() string {
  174. if m != nil {
  175. return m.Collection
  176. }
  177. return ""
  178. }
  179. func (m *VolumeInformationMessage) GetFileCount() uint64 {
  180. if m != nil {
  181. return m.FileCount
  182. }
  183. return 0
  184. }
  185. func (m *VolumeInformationMessage) GetDeleteCount() uint64 {
  186. if m != nil {
  187. return m.DeleteCount
  188. }
  189. return 0
  190. }
  191. func (m *VolumeInformationMessage) GetDeletedByteCount() uint64 {
  192. if m != nil {
  193. return m.DeletedByteCount
  194. }
  195. return 0
  196. }
  197. func (m *VolumeInformationMessage) GetReadOnly() bool {
  198. if m != nil {
  199. return m.ReadOnly
  200. }
  201. return false
  202. }
  203. func (m *VolumeInformationMessage) GetReplicaPlacement() uint32 {
  204. if m != nil {
  205. return m.ReplicaPlacement
  206. }
  207. return 0
  208. }
  209. func (m *VolumeInformationMessage) GetVersion() uint32 {
  210. if m != nil {
  211. return m.Version
  212. }
  213. return 0
  214. }
  215. func (m *VolumeInformationMessage) GetTtl() uint32 {
  216. if m != nil {
  217. return m.Ttl
  218. }
  219. return 0
  220. }
  221. type Empty struct {
  222. }
  223. func (m *Empty) Reset() { *m = Empty{} }
  224. func (m *Empty) String() string { return proto.CompactTextString(m) }
  225. func (*Empty) ProtoMessage() {}
  226. func (*Empty) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{3} }
  227. type SuperBlockExtra struct {
  228. ErasureCoding *SuperBlockExtra_ErasureCoding `protobuf:"bytes,1,opt,name=erasure_coding,json=erasureCoding" json:"erasure_coding,omitempty"`
  229. }
  230. func (m *SuperBlockExtra) Reset() { *m = SuperBlockExtra{} }
  231. func (m *SuperBlockExtra) String() string { return proto.CompactTextString(m) }
  232. func (*SuperBlockExtra) ProtoMessage() {}
  233. func (*SuperBlockExtra) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{4} }
  234. func (m *SuperBlockExtra) GetErasureCoding() *SuperBlockExtra_ErasureCoding {
  235. if m != nil {
  236. return m.ErasureCoding
  237. }
  238. return nil
  239. }
  240. type SuperBlockExtra_ErasureCoding struct {
  241. Data uint32 `protobuf:"varint,1,opt,name=data" json:"data,omitempty"`
  242. Parity uint32 `protobuf:"varint,2,opt,name=parity" json:"parity,omitempty"`
  243. VolumeIds []uint32 `protobuf:"varint,3,rep,packed,name=volume_ids,json=volumeIds" json:"volume_ids,omitempty"`
  244. }
  245. func (m *SuperBlockExtra_ErasureCoding) Reset() { *m = SuperBlockExtra_ErasureCoding{} }
  246. func (m *SuperBlockExtra_ErasureCoding) String() string { return proto.CompactTextString(m) }
  247. func (*SuperBlockExtra_ErasureCoding) ProtoMessage() {}
  248. func (*SuperBlockExtra_ErasureCoding) Descriptor() ([]byte, []int) {
  249. return fileDescriptor0, []int{4, 0}
  250. }
  251. func (m *SuperBlockExtra_ErasureCoding) GetData() uint32 {
  252. if m != nil {
  253. return m.Data
  254. }
  255. return 0
  256. }
  257. func (m *SuperBlockExtra_ErasureCoding) GetParity() uint32 {
  258. if m != nil {
  259. return m.Parity
  260. }
  261. return 0
  262. }
  263. func (m *SuperBlockExtra_ErasureCoding) GetVolumeIds() []uint32 {
  264. if m != nil {
  265. return m.VolumeIds
  266. }
  267. return nil
  268. }
  269. type ClientListenRequest struct {
  270. Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"`
  271. }
  272. func (m *ClientListenRequest) Reset() { *m = ClientListenRequest{} }
  273. func (m *ClientListenRequest) String() string { return proto.CompactTextString(m) }
  274. func (*ClientListenRequest) ProtoMessage() {}
  275. func (*ClientListenRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{5} }
  276. func (m *ClientListenRequest) GetName() string {
  277. if m != nil {
  278. return m.Name
  279. }
  280. return ""
  281. }
  282. type VolumeLocation struct {
  283. Url string `protobuf:"bytes,1,opt,name=url" json:"url,omitempty"`
  284. PublicUrl string `protobuf:"bytes,2,opt,name=public_url,json=publicUrl" json:"public_url,omitempty"`
  285. NewVids []uint32 `protobuf:"varint,3,rep,packed,name=new_vids,json=newVids" json:"new_vids,omitempty"`
  286. DeletedVids []uint32 `protobuf:"varint,4,rep,packed,name=deleted_vids,json=deletedVids" json:"deleted_vids,omitempty"`
  287. }
  288. func (m *VolumeLocation) Reset() { *m = VolumeLocation{} }
  289. func (m *VolumeLocation) String() string { return proto.CompactTextString(m) }
  290. func (*VolumeLocation) ProtoMessage() {}
  291. func (*VolumeLocation) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{6} }
  292. func (m *VolumeLocation) GetUrl() string {
  293. if m != nil {
  294. return m.Url
  295. }
  296. return ""
  297. }
  298. func (m *VolumeLocation) GetPublicUrl() string {
  299. if m != nil {
  300. return m.PublicUrl
  301. }
  302. return ""
  303. }
  304. func (m *VolumeLocation) GetNewVids() []uint32 {
  305. if m != nil {
  306. return m.NewVids
  307. }
  308. return nil
  309. }
  310. func (m *VolumeLocation) GetDeletedVids() []uint32 {
  311. if m != nil {
  312. return m.DeletedVids
  313. }
  314. return nil
  315. }
  316. type LookupVolumeRequest struct {
  317. VolumeIds []string `protobuf:"bytes,1,rep,name=volume_ids,json=volumeIds" json:"volume_ids,omitempty"`
  318. Collection string `protobuf:"bytes,2,opt,name=collection" json:"collection,omitempty"`
  319. }
  320. func (m *LookupVolumeRequest) Reset() { *m = LookupVolumeRequest{} }
  321. func (m *LookupVolumeRequest) String() string { return proto.CompactTextString(m) }
  322. func (*LookupVolumeRequest) ProtoMessage() {}
  323. func (*LookupVolumeRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{7} }
  324. func (m *LookupVolumeRequest) GetVolumeIds() []string {
  325. if m != nil {
  326. return m.VolumeIds
  327. }
  328. return nil
  329. }
  330. func (m *LookupVolumeRequest) GetCollection() string {
  331. if m != nil {
  332. return m.Collection
  333. }
  334. return ""
  335. }
  336. type LookupVolumeResponse struct {
  337. VolumeIdLocations []*LookupVolumeResponse_VolumeIdLocation `protobuf:"bytes,1,rep,name=volume_id_locations,json=volumeIdLocations" json:"volume_id_locations,omitempty"`
  338. }
  339. func (m *LookupVolumeResponse) Reset() { *m = LookupVolumeResponse{} }
  340. func (m *LookupVolumeResponse) String() string { return proto.CompactTextString(m) }
  341. func (*LookupVolumeResponse) ProtoMessage() {}
  342. func (*LookupVolumeResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{8} }
  343. func (m *LookupVolumeResponse) GetVolumeIdLocations() []*LookupVolumeResponse_VolumeIdLocation {
  344. if m != nil {
  345. return m.VolumeIdLocations
  346. }
  347. return nil
  348. }
  349. type LookupVolumeResponse_VolumeIdLocation struct {
  350. VolumeId string `protobuf:"bytes,1,opt,name=volume_id,json=volumeId" json:"volume_id,omitempty"`
  351. Locations []*Location `protobuf:"bytes,2,rep,name=locations" json:"locations,omitempty"`
  352. Error string `protobuf:"bytes,3,opt,name=error" json:"error,omitempty"`
  353. }
  354. func (m *LookupVolumeResponse_VolumeIdLocation) Reset() { *m = LookupVolumeResponse_VolumeIdLocation{} }
  355. func (m *LookupVolumeResponse_VolumeIdLocation) String() string { return proto.CompactTextString(m) }
  356. func (*LookupVolumeResponse_VolumeIdLocation) ProtoMessage() {}
  357. func (*LookupVolumeResponse_VolumeIdLocation) Descriptor() ([]byte, []int) {
  358. return fileDescriptor0, []int{8, 0}
  359. }
  360. func (m *LookupVolumeResponse_VolumeIdLocation) GetVolumeId() string {
  361. if m != nil {
  362. return m.VolumeId
  363. }
  364. return ""
  365. }
  366. func (m *LookupVolumeResponse_VolumeIdLocation) GetLocations() []*Location {
  367. if m != nil {
  368. return m.Locations
  369. }
  370. return nil
  371. }
  372. func (m *LookupVolumeResponse_VolumeIdLocation) GetError() string {
  373. if m != nil {
  374. return m.Error
  375. }
  376. return ""
  377. }
  378. type Location struct {
  379. Url string `protobuf:"bytes,1,opt,name=url" json:"url,omitempty"`
  380. PublicUrl string `protobuf:"bytes,2,opt,name=public_url,json=publicUrl" json:"public_url,omitempty"`
  381. }
  382. func (m *Location) Reset() { *m = Location{} }
  383. func (m *Location) String() string { return proto.CompactTextString(m) }
  384. func (*Location) ProtoMessage() {}
  385. func (*Location) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{9} }
  386. func (m *Location) GetUrl() string {
  387. if m != nil {
  388. return m.Url
  389. }
  390. return ""
  391. }
  392. func (m *Location) GetPublicUrl() string {
  393. if m != nil {
  394. return m.PublicUrl
  395. }
  396. return ""
  397. }
  398. type AssignRequest struct {
  399. Count uint64 `protobuf:"varint,1,opt,name=count" json:"count,omitempty"`
  400. Replication string `protobuf:"bytes,2,opt,name=replication" json:"replication,omitempty"`
  401. Collection string `protobuf:"bytes,3,opt,name=collection" json:"collection,omitempty"`
  402. Ttl string `protobuf:"bytes,4,opt,name=ttl" json:"ttl,omitempty"`
  403. DataCenter string `protobuf:"bytes,5,opt,name=data_center,json=dataCenter" json:"data_center,omitempty"`
  404. Rack string `protobuf:"bytes,6,opt,name=rack" json:"rack,omitempty"`
  405. DataNode string `protobuf:"bytes,7,opt,name=data_node,json=dataNode" json:"data_node,omitempty"`
  406. }
  407. func (m *AssignRequest) Reset() { *m = AssignRequest{} }
  408. func (m *AssignRequest) String() string { return proto.CompactTextString(m) }
  409. func (*AssignRequest) ProtoMessage() {}
  410. func (*AssignRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{10} }
  411. func (m *AssignRequest) GetCount() uint64 {
  412. if m != nil {
  413. return m.Count
  414. }
  415. return 0
  416. }
  417. func (m *AssignRequest) GetReplication() string {
  418. if m != nil {
  419. return m.Replication
  420. }
  421. return ""
  422. }
  423. func (m *AssignRequest) GetCollection() string {
  424. if m != nil {
  425. return m.Collection
  426. }
  427. return ""
  428. }
  429. func (m *AssignRequest) GetTtl() string {
  430. if m != nil {
  431. return m.Ttl
  432. }
  433. return ""
  434. }
  435. func (m *AssignRequest) GetDataCenter() string {
  436. if m != nil {
  437. return m.DataCenter
  438. }
  439. return ""
  440. }
  441. func (m *AssignRequest) GetRack() string {
  442. if m != nil {
  443. return m.Rack
  444. }
  445. return ""
  446. }
  447. func (m *AssignRequest) GetDataNode() string {
  448. if m != nil {
  449. return m.DataNode
  450. }
  451. return ""
  452. }
  453. type AssignResponse struct {
  454. Fid string `protobuf:"bytes,1,opt,name=fid" json:"fid,omitempty"`
  455. Url string `protobuf:"bytes,2,opt,name=url" json:"url,omitempty"`
  456. PublicUrl string `protobuf:"bytes,3,opt,name=public_url,json=publicUrl" json:"public_url,omitempty"`
  457. Count uint64 `protobuf:"varint,4,opt,name=count" json:"count,omitempty"`
  458. Error string `protobuf:"bytes,5,opt,name=error" json:"error,omitempty"`
  459. }
  460. func (m *AssignResponse) Reset() { *m = AssignResponse{} }
  461. func (m *AssignResponse) String() string { return proto.CompactTextString(m) }
  462. func (*AssignResponse) ProtoMessage() {}
  463. func (*AssignResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{11} }
  464. func (m *AssignResponse) GetFid() string {
  465. if m != nil {
  466. return m.Fid
  467. }
  468. return ""
  469. }
  470. func (m *AssignResponse) GetUrl() string {
  471. if m != nil {
  472. return m.Url
  473. }
  474. return ""
  475. }
  476. func (m *AssignResponse) GetPublicUrl() string {
  477. if m != nil {
  478. return m.PublicUrl
  479. }
  480. return ""
  481. }
  482. func (m *AssignResponse) GetCount() uint64 {
  483. if m != nil {
  484. return m.Count
  485. }
  486. return 0
  487. }
  488. func (m *AssignResponse) GetError() string {
  489. if m != nil {
  490. return m.Error
  491. }
  492. return ""
  493. }
  494. type StatisticsRequest struct {
  495. Replication string `protobuf:"bytes,1,opt,name=replication" json:"replication,omitempty"`
  496. Collection string `protobuf:"bytes,2,opt,name=collection" json:"collection,omitempty"`
  497. Ttl string `protobuf:"bytes,3,opt,name=ttl" json:"ttl,omitempty"`
  498. }
  499. func (m *StatisticsRequest) Reset() { *m = StatisticsRequest{} }
  500. func (m *StatisticsRequest) String() string { return proto.CompactTextString(m) }
  501. func (*StatisticsRequest) ProtoMessage() {}
  502. func (*StatisticsRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{12} }
  503. func (m *StatisticsRequest) GetReplication() string {
  504. if m != nil {
  505. return m.Replication
  506. }
  507. return ""
  508. }
  509. func (m *StatisticsRequest) GetCollection() string {
  510. if m != nil {
  511. return m.Collection
  512. }
  513. return ""
  514. }
  515. func (m *StatisticsRequest) GetTtl() string {
  516. if m != nil {
  517. return m.Ttl
  518. }
  519. return ""
  520. }
  521. type StatisticsResponse struct {
  522. Replication string `protobuf:"bytes,1,opt,name=replication" json:"replication,omitempty"`
  523. Collection string `protobuf:"bytes,2,opt,name=collection" json:"collection,omitempty"`
  524. Ttl string `protobuf:"bytes,3,opt,name=ttl" json:"ttl,omitempty"`
  525. TotalSize uint64 `protobuf:"varint,4,opt,name=total_size,json=totalSize" json:"total_size,omitempty"`
  526. UsedSize uint64 `protobuf:"varint,5,opt,name=used_size,json=usedSize" json:"used_size,omitempty"`
  527. FileCount uint64 `protobuf:"varint,6,opt,name=file_count,json=fileCount" json:"file_count,omitempty"`
  528. }
  529. func (m *StatisticsResponse) Reset() { *m = StatisticsResponse{} }
  530. func (m *StatisticsResponse) String() string { return proto.CompactTextString(m) }
  531. func (*StatisticsResponse) ProtoMessage() {}
  532. func (*StatisticsResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{13} }
  533. func (m *StatisticsResponse) GetReplication() string {
  534. if m != nil {
  535. return m.Replication
  536. }
  537. return ""
  538. }
  539. func (m *StatisticsResponse) GetCollection() string {
  540. if m != nil {
  541. return m.Collection
  542. }
  543. return ""
  544. }
  545. func (m *StatisticsResponse) GetTtl() string {
  546. if m != nil {
  547. return m.Ttl
  548. }
  549. return ""
  550. }
  551. func (m *StatisticsResponse) GetTotalSize() uint64 {
  552. if m != nil {
  553. return m.TotalSize
  554. }
  555. return 0
  556. }
  557. func (m *StatisticsResponse) GetUsedSize() uint64 {
  558. if m != nil {
  559. return m.UsedSize
  560. }
  561. return 0
  562. }
  563. func (m *StatisticsResponse) GetFileCount() uint64 {
  564. if m != nil {
  565. return m.FileCount
  566. }
  567. return 0
  568. }
  569. func init() {
  570. proto.RegisterType((*Heartbeat)(nil), "master_pb.Heartbeat")
  571. proto.RegisterType((*HeartbeatResponse)(nil), "master_pb.HeartbeatResponse")
  572. proto.RegisterType((*VolumeInformationMessage)(nil), "master_pb.VolumeInformationMessage")
  573. proto.RegisterType((*Empty)(nil), "master_pb.Empty")
  574. proto.RegisterType((*SuperBlockExtra)(nil), "master_pb.SuperBlockExtra")
  575. proto.RegisterType((*SuperBlockExtra_ErasureCoding)(nil), "master_pb.SuperBlockExtra.ErasureCoding")
  576. proto.RegisterType((*ClientListenRequest)(nil), "master_pb.ClientListenRequest")
  577. proto.RegisterType((*VolumeLocation)(nil), "master_pb.VolumeLocation")
  578. proto.RegisterType((*LookupVolumeRequest)(nil), "master_pb.LookupVolumeRequest")
  579. proto.RegisterType((*LookupVolumeResponse)(nil), "master_pb.LookupVolumeResponse")
  580. proto.RegisterType((*LookupVolumeResponse_VolumeIdLocation)(nil), "master_pb.LookupVolumeResponse.VolumeIdLocation")
  581. proto.RegisterType((*Location)(nil), "master_pb.Location")
  582. proto.RegisterType((*AssignRequest)(nil), "master_pb.AssignRequest")
  583. proto.RegisterType((*AssignResponse)(nil), "master_pb.AssignResponse")
  584. proto.RegisterType((*StatisticsRequest)(nil), "master_pb.StatisticsRequest")
  585. proto.RegisterType((*StatisticsResponse)(nil), "master_pb.StatisticsResponse")
  586. }
  587. // Reference imports to suppress errors if they are not otherwise used.
  588. var _ context.Context
  589. var _ grpc.ClientConn
  590. // This is a compile-time assertion to ensure that this generated file
  591. // is compatible with the grpc package it is being compiled against.
  592. const _ = grpc.SupportPackageIsVersion4
  593. // Client API for Seaweed service
  594. type SeaweedClient interface {
  595. SendHeartbeat(ctx context.Context, opts ...grpc.CallOption) (Seaweed_SendHeartbeatClient, error)
  596. KeepConnected(ctx context.Context, opts ...grpc.CallOption) (Seaweed_KeepConnectedClient, error)
  597. LookupVolume(ctx context.Context, in *LookupVolumeRequest, opts ...grpc.CallOption) (*LookupVolumeResponse, error)
  598. Assign(ctx context.Context, in *AssignRequest, opts ...grpc.CallOption) (*AssignResponse, error)
  599. Statistics(ctx context.Context, in *StatisticsRequest, opts ...grpc.CallOption) (*StatisticsResponse, error)
  600. }
  601. type seaweedClient struct {
  602. cc *grpc.ClientConn
  603. }
  604. func NewSeaweedClient(cc *grpc.ClientConn) SeaweedClient {
  605. return &seaweedClient{cc}
  606. }
  607. func (c *seaweedClient) SendHeartbeat(ctx context.Context, opts ...grpc.CallOption) (Seaweed_SendHeartbeatClient, error) {
  608. stream, err := grpc.NewClientStream(ctx, &_Seaweed_serviceDesc.Streams[0], c.cc, "/master_pb.Seaweed/SendHeartbeat", opts...)
  609. if err != nil {
  610. return nil, err
  611. }
  612. x := &seaweedSendHeartbeatClient{stream}
  613. return x, nil
  614. }
  615. type Seaweed_SendHeartbeatClient interface {
  616. Send(*Heartbeat) error
  617. Recv() (*HeartbeatResponse, error)
  618. grpc.ClientStream
  619. }
  620. type seaweedSendHeartbeatClient struct {
  621. grpc.ClientStream
  622. }
  623. func (x *seaweedSendHeartbeatClient) Send(m *Heartbeat) error {
  624. return x.ClientStream.SendMsg(m)
  625. }
  626. func (x *seaweedSendHeartbeatClient) Recv() (*HeartbeatResponse, error) {
  627. m := new(HeartbeatResponse)
  628. if err := x.ClientStream.RecvMsg(m); err != nil {
  629. return nil, err
  630. }
  631. return m, nil
  632. }
  633. func (c *seaweedClient) KeepConnected(ctx context.Context, opts ...grpc.CallOption) (Seaweed_KeepConnectedClient, error) {
  634. stream, err := grpc.NewClientStream(ctx, &_Seaweed_serviceDesc.Streams[1], c.cc, "/master_pb.Seaweed/KeepConnected", opts...)
  635. if err != nil {
  636. return nil, err
  637. }
  638. x := &seaweedKeepConnectedClient{stream}
  639. return x, nil
  640. }
  641. type Seaweed_KeepConnectedClient interface {
  642. Send(*ClientListenRequest) error
  643. Recv() (*VolumeLocation, error)
  644. grpc.ClientStream
  645. }
  646. type seaweedKeepConnectedClient struct {
  647. grpc.ClientStream
  648. }
  649. func (x *seaweedKeepConnectedClient) Send(m *ClientListenRequest) error {
  650. return x.ClientStream.SendMsg(m)
  651. }
  652. func (x *seaweedKeepConnectedClient) Recv() (*VolumeLocation, error) {
  653. m := new(VolumeLocation)
  654. if err := x.ClientStream.RecvMsg(m); err != nil {
  655. return nil, err
  656. }
  657. return m, nil
  658. }
  659. func (c *seaweedClient) LookupVolume(ctx context.Context, in *LookupVolumeRequest, opts ...grpc.CallOption) (*LookupVolumeResponse, error) {
  660. out := new(LookupVolumeResponse)
  661. err := grpc.Invoke(ctx, "/master_pb.Seaweed/LookupVolume", in, out, c.cc, opts...)
  662. if err != nil {
  663. return nil, err
  664. }
  665. return out, nil
  666. }
  667. func (c *seaweedClient) Assign(ctx context.Context, in *AssignRequest, opts ...grpc.CallOption) (*AssignResponse, error) {
  668. out := new(AssignResponse)
  669. err := grpc.Invoke(ctx, "/master_pb.Seaweed/Assign", in, out, c.cc, opts...)
  670. if err != nil {
  671. return nil, err
  672. }
  673. return out, nil
  674. }
  675. func (c *seaweedClient) Statistics(ctx context.Context, in *StatisticsRequest, opts ...grpc.CallOption) (*StatisticsResponse, error) {
  676. out := new(StatisticsResponse)
  677. err := grpc.Invoke(ctx, "/master_pb.Seaweed/Statistics", in, out, c.cc, opts...)
  678. if err != nil {
  679. return nil, err
  680. }
  681. return out, nil
  682. }
  683. // Server API for Seaweed service
  684. type SeaweedServer interface {
  685. SendHeartbeat(Seaweed_SendHeartbeatServer) error
  686. KeepConnected(Seaweed_KeepConnectedServer) error
  687. LookupVolume(context.Context, *LookupVolumeRequest) (*LookupVolumeResponse, error)
  688. Assign(context.Context, *AssignRequest) (*AssignResponse, error)
  689. Statistics(context.Context, *StatisticsRequest) (*StatisticsResponse, error)
  690. }
  691. func RegisterSeaweedServer(s *grpc.Server, srv SeaweedServer) {
  692. s.RegisterService(&_Seaweed_serviceDesc, srv)
  693. }
  694. func _Seaweed_SendHeartbeat_Handler(srv interface{}, stream grpc.ServerStream) error {
  695. return srv.(SeaweedServer).SendHeartbeat(&seaweedSendHeartbeatServer{stream})
  696. }
  697. type Seaweed_SendHeartbeatServer interface {
  698. Send(*HeartbeatResponse) error
  699. Recv() (*Heartbeat, error)
  700. grpc.ServerStream
  701. }
  702. type seaweedSendHeartbeatServer struct {
  703. grpc.ServerStream
  704. }
  705. func (x *seaweedSendHeartbeatServer) Send(m *HeartbeatResponse) error {
  706. return x.ServerStream.SendMsg(m)
  707. }
  708. func (x *seaweedSendHeartbeatServer) Recv() (*Heartbeat, error) {
  709. m := new(Heartbeat)
  710. if err := x.ServerStream.RecvMsg(m); err != nil {
  711. return nil, err
  712. }
  713. return m, nil
  714. }
  715. func _Seaweed_KeepConnected_Handler(srv interface{}, stream grpc.ServerStream) error {
  716. return srv.(SeaweedServer).KeepConnected(&seaweedKeepConnectedServer{stream})
  717. }
  718. type Seaweed_KeepConnectedServer interface {
  719. Send(*VolumeLocation) error
  720. Recv() (*ClientListenRequest, error)
  721. grpc.ServerStream
  722. }
  723. type seaweedKeepConnectedServer struct {
  724. grpc.ServerStream
  725. }
  726. func (x *seaweedKeepConnectedServer) Send(m *VolumeLocation) error {
  727. return x.ServerStream.SendMsg(m)
  728. }
  729. func (x *seaweedKeepConnectedServer) Recv() (*ClientListenRequest, error) {
  730. m := new(ClientListenRequest)
  731. if err := x.ServerStream.RecvMsg(m); err != nil {
  732. return nil, err
  733. }
  734. return m, nil
  735. }
  736. func _Seaweed_LookupVolume_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
  737. in := new(LookupVolumeRequest)
  738. if err := dec(in); err != nil {
  739. return nil, err
  740. }
  741. if interceptor == nil {
  742. return srv.(SeaweedServer).LookupVolume(ctx, in)
  743. }
  744. info := &grpc.UnaryServerInfo{
  745. Server: srv,
  746. FullMethod: "/master_pb.Seaweed/LookupVolume",
  747. }
  748. handler := func(ctx context.Context, req interface{}) (interface{}, error) {
  749. return srv.(SeaweedServer).LookupVolume(ctx, req.(*LookupVolumeRequest))
  750. }
  751. return interceptor(ctx, in, info, handler)
  752. }
  753. func _Seaweed_Assign_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
  754. in := new(AssignRequest)
  755. if err := dec(in); err != nil {
  756. return nil, err
  757. }
  758. if interceptor == nil {
  759. return srv.(SeaweedServer).Assign(ctx, in)
  760. }
  761. info := &grpc.UnaryServerInfo{
  762. Server: srv,
  763. FullMethod: "/master_pb.Seaweed/Assign",
  764. }
  765. handler := func(ctx context.Context, req interface{}) (interface{}, error) {
  766. return srv.(SeaweedServer).Assign(ctx, req.(*AssignRequest))
  767. }
  768. return interceptor(ctx, in, info, handler)
  769. }
  770. func _Seaweed_Statistics_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
  771. in := new(StatisticsRequest)
  772. if err := dec(in); err != nil {
  773. return nil, err
  774. }
  775. if interceptor == nil {
  776. return srv.(SeaweedServer).Statistics(ctx, in)
  777. }
  778. info := &grpc.UnaryServerInfo{
  779. Server: srv,
  780. FullMethod: "/master_pb.Seaweed/Statistics",
  781. }
  782. handler := func(ctx context.Context, req interface{}) (interface{}, error) {
  783. return srv.(SeaweedServer).Statistics(ctx, req.(*StatisticsRequest))
  784. }
  785. return interceptor(ctx, in, info, handler)
  786. }
  787. var _Seaweed_serviceDesc = grpc.ServiceDesc{
  788. ServiceName: "master_pb.Seaweed",
  789. HandlerType: (*SeaweedServer)(nil),
  790. Methods: []grpc.MethodDesc{
  791. {
  792. MethodName: "LookupVolume",
  793. Handler: _Seaweed_LookupVolume_Handler,
  794. },
  795. {
  796. MethodName: "Assign",
  797. Handler: _Seaweed_Assign_Handler,
  798. },
  799. {
  800. MethodName: "Statistics",
  801. Handler: _Seaweed_Statistics_Handler,
  802. },
  803. },
  804. Streams: []grpc.StreamDesc{
  805. {
  806. StreamName: "SendHeartbeat",
  807. Handler: _Seaweed_SendHeartbeat_Handler,
  808. ServerStreams: true,
  809. ClientStreams: true,
  810. },
  811. {
  812. StreamName: "KeepConnected",
  813. Handler: _Seaweed_KeepConnected_Handler,
  814. ServerStreams: true,
  815. ClientStreams: true,
  816. },
  817. },
  818. Metadata: "master.proto",
  819. }
  820. func init() { proto.RegisterFile("master.proto", fileDescriptor0) }
  821. var fileDescriptor0 = []byte{
  822. // 1043 bytes of a gzipped FileDescriptorProto
  823. 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xb4, 0x56, 0xcd, 0x6e, 0x24, 0x35,
  824. 0x10, 0xde, 0xee, 0xf9, 0xed, 0x9a, 0x4c, 0x76, 0xe2, 0x44, 0xa8, 0x77, 0x96, 0xdd, 0x1d, 0x9a,
  825. 0xcb, 0x20, 0x50, 0xb4, 0x84, 0x23, 0x42, 0x88, 0x8d, 0x82, 0x88, 0x12, 0xd8, 0xd0, 0x61, 0xf7,
  826. 0xc0, 0xa5, 0x71, 0xba, 0x2b, 0x91, 0x95, 0xfe, 0xc3, 0xf6, 0x24, 0x33, 0x7b, 0xe1, 0xc8, 0x5b,
  827. 0x71, 0x81, 0x1b, 0x8f, 0xc2, 0x8d, 0x27, 0x40, 0xfe, 0xe9, 0x4e, 0x4f, 0x27, 0x21, 0x12, 0x12,
  828. 0x37, 0xfb, 0x73, 0xd9, 0xae, 0xfa, 0xbe, 0xaa, 0xb2, 0x61, 0x23, 0xa3, 0x42, 0x22, 0xdf, 0x2d,
  829. 0x79, 0x21, 0x0b, 0xe2, 0x99, 0x59, 0x54, 0x9e, 0x05, 0x7f, 0xb9, 0xe0, 0x7d, 0x83, 0x94, 0xcb,
  830. 0x33, 0xa4, 0x92, 0x6c, 0x82, 0xcb, 0x4a, 0xdf, 0x99, 0x39, 0x73, 0x2f, 0x74, 0x59, 0x49, 0x08,
  831. 0x74, 0xcb, 0x82, 0x4b, 0xdf, 0x9d, 0x39, 0xf3, 0x71, 0xa8, 0xc7, 0xe4, 0x19, 0x40, 0xb9, 0x38,
  832. 0x4b, 0x59, 0x1c, 0x2d, 0x78, 0xea, 0x77, 0xb4, 0xad, 0x67, 0x90, 0x37, 0x3c, 0x25, 0x73, 0x98,
  833. 0x64, 0x74, 0x19, 0x5d, 0x15, 0xe9, 0x22, 0xc3, 0x28, 0x2e, 0x16, 0xb9, 0xf4, 0xbb, 0x7a, 0xfb,
  834. 0x66, 0x46, 0x97, 0x6f, 0x35, 0xbc, 0xaf, 0x50, 0x32, 0x53, 0x5e, 0x2d, 0xa3, 0x73, 0x96, 0x62,
  835. 0x74, 0x89, 0x2b, 0xbf, 0x37, 0x73, 0xe6, 0xdd, 0x10, 0x32, 0xba, 0xfc, 0x9a, 0xa5, 0x78, 0x84,
  836. 0x2b, 0xf2, 0x02, 0x46, 0x09, 0x95, 0x34, 0x8a, 0x31, 0x97, 0xc8, 0xfd, 0xbe, 0xbe, 0x0b, 0x14,
  837. 0xb4, 0xaf, 0x11, 0xe5, 0x1f, 0xa7, 0xf1, 0xa5, 0x3f, 0xd0, 0x2b, 0x7a, 0xac, 0xfc, 0xa3, 0x49,
  838. 0xc6, 0xf2, 0x48, 0x7b, 0x3e, 0xd4, 0x57, 0x7b, 0x1a, 0x39, 0x51, 0xee, 0x7f, 0x01, 0x03, 0xe3,
  839. 0x9b, 0xf0, 0xbd, 0x59, 0x67, 0x3e, 0xda, 0xfb, 0x70, 0xb7, 0x66, 0x63, 0xd7, 0xb8, 0x77, 0x98,
  840. 0x9f, 0x17, 0x3c, 0xa3, 0x92, 0x15, 0xf9, 0xb7, 0x28, 0x04, 0xbd, 0xc0, 0xb0, 0xda, 0x43, 0x9e,
  841. 0xc0, 0x30, 0xc7, 0xeb, 0xe8, 0x8a, 0x25, 0xc2, 0x87, 0x59, 0x67, 0x3e, 0x0e, 0x07, 0x39, 0x5e,
  842. 0xbf, 0x65, 0x89, 0x20, 0x1f, 0xc0, 0x46, 0x82, 0x29, 0x4a, 0x4c, 0xcc, 0xf2, 0x48, 0x2f, 0x8f,
  843. 0x2c, 0xa6, 0x4c, 0x82, 0x37, 0xb0, 0x55, 0x93, 0x1d, 0xa2, 0x28, 0x8b, 0x5c, 0x20, 0x99, 0xc3,
  844. 0x63, 0x73, 0xfa, 0x29, 0x7b, 0x87, 0xc7, 0x2c, 0x63, 0x52, 0x2b, 0xd0, 0x0d, 0xdb, 0x30, 0x79,
  845. 0x0f, 0xfa, 0x29, 0xd2, 0x04, 0xb9, 0xa5, 0xdd, 0xce, 0x82, 0x3f, 0x5c, 0xf0, 0xef, 0x73, 0x5d,
  846. 0x6b, 0x9a, 0xe8, 0x13, 0xc7, 0xa1, 0xcb, 0x12, 0xc5, 0x99, 0x60, 0xef, 0x50, 0x6b, 0xda, 0x0d,
  847. 0xf5, 0x98, 0x3c, 0x07, 0x88, 0x8b, 0x34, 0xc5, 0x58, 0x6d, 0xb4, 0x87, 0x37, 0x10, 0xc5, 0xa9,
  848. 0x96, 0xe9, 0x46, 0xce, 0x6e, 0xe8, 0x29, 0xc4, 0x28, 0x59, 0x47, 0x6e, 0x0d, 0x8c, 0x92, 0x36,
  849. 0x72, 0x63, 0xf2, 0x09, 0x90, 0x8a, 0x9c, 0xb3, 0x55, 0x6d, 0xd8, 0xd7, 0x86, 0x13, 0xbb, 0xf2,
  850. 0x6a, 0x55, 0x59, 0x3f, 0x05, 0x8f, 0x23, 0x4d, 0xa2, 0x22, 0x4f, 0x57, 0x5a, 0xdc, 0x61, 0x38,
  851. 0x54, 0xc0, 0xeb, 0x3c, 0x5d, 0x91, 0x8f, 0x61, 0x8b, 0x63, 0x99, 0xb2, 0x98, 0x46, 0x65, 0x4a,
  852. 0x63, 0xcc, 0x30, 0xaf, 0x74, 0x9e, 0xd8, 0x85, 0x93, 0x0a, 0x27, 0x3e, 0x0c, 0xae, 0x90, 0x0b,
  853. 0x15, 0x96, 0xa7, 0x4d, 0xaa, 0x29, 0x99, 0x40, 0x47, 0xca, 0xd4, 0x07, 0x8d, 0xaa, 0x61, 0x30,
  854. 0x80, 0xde, 0x41, 0x56, 0xca, 0x55, 0xf0, 0x9b, 0x03, 0x8f, 0x4f, 0x17, 0x25, 0xf2, 0x57, 0x69,
  855. 0x11, 0x5f, 0x1e, 0x2c, 0x25, 0xa7, 0xe4, 0x35, 0x6c, 0x22, 0xa7, 0x62, 0xc1, 0x95, 0xef, 0x09,
  856. 0xcb, 0x2f, 0x34, 0xa5, 0xa3, 0xbd, 0x79, 0x23, 0x7d, 0x5a, 0x7b, 0x76, 0x0f, 0xcc, 0x86, 0x7d,
  857. 0x6d, 0x1f, 0x8e, 0xb1, 0x39, 0x9d, 0xfe, 0x08, 0xe3, 0xb5, 0x75, 0x25, 0x8c, 0x4a, 0x6d, 0x2b,
  858. 0x95, 0x1e, 0x2b, 0xc5, 0x4b, 0xca, 0x99, 0x5c, 0xd9, 0x12, 0xb4, 0x33, 0x25, 0x88, 0xad, 0x30,
  859. 0x95, 0x69, 0x1d, 0x9d, 0x69, 0x9e, 0x41, 0x0e, 0x13, 0x11, 0x7c, 0x04, 0xdb, 0xfb, 0x29, 0xc3,
  860. 0x5c, 0x1e, 0x33, 0x21, 0x31, 0x0f, 0xf1, 0xe7, 0x05, 0x0a, 0xa9, 0x6e, 0xc8, 0x69, 0x86, 0xb6,
  861. 0xc0, 0xf5, 0x38, 0xf8, 0x05, 0x36, 0x4d, 0xea, 0x1c, 0x17, 0xb1, 0xce, 0x1b, 0x45, 0x8c, 0xaa,
  862. 0x6c, 0x63, 0xa4, 0x86, 0xad, 0x92, 0x77, 0xdb, 0x25, 0xdf, 0xac, 0x89, 0xce, 0xbf, 0xd7, 0x44,
  863. 0xf7, 0x76, 0x4d, 0xfc, 0x00, 0xdb, 0xc7, 0x45, 0x71, 0xb9, 0x28, 0x8d, 0x1b, 0x95, 0xaf, 0xeb,
  864. 0x11, 0x3a, 0xb3, 0x8e, 0xba, 0xb3, 0x8e, 0xb0, 0x95, 0xb1, 0x6e, 0x3b, 0x63, 0x83, 0xbf, 0x1d,
  865. 0xd8, 0x59, 0x3f, 0xd6, 0x56, 0xdb, 0x4f, 0xb0, 0x5d, 0x9f, 0x1b, 0xa5, 0x36, 0x66, 0x73, 0xc1,
  866. 0x68, 0xef, 0x65, 0x43, 0xcc, 0xbb, 0x76, 0x57, 0x0d, 0x22, 0xa9, 0xc8, 0x0a, 0xb7, 0xae, 0x5a,
  867. 0x88, 0x98, 0x2e, 0x61, 0xd2, 0x36, 0x53, 0x09, 0x5d, 0xdf, 0x6a, 0x99, 0x1d, 0x56, 0x3b, 0xc9,
  868. 0xa7, 0xe0, 0xdd, 0x38, 0xe2, 0x6a, 0x47, 0xb6, 0xd7, 0x1c, 0xb1, 0x77, 0xdd, 0x58, 0x91, 0x1d,
  869. 0xe8, 0x21, 0xe7, 0x45, 0xd5, 0x08, 0xcc, 0x24, 0xf8, 0x1c, 0x86, 0xff, 0x59, 0xc5, 0xe0, 0x4f,
  870. 0x07, 0xc6, 0x5f, 0x09, 0xc1, 0x2e, 0xea, 0x74, 0xd9, 0x81, 0x9e, 0x29, 0x53, 0xd3, 0x8e, 0xcc,
  871. 0x84, 0xcc, 0x60, 0x64, 0xab, 0xac, 0x41, 0x7d, 0x13, 0x7a, 0xb0, 0x9b, 0xd8, 0xca, 0xeb, 0x1a,
  872. 0xd7, 0xa4, 0x4c, 0xdb, 0x8d, 0xbe, 0x77, 0x6f, 0xa3, 0xef, 0x37, 0x1a, 0xfd, 0x53, 0xf0, 0xf4,
  873. 0xa6, 0xbc, 0x48, 0xd0, 0xbe, 0x00, 0x43, 0x05, 0x7c, 0x57, 0x24, 0x3a, 0xad, 0xab, 0x60, 0xac,
  874. 0xf0, 0x13, 0xe8, 0x9c, 0xd7, 0xe4, 0xab, 0x61, 0x45, 0x91, 0x7b, 0x1f, 0x45, 0xb7, 0xde, 0xb6,
  875. 0x9a, 0x90, 0x6e, 0x93, 0x90, 0x5a, 0x8b, 0x5e, 0x53, 0x8b, 0x0b, 0xd8, 0x3a, 0x95, 0x54, 0x32,
  876. 0x21, 0x59, 0x2c, 0x2a, 0x46, 0x5b, 0xdc, 0x39, 0x0f, 0x71, 0xe7, 0xde, 0xc7, 0x5d, 0xa7, 0xe6,
  877. 0x2e, 0xf8, 0xdd, 0x01, 0xd2, 0xbc, 0xc9, 0x86, 0xfb, 0x3f, 0x5c, 0xa5, 0xe8, 0x91, 0x85, 0xa4,
  878. 0x69, 0xa4, 0x1f, 0x10, 0xfb, 0x0c, 0x68, 0x44, 0xbd, 0x51, 0x4a, 0x90, 0x85, 0xc0, 0xc4, 0xac,
  879. 0x9a, 0x37, 0x60, 0xa8, 0x00, 0xbd, 0xb8, 0xfe, 0x84, 0xf4, 0x5b, 0x4f, 0xc8, 0xde, 0xaf, 0x1d,
  880. 0x18, 0x9c, 0x22, 0xbd, 0x46, 0x4c, 0xc8, 0x21, 0x8c, 0x4f, 0x31, 0x4f, 0x6e, 0xbe, 0x25, 0x3b,
  881. 0x8d, 0x6a, 0xa8, 0xd1, 0xe9, 0xfb, 0x77, 0xa1, 0x55, 0xfc, 0xc1, 0xa3, 0xb9, 0xf3, 0xd2, 0x21,
  882. 0x27, 0x30, 0x3e, 0x42, 0x2c, 0xf7, 0x8b, 0x3c, 0xc7, 0x58, 0x62, 0x42, 0x9e, 0x37, 0x36, 0xdd,
  883. 0xd1, 0x22, 0xa7, 0x4f, 0x6e, 0xfd, 0x06, 0xaa, 0x8a, 0xb2, 0x27, 0x7e, 0x0f, 0x1b, 0xcd, 0xce,
  884. 0xb0, 0x76, 0xe0, 0x1d, 0x7d, 0x6c, 0xfa, 0xe2, 0x81, 0x96, 0x12, 0x3c, 0x22, 0x5f, 0x42, 0xdf,
  885. 0xe4, 0x2a, 0xf1, 0x1b, 0xc6, 0x6b, 0xb5, 0xb8, 0xe6, 0xd7, 0x7a, 0x62, 0x07, 0x8f, 0xc8, 0x11,
  886. 0xc0, 0x4d, 0x06, 0x90, 0x26, 0x2f, 0xb7, 0x52, 0x70, 0xfa, 0xec, 0x9e, 0xd5, 0xea, 0xb0, 0xb3,
  887. 0xbe, 0xfe, 0x23, 0x7e, 0xf6, 0x4f, 0x00, 0x00, 0x00, 0xff, 0xff, 0x77, 0xb3, 0x32, 0xc7, 0x33,
  888. 0x0a, 0x00, 0x00,
  889. }