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 |