2
0

StickyNoteViewController.swift 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. /*
  2. *
  3. * Copyright 2016, Google Inc.
  4. * All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions are
  8. * met:
  9. *
  10. * * Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * * Redistributions in binary form must reproduce the above
  13. * copyright notice, this list of conditions and the following disclaimer
  14. * in the documentation and/or other materials provided with the
  15. * distribution.
  16. * * Neither the name of Google Inc. nor the names of its
  17. * contributors may be used to endorse or promote products derived from
  18. * this software without specific prior written permission.
  19. *
  20. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  21. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  22. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  23. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  24. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  25. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  26. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  27. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  28. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  29. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  30. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  31. *
  32. */
  33. import AppKit
  34. import gRPC
  35. import QuickProto
  36. class StickyNoteViewController : NSViewController, NSTextFieldDelegate {
  37. @IBOutlet weak var messageField: NSTextField!
  38. @IBOutlet weak var imageView: NSImageView!
  39. var client: Client!
  40. var enabled = false
  41. @IBAction func messageReturnPressed(sender: NSTextField) {
  42. if enabled {
  43. callServer(address:"localhost:8085")
  44. }
  45. }
  46. override func viewDidLoad() {
  47. gRPC.initialize()
  48. }
  49. override func viewDidAppear() {
  50. DispatchQueue.main.asyncAfter(deadline: .now() + 1.0) {
  51. self.enabled = true
  52. }
  53. }
  54. func log(_ message: String) {
  55. print(message)
  56. }
  57. func callServer(address:String) {
  58. let fileDescriptorSet = FileDescriptorSet(filename:"stickynote.out")
  59. let text = self.messageField.stringValue
  60. // build the message
  61. if let requestMessage = fileDescriptorSet.createMessage("StickyNoteRequest") {
  62. requestMessage.addField("message", value:text)
  63. let requestHost = "foo.test.google.fr"
  64. let requestMethod = "/messagepb.StickyNote/Get"
  65. let requestMetadata = Metadata([["x":"xylophone"],
  66. ["y":"yu"],
  67. ["z":"zither"]])
  68. client = Client(address:address)
  69. let call = client.createCall(host: requestHost, method: requestMethod, timeout: 600)
  70. call.performNonStreamingCall(messageData: requestMessage.serialize(),
  71. metadata: requestMetadata,
  72. completion:
  73. { (response) in
  74. if let initialMetadata = response.initialMetadata {
  75. for j in 0..<initialMetadata.count() {
  76. self.log("Received initial metadata -> "
  77. + initialMetadata.key(index:j) + " : "
  78. + initialMetadata.value(index:j))
  79. }
  80. }
  81. self.log("Received status: \(response.status) " + response.statusDetails)
  82. if let responseData = response.messageData,
  83. let responseMessage = fileDescriptorSet.readMessage("StickyNoteResponse",
  84. data: responseData) {
  85. responseMessage.forOneField("image") {(field) in
  86. if let image = NSImage(data: field.data() as Data) {
  87. DispatchQueue.main.async {
  88. self.imageView.image = image
  89. }
  90. }
  91. }
  92. }
  93. if let trailingMetadata = response.trailingMetadata {
  94. for j in 0..<trailingMetadata.count() {
  95. self.log("Received trailing metadata -> "
  96. + trailingMetadata.key(index:j) + " : "
  97. + trailingMetadata.value(index:j))
  98. }
  99. }
  100. }
  101. )
  102. }
  103. }
  104. }