-
Notifications
You must be signed in to change notification settings - Fork 11
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
UPSTREAM: <carry>: Update ArtifactView enum to allow pipelines artifacts api to have optional content disposition #118
base: master
Are you sure you want to change the base?
Conversation
[APPROVALNOTIFIER] This PR is NOT APPROVED This pull-request has been approved by: The full list of commands accepted by this bot can be found here.
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
Commit Checker results:
|
f80f861
to
74d1b1f
Compare
Commit Checker results:
|
Commit Checker results:
|
c4e69f8
to
35108ee
Compare
Commit Checker results:
|
Commit Checker results:
|
35108ee
to
a2234ba
Compare
Commit Checker results:
|
e246405
to
560543d
Compare
Commit Checker results:
|
Commit Checker results:
|
Change to PR detected. A new PR build was completed. |
1 similar comment
Change to PR detected. A new PR build was completed. |
Commit Checker results:
|
Change to PR detected. A new PR build was completed. |
Commit Checker results:
|
Commit Checker results:
|
Change to PR detected. A new PR build was completed. |
1 similar comment
Change to PR detected. A new PR build was completed. |
Commit Checker results:
|
Change to PR detected. A new PR build was completed. |
37e68e1
to
1385dce
Compare
Commit Checker results:
|
Change to PR detected. A new PR build was completed. |
Commit Checker results:
|
Change to PR detected. A new PR build was completed. |
b0d161c
to
03a51c2
Compare
Commit Checker results:
|
Change to PR detected. A new PR build was completed. |
Commit Checker results:
|
Change to PR detected. A new PR build was completed. |
…s api to have optional content disposition Signed-off-by: VaniHaripriya <[email protected]>
2e5fc93
to
41d6864
Compare
Commit Checker results:
|
Change to PR detected. A new PR build was completed. |
@VaniHaripriya both URLs took me to the very same screen. Is that the expected result? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
/lgtm
as long as #118 (comment) is the expected result.
/hold for #118 (comment) |
/unhold |
@@ -41,6 +41,7 @@ type ObjectStoreInterface interface { | |||
GetFromYamlFile(o interface{}, filePath string) error | |||
GetPipelineKey(pipelineId string) string | |||
GetSignedUrl(bucketConfig *objectstore.Config, secret *v1.Secret, expirySeconds time.Duration, artifactURI string) (string, error) | |||
GetSignedUrlWithoutContentDisposition(bucketConfig *objectstore.Config, secret *v1.Secret, expirySeconds time.Duration, artifactURI string) (string, error) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could we make this more configurable? For example, the following would allow further customizations without having to add a new method for each variation.
GetSignedUrlWithoutContentDisposition(bucketConfig *objectstore.Config, secret *v1.Secret, expirySeconds time.Duration, artifactURI string) (string, error) | |
GetSignedUrlWithQueryParams(bucketConfig *objectstore.Config, secret *v1.Secret, expirySeconds time.Duration, artifactURI string, queryParams url.Values) |
@@ -143,6 +144,27 @@ func (m *MinioObjectStore) GetSignedUrl(bucketConfig *objectstore.Config, secret | |||
return "", err | |||
} | |||
reqParams := make(url.Values) | |||
reqParams.Set("response-content-disposition", "attachment; filename=\""+key+"\"") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If you go with my comment of having the method GetSignedUrlWithQueryParams(bucketConfig *objectstore.Config, secret *v1.Secret, expirySeconds time.Duration, artifactURI string, queryParams url.Values)
, then you can just have GetSignedUrl
wrap GetSignedUrlWithQueryParams
and pass the content disposition to queryParams
.
This will reduce code duplication.
@@ -212,6 +215,7 @@ func (s *ArtifactServer) generateResponseArtifact( | |||
bucketConfig *objectstore.Config, | |||
namespace string, | |||
includeShareUrl bool, | |||
includeRenderUrl bool, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Optional, but rather than a bool, you could replace includeShareUrl
and includeRenderUrl
with a single argument of type GetArtifactRequest_ArtifactView
since it doesn't seem like this will ever need to generate more than one. This would allow for additional options in the future.
return signedUrl.String(), nil | ||
} | ||
|
||
func (m *MinioObjectStore) GetSignedUrlWithoutContentDisposition(bucketConfig *objectstore.Config, secret *v1.Secret, expirySeconds time.Duration, artifactURI string) (string, error) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What's the plan for test coverage of this method since the tests I see are mocking this out? Is this a separate task for an integration test?
Description of your changes:
This PR resolves # RHOAIENG-12014
Testing Instructions:
quay.io/opendatahub/ds-pipelines-api-server:pr-118
}
```
Open the render_url in a browser to view a preview of the artifact.
Checklist: