| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2011 Google Inc. All rights reserved. | 2 * |
| 3 * Copyright 2015, Google Inc. |
| 4 * All rights reserved. |
| 3 * | 5 * |
| 4 * Redistribution and use in source and binary forms, with or without | 6 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 7 * modification, are permitted provided that the following conditions are |
| 6 * met: | 8 * met: |
| 7 * | 9 * |
| 8 * * Redistributions of source code must retain the above copyright | 10 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 11 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 12 * * Redistributions in binary form must reproduce the above |
| 11 * copyright notice, this list of conditions and the following disclaimer | 13 * copyright notice, this list of conditions and the following disclaimer |
| 12 * in the documentation and/or other materials provided with the | 14 * in the documentation and/or other materials provided with the |
| 13 * distribution. | 15 * distribution. |
| 14 * * Neither the name of Google Inc. nor the names of its | 16 * * Neither the name of Google Inc. nor the names of its |
| 15 * contributors may be used to endorse or promote products derived from | 17 * contributors may be used to endorse or promote products derived from |
| 16 * this software without specific prior written permission. | 18 * this software without specific prior written permission. |
| 17 * | 19 * |
| 18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| 19 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 21 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| 20 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| 21 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | 23 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| 22 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 24 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| 23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 25 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| 24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 26 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 27 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 28 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 30 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 31 * |
| 29 */ | 32 */ |
| 30 | 33 |
| 31 #ifndef WebScopedUserGesture_h | 34 #include <iostream> |
| 32 #define WebScopedUserGesture_h | 35 #include <memory> |
| 36 #include <string> |
| 33 | 37 |
| 34 #include "../platform/WebPrivateOwnPtr.h" | 38 #include <grpc++/grpc++.h> |
| 35 | 39 |
| 36 namespace blink { | 40 #include "helloworld.grpc.pb.h" |
| 37 | 41 |
| 38 class UserGestureIndicator; | 42 using grpc::Server; |
| 39 class WebUserGestureToken; | 43 using grpc::ServerBuilder; |
| 44 using grpc::ServerContext; |
| 45 using grpc::Status; |
| 46 using helloworld::HelloRequest; |
| 47 using helloworld::HelloReply; |
| 48 using helloworld::Greeter; |
| 40 | 49 |
| 41 // An instance of this class, while kept alive, will indicate that we are in | 50 // Logic and data behind the server's behavior. |
| 42 // the context of a known user gesture. To use, create one, perform whatever | 51 class GreeterServiceImpl final : public Greeter::Service { |
| 43 // actions were done under color of a known user gesture, and then delete it. | 52 Status SayHello(ServerContext* context, const HelloRequest* request, |
| 44 // Usually this will be done on the stack. | 53 HelloReply* reply) override { |
| 45 // | 54 std::string prefix("Hello "); |
| 46 // SECURITY WARNING: Do not create several instances of this class for the same | 55 reply->set_message(prefix + request->name()); |
| 47 // user gesture. Doing so might enable malicious code to work around certain | 56 return Status::OK; |
| 48 // restrictions such as opening multiple windows. | 57 } |
| 49 // Instead, obtain the current WebUserGestureToken from the | |
| 50 // WebUserGestureIndicator, and use this token to create a | |
| 51 // WebScopedUserGesture. If the token was alrady consumed, the new | |
| 52 // WebScopedUserGesture will not indicate that we are in the context of a user | |
| 53 // gesture. | |
| 54 class WebScopedUserGesture { | |
| 55 public: | |
| 56 explicit WebScopedUserGesture(const WebUserGestureToken& token) { initialize
WithToken(token); } | |
| 57 WebScopedUserGesture() { initialize(); } | |
| 58 ~WebScopedUserGesture() { reset(); } | |
| 59 | |
| 60 private: | |
| 61 BLINK_EXPORT void initialize(); | |
| 62 BLINK_EXPORT void initializeWithToken(const WebUserGestureToken&); | |
| 63 BLINK_EXPORT void reset(); | |
| 64 | |
| 65 WebPrivateOwnPtr<UserGestureIndicator> m_indicator; | |
| 66 }; | 58 }; |
| 67 | 59 |
| 68 } // namespace blink | 60 void RunServer() { |
| 61 std::string server_address("0.0.0.0:50051"); |
| 62 GreeterServiceImpl service; |
| 69 | 63 |
| 70 #endif // WebScopedUserGesture_h | 64 ServerBuilder builder; |
| 65 // Listen on the given address without any authentication mechanism. |
| 66 builder.AddListeningPort(server_address, grpc::InsecureServerCredentials()); |
| 67 // Register "service" as the instance through which we'll communicate with |
| 68 // clients. In this case it corresponds to an *synchronous* service. |
| 69 builder.RegisterService(&service); |
| 70 // Finally assemble the server. |
| 71 std::unique_ptr<Server> server(builder.BuildAndStart()); |
| 72 std::cout << "Server listening on " << server_address << std::endl; |
| 73 |
| 74 // Wait for the server to shutdown. Note that some other thread must be |
| 75 // responsible for shutting down the server for this call to ever return. |
| 76 server->Wait(); |
| 77 } |
| 78 |
| 79 int main(int argc, char** argv) { |
| 80 RunServer(); |
| 81 |
| 82 return 0; |
| 83 } |
| OLD | NEW |