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

Set or change the Destination path from the CLI #87

Closed
leggetter opened this issue Jul 12, 2024 · 21 comments
Closed

Set or change the Destination path from the CLI #87

leggetter opened this issue Jul 12, 2024 · 21 comments
Labels
enhancement New feature or request

Comments

@leggetter
Copy link
Collaborator

leggetter commented Jul 12, 2024

Running the following will prompt for a path for the CLI:

hookdeck listen 3030 {SOURCE_NAME} 
? What path should the events be forwarded to (ie: /webhooks)?

However, after this point, if you want to change the path, you need to go to the dashboard and edit from the UI.

Can we add support for setting the CLI path on the original request and changing the "CLI path" for a Destination from the CLI?

There's a great discussion and some good work gone into #68 as an experiment for adding broader CRUD support and we ultimately decided against it (for now).

However, this feels like a common sense feature to support.

Options I can think of:

  1. Add a command that supports modifying the CLI path of a source. It would need to check the provided source was of type CLI. We may also then want to allow sources to be listed to help with discoverability. That would need to show the source name, type, and CLI path if the type was CLI path.
  2. Add a keypress handler when the CLI is running that allows the path of the running process to be edited. This removes the need for a new command as you just use the current context. However, this is complicated by the support for listening on multiple sources (v0.2.0 #84).
  3. Set or change the Destination path from the CLI #87 (comment)

@alexluong WDYT?

@leggetter leggetter added the enhancement New feature or request label Jul 12, 2024
@alexluong
Copy link
Collaborator

I think this is a fair idea. It does make sense that we want to keep user on their terminal, especially when they're configuring some their development configuration anyway.

I'm curious if a better solution is to encourage better adoption of Terraform? Although I can see how it's not possible for every team.

From the 2 options you have, I think option 1 is way more viable. I feel the complexity of adding feature to the listen command may not be worth it. Can you share the TUI UX you have in mind?

@leggetter
Copy link
Collaborator Author

What about dynamically changing if a --cli-path {path} flag is passed to the listen command?

This allows:

  1. the path to be updated dynamically when listen is called
  2. the interactive prompt for the path to be bypassed

@alexluong
Copy link
Collaborator

alexluong commented Jul 16, 2024

@leggetter what if a source has multiple connections to different CLI destinations, how do we know which destination to override?

@leggetter
Copy link
Collaborator Author

@alexluong, how does the CLI know which destination to inherit and use when it connects, and multiple CLI Destinations exist?

@alexluong
Copy link
Collaborator

@leggetter it doesn't, it just sends the events to every connected destination when there's a new event.

@leggetter
Copy link
Collaborator Author

@alexluong, so, there must be some server-side websocket handling code that decides which CLI destination the CLI should inherit?

@alexluong
Copy link
Collaborator

@leggetter my understanding is that when a request comes to the source, the server will turn that request into events to relevant destinations (via connection rules logic). The websocket server will deliver each event to the CLI, which will then proxy to the local CLI path.

However, from the CLI, it proxies based on source (you can specify the connection too but it's not relevant in this discussion). Not sure if this clarifies things. I'm not entirely sure what your idea is to go about this 😅

@leggetter leggetter changed the title Change the Destination path from the CLI Set or change the Destination path from the CLI Jul 16, 2024
@leggetter
Copy link
Collaborator Author

What about dynamically changing if a --cli-path {path} flag is passed to the listen command?

This allows:

  1. the path to be updated dynamically when listen is called
  2. the interactive prompt for the path to be bypassed

@alexluong could you create a branch to experiment with this and find any problems we need to solve?

Using a flag avoids a breaking change and/or avoids the need for additional optional prams to be passed since listen already takes, port, source, connection query.

@mkherlakian I'm going to suggest we don't change the default behaviour to prompt for a CLI path. We could change to default to / but this feels like a breaking change.

@mkherlakian
Copy link
Contributor

@mkherlakian I'm going to suggest we don't change the default behaviour to prompt for a CLI path. We could change to default to / but this feels like a breaking change.

Ok. But how do you choose the connection that this applies to in this case? Without a connection, the CLI doesn't know which destination to update unless there's only one dest

@alexluong
Copy link
Collaborator

alexluong commented Jul 19, 2024

CleanShot 2024-07-19 at 18 50 49

Hey @leggetter, so let me elaborate the point a bit just to make sure we understand your idea a bit better. Let's say we have a connection set up like this where a source has 2 connections to 2 CLI destinations. This is how it looks when proxying:

$ hookdeck-cli git:(main) hookdeck listen 4000
? Select a source source

Dashboard
👉 Inspect and replay events: https://dashboard.hookdeck.com?team_id=tm_odIiTVdHmb4a

source Source
🔌 Event URL: https://hkdk.events/rmvvtxrgic256w

Connections
local-2 forwarding to /local/2
local-1 forwarding to /local/1

> Ready! (^C to quit)

So, from your idea, if we run $ hookdeck listen 4000 --cli-path /local/another, how should we decide between local-1 and local-2 destinations?

I understand your intention is to make changing CLI path easier, but we need to think through these edge cases before we can proceed with the simple use case.


Besides, another case we should think about is the multi-source support that we will support soon. In that case, there are many different destinations with different path, how should we determine which path to override?

@leggetter
Copy link
Collaborator Author

leggetter commented Jul 19, 2024

@alexluong thanks for clarifying. @mkherlakian see above. Would providing a connection name resolved then problem?

hookdeck listen 3030 source connection --cli_path /webhooks

Honestly, for newcomers who don't know about sources and connections it adds another unknown param sonim not super happy about it.

@alexluong
Copy link
Collaborator

alexluong commented Jul 19, 2024

Would providing a connection name resolved then problem?

Yes, this would sort of resolve the problem. The only thing is I don't see a ton of value in this, but we can make this work.

Basically this will override the CLI path. That's great for temporary work, but if this is a long-term change, than wouldn't updating the destination be better for future usage as well as collaboration?

Honestly, for newcomers who don't know about sources and connections it adds another unknown param sonim not super happy about it.

The concern is this may add more complexity instead of reducing it. The thing is the user must set up their connection & destination first, one way or the other, before doing this. Therefore, I don't quite see the problem this solution is solving.

@mkherlakian
Copy link
Contributor

mkherlakian commented Jul 20, 2024

The only thing is I don't see a ton of value in this

Why not?

Basically this will override the CLI path. That's great for temporary work, but if this is a long-term change, than wouldn't updating the destination be better for future usage as well as collaboration?

The way I see it, we should be updating the destination if the path param is specified in the CLI args, or creating it if it doesn't exist.

The thing is the user must set up their connection & destination first, one way or the other, before doing this.

Why can't the connection and destination be created on the fly?

The concern is this may add more complexity instead of reducing it.

On the contrary - If we instruct users to just issue the one command, and everything is created for them, even if they are not familiar with source, dest, and connection constructs, they can get started immediately. It reduces friction quite a bit. Ideally we can do this with a guest accounts as well.

@alexluong
Copy link
Collaborator

alexluong commented Jul 20, 2024

Why can't the connection and destination be created on the fly?

They can, but not with just cli-path. We need at the very least the destination name as well.


It seems I'm not quite following the purpose of what we're trying to do here. Maybe @leggetter or @mkherlakian can help write a short summary to make sure we're aligned.

From this original message:

CleanShot 2024-07-20 at 20 16 52

I thought this is to assist with the UX for continued usage instead of the initial adoption. But from your message @mkherlakian, it seems you're focusing more on the initial friction and user experience?

I'm also confused between 2 goals:

  • Manage resources (create connection & destination on the fly)
  • Override value during development (override cli-path of an already-created destination)

So overall it's just a bit difficult what we're trying to solve for. Either of those, or both of those, are all good, but I hope we should clarify the intention so we can solve the right problem.

@leggetter
Copy link
Collaborator Author

@alexluong @mkherlakian have a look at this #90

Try:

./hookdeck-cli listen 8080 source_name --cli-path /some_path --log-level debug

(jumping on a flight so this is a quick draft PR)

@alexluong
Copy link
Collaborator

alexluong commented Jul 21, 2024

Thanks for the PR @leggetter, so from what I can see, here are the key behaviors I noticed from the PR:

  1. When there's no CLI destination, we will create the destination & connection with hard-coded name cli.
  2. When there's an existing 1-to-1 source to CLI destination, if the CLI path is different between --cli-path and the destination value, then we will update it on Hookdeck as well.
  3. When a source maps to multiple CLI destinations, the CLI ignores --cli-path config.

I think we can certainly work with this if this is the behavior you'd like. Maybe some small improvements around logging to communicate what we're doing to avoid confusion, but other than that I do think this should work if the behaviors above make sense to yall.

@mkherlakian
Copy link
Contributor

That works, thanks @leggetter!

Let's polish and release.

It would be nice to solve the multiple destinations problem too - maybe if you pass a CLI path that matches one of the connections, you select that connection. And if it doesn't match, you create that destination?

@mkherlakian
Copy link
Contributor

mkherlakian commented Jul 22, 2024

Considering another approach -
How about if we gave the option to the user to provide a connection name?

  • If the connection exists:
    • if it has a cli dest and path matches, use it
    • if it has a cli dest adn path doesn't match, update
    • it it doesn't have a cli dest, create
  • If the connection doesn't exist:
    • create source, dest and connection with cli path

Problem is listen now accepts a source, would be difficult to distinguish between source and connection.

@alexluong
Copy link
Collaborator

alexluong commented Jul 22, 2024

maybe if you pass a CLI path that matches one of the connections, you select that connection. And if it doesn't match, you create that destination?

This could work, so if you pass cli-path, that guarantees that you'll always proxy to a single connection (unless multiple connections with the same CLI destination matching the path).

Problem is listen now accepts a source, would be difficult to distinguish between source and connection.

You can pass a source AND a connection.

$ hookdeck listen 4000 source_name connection_name

We actually already support the CLI path in place of connection_name here too actually, maybe something to think about?

Let's polish and release.

@leggetter let me know if you'd like to polish yourself or if you'd like my help here!

@leggetter
Copy link
Collaborator Author

@mkherlakian @alexluong here's another pass #92

I've mapped out various scenarios and shown the old behavior and the new behavior.

A reasonably big functional change is to remove the interactivity. Reasoning is in the PR.

@leggetter
Copy link
Collaborator Author

Fixed in #97

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

No branches or pull requests

3 participants