Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Enabling gRPC Generic Event in Server Template #400

Open
KarthikAbiram opened this issue Jan 2, 2025 · 4 comments
Open

Enabling gRPC Generic Event in Server Template #400

KarthikAbiram opened this issue Jan 2, 2025 · 4 comments

Comments

@KarthikAbiram
Copy link
Contributor

KarthikAbiram commented Jan 2, 2025

A generic user event was added to the template few years back (#29), so that users can have the option of getting a single event for all gRPC methods, like below:
140873363-32ba9b61-c191-4693-9b8f-56cfd55496a9

This was quite handy for keeping the generated code and user code separate as well as allowing users to implement their own handlers/dispatchers.

Could someone please let me know how I can get this feature with the latest template?

AB#2963372

@jasonmreding
Copy link
Collaborator

I don't have a lot of background context on this, but I'm not sure this feature was really ever fully implemented/tested. Either that or subsequent changes to the LV code broke it. From looking at the code, it appears that only one event type is active in the server code at a time. So you can either receive a single generic event notification for all RPCs or an event that is specific to each RPC but not both. By default, the server template is generated such that it enables the RPC specific user events. This can be seen by looking at the generated Bind RPC ... .vi for the server. It should look something like below (I've deleted some data in the string constants and labels that are service specific).

image

This generated VI calls Create and Register Server Event.vim which is part of the grpc library installed to vilib and is also on the palette. This VI is in turn called by the generated Register gPRC Methods.vi. If you want to instead use a generic event, you will need to modify Register gRPC Methods.vi and replace the call to Create and Register Server Event.vim with Create and Register Generic Method Server Event.vi (also on the grpc functions palette). However, the user event for this VI has a different signature than the one that is generated for the server class. That means you will have to modify the server class to include this event type instead or do something else to "plumb" the data along so that it is accessible from Start Sync.vi or Start Async.vi. I guess you could inject another event loop that does nothing but convert from Method Name and Method gRPCid in one event type to the Command and Data used by the other event type. However, I'm not really sure what that buys you.

All of these comments are made from code inspection. I haven't actually tested any of this. I suspect you can probably get this to work by applying what I described above. However, my take from looking at the code is that this was never a fully fleshed out feature. This, Start Sync.vi, and Start Async.vi all seem like variations of the same theme at least in terms of handlers/dispatchers and parallelism. Long term, I think the generator should generate more of this dispatcher code for you and do a better job of separating generated code from user logic so the server can be updated based on latest proto file changes without overwriting user code.

@KarthikAbiram
Copy link
Contributor Author

@jasonmreding Thank you for your detailed response, this is very helpful.

I was able to make the changes based on my understanding & I am able to see the generic event received by server. But I am having trouble in sending response to the client. I am attaching sample code which I have tried, along with read me instructions on how to run/reproduce the issue.

SampleGrpc.zip

Modes

There is a boolean feature flag to choose between generic event (True) and individual events (False) in below VI:
SampleGrpc\Generated_server\RPC Service\SampleGrpc\Server API\Register gRPC Methods.vi

The current value is set to True (Using Generic Event).

Run Server

Run below VI to start the server:
SampleGrpc\Generated_server\Run Service.vi

Run Client Example

Run below VI:
SampleGrpc\Generated_client\gRPC Client Test.vi

Expected Behavior

When generic event flag is True, client is expected to receive a response 'Generic + .' For debugging, a pop up is added in the server for the generic event.

When generic event flag is False, client is expected to receive a response 'Standard + .'

Actual Behavior

When generic event flag is True, there is a pop up in server as expected. But there is no response received by the client.

When generic event flag is False, it is working as expected.

Please let me know if you have any suggestions on what could be the reason for this issue. Thanks!

@jasonmreding
Copy link
Collaborator

In the generic event case, you still need to call the generated Bind RPC...vi as that registers metadata for the request/response messages that are needed by the server to get the request/response messages for the call. If you update your server code as shown below, everything should work.

Image

@kthirunx
Copy link

kthirunx commented Jan 23, 2025

Thanks @jasonmreding , it works as expected after making the suggested change.

Attaching the latest code for any future references (LabVIEW 2019)

SampleGrpc.zip.

We can close this issue.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants