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

[Rust, Rust-server] should we merge the two rust generators into one? #7347

Open
bjgill opened this issue Jan 9, 2018 · 9 comments
Open

Comments

@bjgill
Copy link
Contributor

bjgill commented Jan 9, 2018

Description

I'm currently seeing a lot of PRs for rust seeking to add features that rust-server already has. It's going to be rather tedious to keep maintaining two parallel Rust generators.

Suggest a fix/enhancement

It would surely be more efficient to either pick only one for future maintenance or merge the two?

@bjgill
Copy link
Contributor Author

bjgill commented Jan 9, 2018

@frol @farcaller @wing328 - I don't know if you have any views on this? I don't know rust very well, so don't actually know if it has any features lacking from rust-server or vice-versa...

@frol
Copy link
Contributor

frol commented Jan 9, 2018

I am not the right person to ask this. I have not done anything but reviews of PRs to the Rust generators (I mean, I won't be able to implement any of the two generators myself in Rust), so I cannot make any decision here. I agree that a single implementation would be easier to maintain, so if someone is willing to make that move, that would be great!

@aykutakin
Copy link
Contributor

I see the benefit of merging this two implementations (having one source of truth, increasing maintainability, no need to patch 2 different place etc.). However, what should people do that only need client code in case of these implementations are merged? Should they generate code and remove server code later? Exact opposite is also valid if they only need server code.

As far as I see from other languages, client and server codes are generated separately. So, it may make sense to extract client code from rust-server completely and continue with separate implementations.

Please let me know if you have different kind of concerns about separating 2 implementations without leaving dependencies between them

@farcaller
Copy link
Contributor

Theoretically, we can hide the server code behind a cfg gate.

@wing328
Copy link
Contributor

wing328 commented Feb 1, 2018

Based on my experiences with other generators, I would suggest:

  • consolidates the Rust client (rust, rust-server's client code) into one
  • if we need to support more than 1 HTTP library, we better do it with the -l or --library option with a swappable ApiClient struct

The consolidation does not imply which Rust client (rust or rust-server's client code) is better.

The goal is to consolidate all efforts into one Rust client generator so that all Rust developers are better off maintaining just one generator for Rust client.

Ref: #6756

@aykutakin
Copy link
Contributor

Well, I can take over this issue, however I think it'd make sense to wait hyper version upgrade to deal with less complications

@wing328
Copy link
Contributor

wing328 commented Feb 3, 2018

Well, I can take over this issue, however I think it'd make sense to wait hyper version upgrade to deal with less complications

Agreed 👍

@bjgill
Copy link
Contributor Author

bjgill commented Feb 5, 2018

A few comments based on my knowledge of the design of rust_server:

I see the benefit of merging this two implementations (having one source of truth, increasing maintainability, no need to patch 2 different place etc.). However, what should people do that only need client code in case of these implementations are merged? Should they generate code and remove server code later? Exact opposite is also valid if they only need server code.

Currently, rust-server has client and server features. This allows users to omit whichever one they don't need. The unused code will still be in the autogenerated output, but will be ignored by the Rust compiler when the appropriate feature is specified.

As far as I see from other languages, client and server codes are generated separately. So, it may make sense to extract client code from rust-server completely and continue with separate implementations.

Please let me know if you have different kind of concerns about separating 2 implementations without leaving dependencies between them

When creating rust-server, it was a deliberate design decision to have the client and server closely tied together. Clients use the same trait that servers implement. This means that you can effectively create a distributed strongly typed system - the Rust compiler can verify that there are no mis-matches between servers and clients. This unification also means that we can safely pass around a Context object, which allows us to include a trail ID with the logs we generate.

rust-server is therefore quite different to most of the generators for other languages. My impression is that the other generators have been created by people interested in either servers or clients. rust-server, by contrast, is designed for systems containing a mix of both servers and clients.

@wing328
Copy link
Contributor

wing328 commented Feb 5, 2018

This allows users to omit whichever one they don't need. The unused code will still be in the autogenerated output, but will be ignored by the Rust compiler when the appropriate feature is specified.

Another option is to leverage the .swagger-codegen-ignore file to skip generating files for client or server if the user only needs either one of them.

My impression is that the other generators have been created by people interested in either servers or clients. rust-server, by contrast, is designed for systems containing a mix of both servers and clients.

haskell (servant) generator is another example that generates both server and client. Similarly, there's a Haskell client generator (haskell-http-client) to focus just on the client generation for Haskell developers.

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

No branches or pull requests

5 participants