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

Migration of Backend from NestJS to Go #430

Open
devleejb opened this issue Dec 23, 2024 · 27 comments · May be fixed by #434
Open

Migration of Backend from NestJS to Go #430

devleejb opened this issue Dec 23, 2024 · 27 comments · May be fixed by #434
Assignees
Labels
enhancement 🌟 New feature or request

Comments

@devleejb
Copy link
Member

What would you like to be added:
The current backend is structured using NestJS, and there is a proposal to migrate it to Go. The primary reason for this migration is to engage contributors who have a stronger interest in backend development.

The migration should take into account the following considerations:

  • Implement LangChain functionality in the Go environment.
  • Utilize OAuth for user authentication and authorization.
  • Ensure proper validation mechanisms are in place.
  • Verify that the new backend operations are consistent with the existing functionality.
  • Generate Swagger documentation for the API in the new setup.

Why is this needed:
Migrating to Go may enhance our ability to attract backend-focused contributors and improve the overall performance and scalability of our application. This transition also aims to maintain functionality while leveraging Go's efficiency and capabilities.

Additional Information:

@devleejb devleejb added the enhancement 🌟 New feature or request label Dec 23, 2024
@github-project-automation github-project-automation bot moved this to Backlog in CodePair Dec 23, 2024
@devleejb
Copy link
Member Author

@blurfx @krapie @window9u Could you share your thoughts on migration and any considerations?

@window9u
Copy link

@devleejb

I completely agree that migrating the CodePair backend to Go aligns well with Yorkie contributors' expertise, making collaboration more natural. If this proposal moves forward, I’m excited to join the migration team and contribute to building a robust Go-based backend!

Once a new repository for the Go-based backend is created, I suggest we discuss key decisions like:

  1. HTTP Framework: Should we use Gin, Echo, or native middleware?
  2. MongoDB Integration: Options include the official mongo-go-driver or tools like mgm for simplifying operations.

@devleejb
Copy link
Member Author

@window9u

Thank you for your answer!

  1. HTTP Framework: Should we use Gin, Echo, or native middleware?

I understand that yorkie uses native middleware. Is that correct? If so, we can use it as a valuable reference.

  1. MongoDB Integration: Options include the official mongo-go-driver or tools like mgm for simplifying operations.

yorkie also uses mongo-go-driver. Additionally, we reference the database architecture in yorkie to support other options (e.g., MySQL, and more).

@blurfx
Copy link
Member

blurfx commented Dec 23, 2024

I think fiber is a good option for the http framework. It's very fast and has some nice features.

@window9u
Copy link

@devleejb

HTTP Framework

As far as I know, yes, Yorkie uses native middleware. However, this decision likely stems from its need to handle more complex logic, such as RPC connections and health checks. Here's an example of Yorkie code:

mux := http.NewServeMux()
mux.Handle(v1connect.NewYorkieServiceHandler(newYorkieServer(yorkieServiceCtx, be), opts...))
mux.Handle(v1connect.NewAdminServiceHandler(newAdminServer(be, tokenManager), opts...))
mux.Handle(v1connect.NewClusterServiceHandler(newClusterServer(be, opts...)))
mux.Handle(grpchealth.NewHandler(healthChecker))
mux.Handle(httphealth.NewHandler(healthChecker))

For CodePair, if the logic mainly involves simple CRUD operations, using a framework could be a good choice to streamline development. But I’ve only worked with native HTTP handlers, so I don’t have much experience with frameworks. I trust @blurfx’s recommendation would be more informed in this case.

MongoDB Integration

Since Yorkie uses the official mongo-go-driver, it’s a dependable choice for CodePair as well. I also agree with adding support for relational databases as an option, as it could increase flexibility and scalability.

Additionally, I’ve been interested in exploring semantic search using vector databases for CodePair. When considering other database options, it might be valuable to account for this use case. I’ve heard that PostgreSQL offers excellent scalability and extensions for features like vector search, making it worth considering for future-proofing the architecture.

@blurfx
Copy link
Member

blurfx commented Dec 23, 2024

I've used some go http frameworks like net/http, fasthttp, and fiber before and had no problem adapting to any of the three libraries/frameworks. the three of them provides a similar developer experience to most web frameworks. If you have a experience with net/http in go, or express or koa in node.js, I think you're probably already familiar with it.

Database:

I'm curious why you chose MongoDB for your existing CodePair, and what you've liked and disliked about it.
Changing databases is a quite large task and MongoDB is relatively scalable than other databases, so I think we can keep it, but as @window9u said, PostgreSQL might be a good option. there are many (third-party) extensions that can do full text search or message queue, etc...

@devleejb
Copy link
Member Author

@blurfx I chose MongoDB to utilize Yorkie’s existing database. To clarify, I am referring to supporting a new database type like yorkie (MongoDB, In-Memory), not replacing the production database.

@blurfx
Copy link
Member

blurfx commented Dec 23, 2024

I misread that. I understand now.

@devleejb
Copy link
Member Author

devleejb commented Dec 23, 2024

@blurfx Could you recommend a framework? Actually, I’ve been considering using Yorkie’s architecture to accommodate contributions from Yorkie contributors.

@blurfx
Copy link
Member

blurfx commented Dec 23, 2024

@devleejb I don't know the workload of CodePair server, but I can suggest the following options:

Performance - Fiber
Ecosystem - Echo
Minimal, lightweight, (not framework) - chi


I personally prefer fiber but is not compatible net/http interface so there might be issues with using third-party packages.

So I think echo would be great with a large ecosystem and a well-documented and built-in features.

@hackerwins
Copy link
Member

@blurfx @devleejb
I think it would be good to create a few backend scaffolding PRs and compare them.

@krapie
Copy link
Member

krapie commented Dec 24, 2024

@devleejb @hackerwins @devleejb @window9u

I have experimentally ported the backend to a Go server application using both echo and net/http for comparison, with the help of Cursor(Claude).

Please note that some modules might be missing or not fully implemented.

@devleejb
Copy link
Member Author

devleejb commented Dec 25, 2024

@krapie
Thank you for your hard work! It’s truly amazing!
I think echo works really well for codepair. I’ll take a closer look at the code this weekend.
If you have any suggestions, please feel free to share them!

I’ll put together a migration plan (including target APIs, timeline, validation, etc.).

I’m aiming to release version v0.2 along with the Go migration. :)

@devleejb
Copy link
Member Author

@sejongk I’m also curious about your thoughts.

@devleejb
Copy link
Member Author

I have outlined the goals, tasks, considerations, and discussion points for this migration (CodePair Document).
If you’re interested in this issue, please add your name to the Participants field.

Feel free to join the discussion!
Support from Gophers is highly appreciated.

@devleejb
Copy link
Member Author

devleejb commented Jan 1, 2025

If there are no further discussions, I’d like to move on to the next tasks. :)

CC. @blurfx How about using echo so we can take advantage of its large ecosystem? I also looked into chi, but I’d rather use something with a bigger community around it.

@blurfx
Copy link
Member

blurfx commented Jan 2, 2025

@devleejb Great. I think echo is a good way to get things done quickly because a lot of features comes from the framework's built-in features or community.

@devleejb
Copy link
Member Author

devleejb commented Jan 7, 2025

@kokodak @blurfx @krapie @window9u @sihyeong671
Is anyone interested in implementing scaffolding? I’m short on time these days.
I think we can start with @krapie 's scaffolding.

@window9u
Copy link

window9u commented Jan 8, 2025

@devleejb
Can I try this on? And I'll ask questions if I get stuck.

@devleejb
Copy link
Member Author

devleejb commented Jan 8, 2025

@window9u Of course! Feel free to reach out any time when you’re stuck.

@blurfx
Copy link
Member

blurfx commented Jan 8, 2025

I will be busy this week, but I think I'll be able to start working on it actively next week. There is something I can help with?

@krapie
Copy link
Member

krapie commented Jan 9, 2025

@window9u Could you create a draft PR later? It would be better for tracking the implementation progress, and others can easily contribute to that branch.

@window9u
Copy link

window9u commented Jan 9, 2025

@krapie
Sure! I'll create it once I start writing the code. For now, I'm focusing on understanding the previous context.

@devleejb
Copy link
Member Author

devleejb commented Jan 11, 2025

I will be busy this week, but I think I'll be able to start working on it actively next week. There is something I can help with?

@blurfx Could you help set up an incremental deployment process? As we discussed earlier, I believe we can leverage Nginx within a Docker container.

@devleejb
Copy link
Member Author

devleejb commented Jan 11, 2025

If you’re interested in working on it, feel free to ask me. I’ll assign the task to you!

  • Discussions @devleejb
    • Framework vs. net/http
    • Yorkie Intelligence (LangChain)
    • Documentation (eg, swagger)
    • Deployment Method
    • Testing Method (Verify whether the Go API supports same behavior)
  • Implement scaffolding (Go) @window9u
    • Project Initialization (Framework, CORS, Swagger, Envrironment...)
    • Auth middleware
    • Dummy Database Layer (Including database connection)
    • Dummy Service Layer
    • Dummy Handler Layer
  • Implement scaffolding (Python) @sihyeong671
    • Project Initialization (Framework, CORS, Swagger, Envrironment...)
  • Set up incremental deploy @blurfx
  • Migrate APIs (https://codepair-api.yorkie.dev/api)
    • GET /users
    • PUT /users
    • GET /auth/login/github
    • POST /auth/refresh
    • POST /workspaces
    • GET /workspaces
    • GET /workspaces/{worskapce_slug}
    • POST /workspaces/{workspace_id}/invite-token
    • POST /workspaces/join
    • GET /workspaces/{workspace_id}/users
    • PUT /workspaces/{workspace_id}/documents/{document_id}
    • GET /workspaces/{workspace_id}/documents/{document_id}
    • GET /workspaces/{workspace_id}/documents
    • POST /workspaces/{workspace_id}/documents
    • POST /workspaces/{workspace_id}/documents/{document_id}/share-token
    • GET /documents/share
    • POST /check/name-conflict
    • POST /check/yorkie
    • POST /intelligence
    • POST /intelligence/{feature}
    • POST /files
    • GET `/files/{file_name}
    • POST /files/export-markdown
    • GET /settings
  • Testing
  • Deploy
  • Deprecate NestJS backend

@blurfx
Copy link
Member

blurfx commented Jan 11, 2025

I will be busy this week, but I think I'll be able to start working on it actively next week. There is something I can help with?

@blurfx Could you help set up an incremental deployment process? As we discussed earlier, I believe we can leverage Nginx within a Docker container.

Sure. I'll try it soon.

@window9u window9u linked a pull request Jan 13, 2025 that will close this issue
7 tasks
@sihyeong671
Copy link
Contributor

I'll take python Implement scaffolding, please assign me that issue

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
Status: Backlog
Status: Backlog
Development

Successfully merging a pull request may close this issue.

7 participants