github.com/core-coin/go-core/v2@v2.1.9/rpc/doc.go (about) 1 // Copyright 2015 by the Authors 2 // This file is part of the go-core library. 3 // 4 // The go-core library is free software: you can redistribute it and/or modify 5 // it under the terms of the GNU Lesser General Public License as published by 6 // the Free Software Foundation, either version 3 of the License, or 7 // (at your option) any later version. 8 // 9 // The go-core library is distributed in the hope that it will be useful, 10 // but WITHOUT ANY WARRANTY; without even the implied warranty of 11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 // GNU Lesser General Public License for more details. 13 // 14 // You should have received a copy of the GNU Lesser General Public License 15 // along with the go-core library. If not, see <http://www.gnu.org/licenses/>. 16 17 /* 18 Package rpc implements bi-directional JSON-RPC 2.0 on multiple transports. 19 20 It provides access to the exported methods of an object across a network or other I/O 21 connection. After creating a server or client instance, objects can be registered to make 22 them visible as 'services'. Exported methods that follow specific conventions can be 23 called remotely. It also has support for the publish/subscribe pattern. 24 25 # RPC Methods 26 27 Methods that satisfy the following criteria are made available for remote access: 28 29 - method must be exported 30 - method returns 0, 1 (response or error) or 2 (response and error) values 31 32 An example method: 33 34 func (s *CalcService) Add(a, b int) (int, error) 35 36 When the returned error isn't nil the returned integer is ignored and the error is sent 37 back to the client. Otherwise the returned integer is sent back to the client. 38 39 Optional arguments are supported by accepting pointer values as arguments. E.g. if we want 40 to do the addition in an optional finite field we can accept a mod argument as pointer 41 value. 42 43 func (s *CalcService) Add(a, b int, mod *int) (int, error) 44 45 This RPC method can be called with 2 integers and a null value as third argument. In that 46 case the mod argument will be nil. Or it can be called with 3 integers, in that case mod 47 will be pointing to the given third argument. Since the optional argument is the last 48 argument the RPC package will also accept 2 integers as arguments. It will pass the mod 49 argument as nil to the RPC method. 50 51 The server offers the ServeCodec method which accepts a ServerCodec instance. It will read 52 requests from the codec, process the request and sends the response back to the client 53 using the codec. The server can execute requests concurrently. Responses can be sent back 54 to the client out of order. 55 56 An example server which uses the JSON codec: 57 58 type CalculatorService struct {} 59 60 func (s *CalculatorService) Add(a, b int) int { 61 return a + b 62 } 63 64 func (s *CalculatorService) Div(a, b int) (int, error) { 65 if b == 0 { 66 return 0, errors.New("divide by zero") 67 } 68 return a/b, nil 69 } 70 71 calculator := new(CalculatorService) 72 server := NewServer() 73 server.RegisterName("calculator", calculator) 74 l, _ := net.ListenUnix("unix", &net.UnixAddr{Net: "unix", Name: "/tmp/calculator.sock"}) 75 server.ServeListener(l) 76 77 # Subscriptions 78 79 The package also supports the publish subscribe pattern through the use of subscriptions. 80 A method that is considered eligible for notifications must satisfy the following 81 criteria: 82 83 - method must be exported 84 - first method argument type must be context.Context 85 - method must have return types (rpc.Subscription, error) 86 87 An example method: 88 89 func (s *BlockChainService) NewBlocks(ctx context.Context) (rpc.Subscription, error) { 90 ... 91 } 92 93 When the service containing the subscription method is registered to the server, for 94 example under the "blockchain" namespace, a subscription is created by calling the 95 "blockchain_subscribe" method. 96 97 Subscriptions are deleted when the user sends an unsubscribe request or when the 98 connection which was used to create the subscription is closed. This can be initiated by 99 the client and server. The server will close the connection for any write error. 100 101 For more information about subscriptions, see https://github.com/core-coin/go-core/v2/wiki/RPC-PUB-SUB. 102 103 # Reverse Calls 104 105 In any method handler, an instance of rpc.Client can be accessed through the 106 ClientFromContext method. Using this client instance, server-to-client method calls can be 107 performed on the RPC connection. 108 */ 109 package rpc