You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
A Client established a connection with a Farcaster Hub which can be used to send and receive messages. It is initialized
with the IP address and gRPC port of the Hub. Once connected, a Client instance can:
Query for messages by user or type.
Query for on-chain Farcaster Contracts state.
Subscribe to changes by type.
Upload new messages.
Constructor
getInsecureHubRpcClient returns a Hub RPC Client. Use getSSLHubRpcClient if the server you're using supports SSL.
Usage
import{getSSLHubRpcClient}from'@farcaster/hub-nodejs';// Instantiate the gRPC client for a secure connectionconstclient=getSSLHubRpcClient('testnet1.farcaster.xyz:2283');// If the Hub does not use SSL, call the getInsecureHubRpcClient method instead// const insecureClient = getInsecureHubRpcClient('https://testnet1.farcaster.xyz:2283');// Wait for the gRPC client to be ready before making any requestsclient.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to the gRPC server:`,e);process.exit(1);}else{console.log(`Connected to the gRPC server`);// Add any gRPC calls you want to make here, for example:// const castsResult = await client.getCastsByFid({ fid: 8928 });// After everything, close the RPC connectionclient.close();}});
Returns
Type
Description
Client
A new Client instance.
Parameters
Name
Type
Description
address
string
Address and RPC port string (e.g. https://testnet1.farcaster.xyz:2283)
Authentication
Some Hubs require authentication to submit messages which is done with basic auth over SSL. Clients will automatically
negotiate an SSL connection if possible, and you'll need to provide the username and password when calling submitMessage.
Methods
Clients expose methods grouped into logical services. Each method returns an async Result
object and may support pagination.
Methods are async and return a HubAsyncResult<T>, a wrapper around neverthrow's Result, which contains either a
successful response of type <T> or an error value. There are three types of return values across all our methods:
Results always return an object of type Message instead of a more specific type like CastAddMessage due to a quick of the protobuf-generated types. This can be easily remedied by passing responses through a typeguard:
import{isCastAddMessage}from'@farcaster/hub-nodejs';// See getCast documentation below for more details on thisconstcastResult=awaitclient.getCast({fid: 2,hash: castHashBytes});if(castResult.isOk()){constcast=castResult.value;// cast is of type Messageif(isCastAddMessage(cast)){console.log(cast);// cast is now a CastAddMessage}}
Pagination
Methods that return multiple values support pagination in requests with a pageSize and pageToken property.
import{getSSLHubRpcClient,HubResult,MessagesResponse}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);letnextPageToken: Uint8Array|undefined=undefined;letisNextPage=true;while(isNextPage){constcastsResult: HubResult<MessagesResponse>=awaitclient.getCastsByFid({fid: 2,pageSize: 10,pageToken: nextPageToken,});if(castsResult.isErr()){break;}constcastsResponse: MessagesResponse=castsResult.value;castsResponse.messages.map((cast)=>console.log(cast?.data?.castAddBody?.text));nextPageToken=castsResponse.nextPageToken;isNextPage=!!nextPageToken&&nextPageToken.length>0;}client.close();}});
Method Request Documentation
getSigner
Returns an active signer message given a fid and the public key of the signer.
Usage
import{getSSLHubRpcClient,hexStringToBytes}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constsignerPubKeyHex='5feb9e21f3df044197e634e3602a594a3423c71c6f208876074dc5a3e0d7b9ce';constsigner=hexStringToBytes(signerPubKeyHex)._unsafeUnwrap();// Safety: signerPubKeyHex is known and can't errorconstsignerResult=awaitclient.getSigner({fid: 2,
signer,});signerResult.map((signerAdd)=>console.log(signerAdd));client.close();}});
Returns
Type
Description
MessageResult<SignerAddMessage>
A SignerAdd message.
Parameters
Name
Type
Description
fid
number
The fid of the user.
signer
string
The public key of the signer.
getSignersByFid
Returns all active signers created by a fid in reverse chronological order.
Usage
import{getSSLHubRpcClient}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constsignersResult=awaitclient.getSignersByFid({fid: 2});signersResult.map((signers)=>console.log(signers.messages));client.close();}});
Returns
Type
Description
MessagesResult<SignerAddMessage>
One or more SignerAdd messages.
Parameters
Name
Type
Description
fid
number
The fid of the user.
pageSize?
number
Number of results per page.
pageToken?
Uint8Array
Token used to fetch the next page, if it exists.
reverse?
boolean
Reverses the chronological ordering.
getAllSignerMessagesByFid
Returns all active and inactive signers created by an fid in reverse chronological order.
Usage
import{getSSLHubRpcClient}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constsignersResult=awaitclient.getAllSignerMessagesByFid({fid: 2});signersResult.map((signers)=>console.log(signers.messages));client.close();}});
Returns a specific piece of metadata about the user.
Usage
import{getSSLHubRpcClient,UserDataType}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constuserDataResult=awaitclient.getUserData({fid: 2,userDataType: UserDataType.DISPLAY});userDataResult.map((userData)=>console.log(userData));client.close();}});
import{getSSLHubRpcClient}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constuserDataResult=awaitclient.getAllUserDataMessagesByFid({fid: 2});userDataResult.map((userData)=>userData.messages.map((message)=>console.log(message)));client.close();}});
Returns
Type
Description
MessagesResult<UserDataAddMessage>
Zero or more UserDataAdd messages.
Parameters
Name
Type
Description
fid
number
The fid of the user.
reverse?
boolean
Reverses the chronological ordering.
getAllUserDataMessagesByFid
An alias for getUserDataByFid
getCast
Returns an active cast for a user.
Usage
import{getSSLHubRpcClient,hexStringToBytes}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constcastHashHex='460a87ace7014adefe4a2944fb62833b1bf2a6be';constcastHashBytes=hexStringToBytes(castHashHex)._unsafeUnwrap();// Safety: castHashHex is known and can't errorconstcastResult=awaitclient.getCast({fid: 2,hash: castHashBytes});castResult.map((cast)=>console.log(cast));client.close();}});
Returns
Type
Description
MessageResult<CastAddMessage>
The CastAdd message
Parameters
Name
Type
Description
fid
number
The fid of the user.
hash
string
The hash of the cast.
getCastsByFid
Returns active casts for a user in reverse chronological order.
Usage
import{getSSLHubRpcClient}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);client.getCastsByFid({fid: 2}).then((castsResult)=>{castsResult.map((casts)=>console.log(casts.messages));client.close();});}});
Returns
Value
Description
MessagesResult<CastAddMessage>
Zero or more CastAdd messages.
Parameters
Name
Type
Description
fid
number
The fid of the user.
pageSize?
number
Number of results per page.
pageToken?
Uint8Array
Token used to fetch the next page, if it exists.
reverse?
boolean
Reverses the chronological ordering.
getCastsByMention
Returns all active casts that mention an fid in reverse chronological order.
Usage
import{getSSLHubRpcClient}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constcastsResult=awaitclient.getCastsByMention({fid: 2});castsResult.map((casts)=>console.log(casts.messages));client.close();}});
Returns
Value
Description
MessagesResult<CastAddMessage>
Zero or more CastAdd messages.
Parameters
Name
Type
Description
fid
number
The fid that is mentioned in the casts.
pageSize?
number
Number of results per page.
pageToken?
Uint8Array
Token used to fetch the next page, if it exists.
reverse?
boolean
Reverses the chronological ordering.
getCastsByParent
Returns all active casts that are replies to a specific cast in reverse chronological order.
Usage
import{geSSLHubRpcClient,hexStringToBytes}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constcastHashHex='ee04762bea3060ce3cca154bced5947de04aa253';constcastHashBytes=hexStringToBytes(castHashHex)._unsafeUnwrap();// Safety: castHashHex is knownconstcastsResult=awaitclient.getCastsByParent({parentCastId: {fid: 2,hash: castHashBytes}});castsResult.map((casts)=>console.log(casts.messages));client.close();}});
Returns all active and inactive casts for a user in reverse chronological order.
Usage
import{getSSLHubRpcClient}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constcastsResult=awaitclient.getAllCastMessagesByFid({fid: 2});castsResult.map((casts)=>console.log(casts.messages));client.close();}});
Returns an active reaction of a particular type made by a user to a cast.
Usage
import{geSSLHubRpcClient,hexStringToBytes,ReactionType}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constcastHashHex='ee04762bea3060ce3cca154bced5947de04aa253';// Cast to fetch reactions forconstcastHashBytes=hexStringToBytes(castHashHex)._unsafeUnwrap();// Safety: castHashHex is known and can't errorconstreactionsResult=awaitclient.getReaction({fid: 8150,reactionType: ReactionType.LIKE,castId: {fid: 2,hash: castHashBytes,},});reactionsResult.map((reaction)=>console.log(reaction));client.close();}});
Returns all active reactions made by users to a cast.
Usage
import{getSSLHubRpcClient,hexStringToBytes,ReactionType}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constcastHashHex='ee04762bea3060ce3cca154bced5947de04aa253';// Cast to fetch reactions forconstcastHashBytes=hexStringToBytes(castHashHex)._unsafeUnwrap();// Safety: castHashHex is known and can't errorconstreactionsResult=awaitclient.getReactionsByCast({reactionType: ReactionType.LIKE,castId: {fid: 2,hash: castHashBytes,},});reactionsResult.map((reaction)=>console.log(reaction.messages));client.close();}});
Returns all active reactions made by a user in reverse chronological order.
Usage
import{getSSLHubRpcClient,ReactionType}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constreactionsResult=awaitclient.getReactionsByFid({fid: 2,reactionType: ReactionType.LIKE});reactionsResult.map((reaction)=>console.log(reaction.messages));client.close();}});
Returns all active and inactive reactions made by a user in reverse chronological order.
Usage
import{getSSLHubRpcClient}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constreactionsResult=awaitclient.getAllReactionMessagesByFid({fid: 2});reactionsResult.map((reaction)=>console.log(reaction.messages));client.close();}});
Zero or more ReactionAdd or ReactionRemove messages.
Parameters
Name
Type
Description
fid
number
The fid of the user.
pageSize?
number
Number of results per page.
pageToken?
Uint8Array
Token used to fetch the next page, if it exists.
reverse?
boolean
Reverses the chronological ordering.
getVerification
Returns an active verification for a specific Ethereum address made by a user.
Usage
import{getSSLHubRpcClient,hexStringToBytes}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constaddressHex='0x2D596314b27dcf1d6a4296e95D9a4897810cE4b5';constaddressBytes=hexStringToBytes(addressHex)._unsafeUnwrap();// Safety: addressHex is known and can't errorconstverificationResult=awaitclient.getVerification({fid: 2,address: addressBytes});verificationResult.map((verification)=>console.log(verification));client.close();}});
Returns
Type
Description
MessageResult<VerificationAddEthAddressMessage>
A VerificationAddEthAddress message.
Parameters
Name
Type
Description
fid
number
The fid of the user.
address
string
The Ethereum address being verified.
getVerificationsByFid
Returns all active verifications for Ethereum addresses made by a user in reverse chronological order.
Usage
import{getSSLHubRpcClient}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constverificationsResult=awaitclient.getVerificationsByFid({fid: 2});verificationsResult.map((verificationsResponse)=>verificationsResponse.messages.map((v)=>{console.log(v);}));client.close();}});
Returns
Value
Description
MessagesResult<VerificationAddEthAddressMessage>
Zero or more VerificationAddEthAddress messages.
Parameters
Name
Type
Description
fid
number
The fid of the user.
pageSize?
number
Number of results per page.
pageToken?
Uint8Array
Token used to fetch the next page, if it exists.
reverse?
boolean
Reverses the chronological ordering.
getAllVerificationMessagesByFid
Returns all active and inactive verifications for Ethereum addresses made by a user in reverse chronological order.
Usage
import{getSSLHubRpcClient}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constverificationsResult=awaitclient.getAllVerificationMessagesByFid({fid: 2});verificationsResult.map((verificationsResponse)=>verificationsResponse.messages.map((v)=>{console.log(v);}));client.close();}});
Zero or more VerificationAddEthAddress or VerificationRemove messages.
Parameters
Name
Type
Description
fid
number
The fid of the user.
pageSize?
number
Number of results per page.
pageToken?
Uint8Array
Token used to fetch the next page, if it exists.
reverse?
boolean
Reverses the chronological ordering.
subscribe
Returns a gRPC Stream object which emits HubEvents in real-time.
Streams emit events from the current timestamp onwards and gRPC guarantees ordered delivery. If a Client is
disconnected, it can request the stream to begin from a specific Event Id. Hubs maintain a short cache of events
which helps with recovery when clients get disconnected temporarily.
Usage
import{getSSLHubRpcClient,HubEventType}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constsubscribeResult=awaitclient.subscribe({eventTypes: [HubEventType.MERGE_MESSAGE],});if(subscribeResult.isOk()){conststream=subscribeResult.value;forawait(consteventofstream){console.log(event);}}client.close();}});
Submits a new message to the Hub. A Hub can choose to require basic authentication or enforce IP-based rate limits for messages accepted over this endpoint from clients.
Usage
import{getSSLHubRpcClient,getAuthMetadata}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constmessage;// Any valid message constructed with a BuilderconstauthMetadata=getAuthMetadata('username','password');// Only necessary if the hubble instance requires authconstsubmitResult=awaitclient.submitMessage(message,authMetadata);constsubmitResult=awaitclient.submitMessage(message);console.log(submitResult);client.close();}});
Returns
Value
Description
MessageResult<T>
The message that was submitted.
Parameters
Name
Type
Description
message
Message
The message being submitted
metadata?
string
(optional) Username and password metadata for authentication
getIdRegistryEvent
Returns the on-chain event most recently associated with changing an fid's ownership.
Usage
import{getSSLHubRpcClient}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constidrResult=awaitclient.getIdRegistryEvent({fid: 2});idrResult.map((event)=>console.log(event));}client.close();});
Returns
Value
Description
HubAsyncResult<IdRegistryEvent>
An IdRegistryEvent.
Parameters
Name
Type
Description
fid
number
The fid of the user.
getNameRegistryEvent
Returns the on-chain event most recently associated with changing an fname's ownership.
Usage
import{getSSLHubRpcClient}from'@farcaster/hub-nodejs';consthubRpcEndpoint='testnet1.farcaster.xyz:2283';constclient=getSSLHubRpcClient(hubRpcEndpoint);client.$.waitForReady(Date.now()+5000,async(e)=>{if(e){console.error(`Failed to connect to ${hubRpcEndpoint}:`,e);process.exit(1);}else{console.log(`Connected to ${hubRpcEndpoint}`);constfnameBytes=newTextEncoder().encode('v');constnrResult=awaitclient.getNameRegistryEvent({name: fnameBytes});nrResult.map((event)=>console.log(event));client.close();}});
Returns
Value
Description
HubAsyncResult<NameRegistryEvent>
A NameRegistryEvent.
Parameters
Name
Type
Description
fname
string
The fname of the user.
Method Response Documentation
MessageResult
A documentation alias for HubAsyncResult<Message> where the success value contains a single message.
Message are of the type requested but this is an implicit guarantee since ts-proto does not generate bindings
correctly to reflect this in the returned types.
MessagesResult
A documentation alias for HubAsyncResult<MessagesResponse> where the success value contains a MessagesResponse object.
Messages are of the type requested but this is an implicit guarantee since ts-proto does not generate bindings
correctly to reflect this in the returned types.