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

https://github.com/second-state/dapr-wasm/pull/42 #7

Open
juntao opened this issue Apr 25, 2023 · 3 comments
Open

https://github.com/second-state/dapr-wasm/pull/42 #7

juntao opened this issue Apr 25, 2023 · 3 comments

Comments

@juntao
Copy link
Contributor

juntao commented Apr 25, 2023

No description provided.

Copy link
Contributor Author

juntao commented Apr 25, 2023

Hello, I am a code review bot on flows.network. Here are my reviews of changed source code files in this PR.


image-api-wasi-socket-rs/Cargo.toml

The code snippet you provided is the content of a Cargo.toml file, which is used as a configuration file for Rust projects. It does not contain any direct source code to review for potential bugs or issues. However, I can provide you with some high-level feedback based on the dependencies and features specified.

  1. Use a specific version of the dependency instead of referring to git. Relying on the git repository and branch may introduce problems with versioning and breaking changes. It's better to use a specific version of the dependency in your project. Consider replacing the hyper and tokio dependencies with their respective specific versions if they exist on crates.io. For example:
hyper = { version = "0.14.0", features = ["full"] }
tokio = { version = "1.5.0", features = ["rt", "macros", "net", "time", "io-util"] }
  1. Keep dependencies up-to-date. It is important to ensure that the dependencies you're using are up-to-date to benefit from bug fixes, security patches, and new features. You may need to review if the image and imageproc dependencies have updated versions. For example, if the latest version of image is 0.24.0, you can update it like this:
image = { version = "0.24.0", default-features = false, features = ["jpeg", "png", "gif"] }
  1. It is always a good practice to give a brief description of the project in the Cargo.toml file. Consider adding a description to the [package] section:
description = "An API for custom image processing"

Apart from these high-level suggestions, it's not possible to review any specific source code problems since this file only contains package metadata and dependencies. You can use tools like cargo clippy and cargo fmt for identifying and fixing common issues in your Rust source files.

The patch contains two key changes:

  1. In the hyper dependency, the features attribute has been modified. Previously, it used ["http1", "server"], and now it uses ["full"]. This change means that the project will now include all features provided by the hyper crate instead of just the http1 and server features.

  2. In the tokio dependency, the branch attribute has been removed, and a new feature - "io-util" - has been added to the features list. By removing the branch attribute, the dependency will now rely on the latest commit of the default branch (main or master). The new feature "io-util" enables additional I/O utilities provided by the tokio crate.

image-api-wasi-socket-rs/src/main.rs

Overall, the provided code looks quite clean and understandable, but there are some potential issues that I found while looking at it:

  1. Error handling: There are several places where .unwrap() is used, which can panic if the function returns an Err. Instead of using unwrap(), consider using proper error handling mechanisms such as propagating the error using the ? operator or pattern matching with match. This will allow for more graceful handling of errors and prevent the application from crashing unexpectedly.

For instance,

let image_format_detected = detected.unwrap();

can be replaced by:

let image_format_detected = detected.map_err(|_| "Failed to detect image format")?;
  1. State POST request: In the /v1.0/state/statestore POST request, the POST body br#"[{ "key": "name", "value": "Bruce"}]"# is hardcoded. You might want to parse the incoming request body into JSON and then forward the JSON content to the state-store URL. This would provide a more dynamic and useful implementation for the clients.

  2. Lack of comments: Though the code is quite readable, adding some comments for the different parts and functions of the code would make it easier for others to understand the purpose and expected behaviors.

  3. Port number: The port number 9005 is hard-coded in the main function. You can consider making this configurable via command-line arguments, environment variables, or a configuration file. This would make it more convenient in case the port needs to be changed in deployment.

  4. Image format handling: Current handling of image formats is limited to GIF and PNG. You might want to handle more formats (like JPEG) or provide proper error handling for unsupported formats.

Other than these potential issues, the code is well-structured, and the use of Rust 2018 idioms and asynchronous handling with hyper and tokio are well-applied. Good job!

The key changes in the provided patch are as follows:

  1. The grayscale function's return type has changed from Result<Response<Body>, hyper::Error> to Result<Response<Body>, Box<dyn std::error::Error + Send + Sync>>. This allows for better error handling by wrapping different types of errors with a trait object.

  2. The logic within the (&Method::POST, "/v1.0/state/statestore") arm of the match statement has been modified. The previous implementation was using WasmEdgeRequest, which has been removed, and now it uses hyper's Client.

  3. The hardcoded POST body used for posting data to the state store endpoint has been defined as a constant POST_BODY: &[u8].

  4. A new asynchronous function, post_url_return_str, has been introduced. This function takes a URL and POST body, posts the provided data using hyper's Client, and prints the response from the server. This function, when called, replaces the removed WasmEdgeRequest functionality.

Overall, the changes simplify the code and adapt it to use hyper's functionality instead of the removed WasmEdgeRequest.

cc second-state/dapr-wasm#42

@juntao
Copy link
Contributor Author

juntao commented Apr 25, 2023

flows summarize

Copy link
Contributor Author

juntao commented Apr 25, 2023

Hello, I am a code review bot on flows.network. Here are my reviews of code commits in this PR.


Overall, the GitHub Pull Request focuses on two main areas: updating the README file and improving the source code quality.

Potential issues and errors:

  1. The patch adds a new document in the image-api-wasi-socket-rs directory - users might want to ensure their environment supports the specified HTTPS features before following the instructions. However, no functional changes or potential problems are introduced by the patch itself.
  2. By enabling the "full" feature set for hyper in the source code, it may introduce additional dependencies and a larger binary size. It could be better to only enable the necessary features.
  3. The updated error handling in the grayscale function is more generic, which can make handling errors more flexible, but it may also make it more difficult to pinpoint specific issues.

Most important findings:

  1. The updated README file provides instructions on using new features related to calling Dapr API within the WasmEdge Sandbox Environment and handling HTTPS URLs.
  2. Rust idioms are updated with the addition of #![deny(warnings)] and #![warn(rust_2018_idioms)] in src/main.rs, promoting code maintainability.
  3. The grayscale function has been refactored, optimizing error handling and replacing the previous method of making POST requests to the state store with a new post_url_return_str async function. This modification improves the code quality and maintainability.

Details

Commit 86949149ba5da52d5fc09c00dcb4edee08ffe5b4

This GitHub patch adds a new document, specifically a README file, in the image-api-wasi-socket-rs directory.

Key changes:

  1. The README file includes instructions on using new features related to calling Dapr API within the WasmEdge Sandbox Environment. It provides a link to the Dapr state API document.
  2. It provides a note about handling HTTPS URLs by enabling the appropriate feature in the wasmedge_http_req crate and the httpsreq plugin.
  3. The instructions explain how to build, start the WasmEdge microservice, and save a new state object to Dapr by providing sample commands and their descriptions.

Potential problems:

  • Since the patch only adds new instructions in a README file, there don't seem to be any functional changes or potential problems in the patch content itself. However, users might want to ensure their environment supports the specified HTTPS features before following the instructions.
  • There might be typos, or the instructions might need to be updated in the future, but these shouldn't cause any immediate issues.

Commit 4bd514368317cdd55efe6eb5fa08a86b5ff40cb2

Summary of key changes:

  1. Added #![deny(warnings)] and #![warn(rust_2018_idioms)] at the beginning of src/main.rs, which will warn and deny outdated Rust idioms.
  2. Changed the features enabled for hyper dependency in Cargo.toml, enabling its "full" feature set.
  3. Updated the error handling in the grayscale function to return a Box<dyn std::error::Error + Send + Sync> rather than a hyper::Error.
  4. Replaced the previous way of making POST requests to the state store in the grayscale function with a new post_url_return_str async function. This new function uses hyper's Client to make the POST request instead of WasmEdgeRequest.
  5. Refactored the grayscale function, removing the now-unnecessary code related to making the POST request after adding the post_url_return_str function.

Potential problems:

  1. By enabling the "full" feature set for hyper, it may introduce additional dependencies and a larger binary size. It could be better to only enable the necessary features.
  2. The error handling in the grayscale function returns a more generic error type. While this can make handling errors more flexible, it could also make it more difficult to pinpoint specific issues.

cc second-state/dapr-wasm#42

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

1 participant