-
Notifications
You must be signed in to change notification settings - Fork 8.3k
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
[ResponseOps] [Cases] Attach file to case API #198377
Conversation
Pinging @elastic/response-ops (Team:ResponseOps) |
Pinging @elastic/response-ops-cases (Feature:Cases) |
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.
Great work! I left some comments.
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.
Thanks for addressing the comments. I left some minor comments.
x-pack/test/cases_api_integration/security_and_spaces/tests/common/files/post_file.ts
Outdated
Show resolved
Hide resolved
660c1ce
to
650289f
Compare
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.
Great work!!
expect(clientArgs.fileService.delete).toHaveBeenCalledWith({ id }); | ||
}); | ||
|
||
it('calls buildAttachmentRequestFromFileJSON with the correct params', async () => { |
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.
nit: What do you think instead of mocking buildAttachmentRequestFromFileJSONMock
to check if the attachmentService
was called with the correct args?
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.
That was my initial idea but we don't call attachmentService directly. We do:
const model = await CaseCommentModel.create(caseId, clientArgs);
const updatedModel = await model.createComment({
createdDate,
commentReq,
id: savedObjectID,
});
```
And I was losing too much time trying to mock this properly so I just wanted to ensure we build the request correctly.
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 follow model.createComment
you will see that it uses the attachment service to create the attachment. No need to mock the model
.
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.
ah cool, I was wondering why you wrote attachmentService
since I don't use that in add_file
💛 Build succeeded, but was flaky
Failed CI StepsMetrics [docs]Async chunks
Page load bundle
Unknown metric groupsESLint disabled line counts
Total ESLint disabled count
History
cc @adcoelho |
Starting backport for target branches: 8.x https://github.com/elastic/kibana/actions/runs/11842007941 |
💔 All backports failed
Manual backportTo create the backport manually run:
Questions ?Please refer to the Backport tool documentation |
Fixes elastic#22832 ## Summary This PR adds the possibility of adding Files/Attachments to Case in Kibana via an API call. ### How to test The new API URL is `https://localhost:5601/api/cases/<CASE_ID>/files`. You can either use postman or curl to test. 1. Start by creating a case. 2. Call the new API ``` curl --location 'https://localhost:5601/api/cases/<CASE_ID>/files' \ --header 'kbn-xsrf: true' \ --header 'Authorization: Basic ZWxhc3RpYzpjaGFuZ2VtZQ==' \ --form 'filename="Notice"' \ --form 'mimeType="text/plain"' \ --form 'file=@"<FULL_PATH_TO_THE_FILE_YOU_WANT_TO_UPLOAD>"' ``` <img width="1090" alt="Screenshot 2024-10-30 at 15 41 26" src="https://github.com/user-attachments/assets/b018f92d-2603-4bf1-ac12-f01452f35303"> 3. Confirm the user action was created. <img width="383" alt="Screenshot 2024-10-30 at 15 48 45" src="https://github.com/user-attachments/assets/04952b8f-e8fb-4f19-a72f-54030f496fe9"> 4. Confirm the file exists in the case and: - it can be downloaded as expected. - it can be previewed as expected(not every MIME type allows this). ### Release Notes Files can now be attached to cases directly via API. --------- Co-authored-by: kibanamachine <[email protected]> Co-authored-by: lcawl <[email protected]>
💚 All backports created successfully
Note: Successful backport PRs will be merged automatically after passing CI. Questions ?Please refer to the Backport tool documentation |
Fixes elastic#22832 ## Summary This PR adds the possibility of adding Files/Attachments to Case in Kibana via an API call. ### How to test The new API URL is `https://localhost:5601/api/cases/<CASE_ID>/files`. You can either use postman or curl to test. 1. Start by creating a case. 2. Call the new API ``` curl --location 'https://localhost:5601/api/cases/<CASE_ID>/files' \ --header 'kbn-xsrf: true' \ --header 'Authorization: Basic ZWxhc3RpYzpjaGFuZ2VtZQ==' \ --form 'filename="Notice"' \ --form 'mimeType="text/plain"' \ --form 'file=@"<FULL_PATH_TO_THE_FILE_YOU_WANT_TO_UPLOAD>"' ``` <img width="1090" alt="Screenshot 2024-10-30 at 15 41 26" src="https://github.com/user-attachments/assets/b018f92d-2603-4bf1-ac12-f01452f35303"> 3. Confirm the user action was created. <img width="383" alt="Screenshot 2024-10-30 at 15 48 45" src="https://github.com/user-attachments/assets/04952b8f-e8fb-4f19-a72f-54030f496fe9"> 4. Confirm the file exists in the case and: - it can be downloaded as expected. - it can be previewed as expected(not every MIME type allows this). ### Release Notes Files can now be attached to cases directly via API. --------- Co-authored-by: kibanamachine <[email protected]> Co-authored-by: lcawl <[email protected]> (cherry picked from commit e2702ff) # Conflicts: # oas_docs/output/kibana.yaml
Fixes elastic#22832 ## Summary This PR adds the possibility of adding Files/Attachments to Case in Kibana via an API call. ### How to test The new API URL is `https://localhost:5601/api/cases/<CASE_ID>/files`. You can either use postman or curl to test. 1. Start by creating a case. 2. Call the new API ``` curl --location 'https://localhost:5601/api/cases/<CASE_ID>/files' \ --header 'kbn-xsrf: true' \ --header 'Authorization: Basic ZWxhc3RpYzpjaGFuZ2VtZQ==' \ --form 'filename="Notice"' \ --form 'mimeType="text/plain"' \ --form 'file=@"<FULL_PATH_TO_THE_FILE_YOU_WANT_TO_UPLOAD>"' ``` <img width="1090" alt="Screenshot 2024-10-30 at 15 41 26" src="https://github.com/user-attachments/assets/b018f92d-2603-4bf1-ac12-f01452f35303"> 3. Confirm the user action was created. <img width="383" alt="Screenshot 2024-10-30 at 15 48 45" src="https://github.com/user-attachments/assets/04952b8f-e8fb-4f19-a72f-54030f496fe9"> 4. Confirm the file exists in the case and: - it can be downloaded as expected. - it can be previewed as expected(not every MIME type allows this). ### Release Notes Files can now be attached to cases directly via API. --------- Co-authored-by: kibanamachine <[email protected]> Co-authored-by: lcawl <[email protected]>
# Backport This will backport the following commits from `main` to `8.x`: - [[ResponseOps] [Cases] Attach file to case API (#198377)](#198377) <!--- Backport version: 8.9.8 --> ### Questions ? Please refer to the [Backport tool documentation](https://github.com/sqren/backport) <!--BACKPORT [{"author":{"name":"Antonio","email":"[email protected]"},"sourceCommit":{"committedDate":"2024-11-14T17:05:11Z","message":"[ResponseOps] [Cases] Attach file to case API (#198377)\n\nFixes #22832\r\n\r\n## Summary\r\n\r\nThis PR adds the possibility of adding Files/Attachments to Case in\r\nKibana via an API call.\r\n\r\n### How to test\r\n\r\nThe new API URL is `https://localhost:5601/api/cases/<CASE_ID>/files`.\r\nYou can either use postman or curl to test.\r\n\r\n1. Start by creating a case.\r\n2. Call the new API\r\n```\r\ncurl --location 'https://localhost:5601/api/cases/<CASE_ID>/files' \\\r\n--header 'kbn-xsrf: true' \\\r\n--header 'Authorization: Basic ZWxhc3RpYzpjaGFuZ2VtZQ==' \\\r\n--form 'filename=\"Notice\"' \\\r\n--form 'mimeType=\"text/plain\"' \\\r\n--form 'file=@\"<FULL_PATH_TO_THE_FILE_YOU_WANT_TO_UPLOAD>\"'\r\n```\r\n<img width=\"1090\" alt=\"Screenshot 2024-10-30 at 15 41 26\"\r\nsrc=\"https://github.com/user-attachments/assets/b018f92d-2603-4bf1-ac12-f01452f35303\">\r\n\r\n3. Confirm the user action was created.\r\n<img width=\"383\" alt=\"Screenshot 2024-10-30 at 15 48 45\"\r\nsrc=\"https://github.com/user-attachments/assets/04952b8f-e8fb-4f19-a72f-54030f496fe9\">\r\n\r\n4. Confirm the file exists in the case and:\r\n - it can be downloaded as expected.\r\n - it can be previewed as expected(not every MIME type allows this).\r\n\r\n\r\n### Release Notes\r\n\r\nFiles can now be attached to cases directly via API.\r\n\r\n---------\r\n\r\nCo-authored-by: kibanamachine <[email protected]>\r\nCo-authored-by: lcawl <[email protected]>","sha":"e2702ff5912ec440060d62fb323a9a03c4881143","branchLabelMapping":{"^v9.0.0$":"main","^v8.17.0$":"8.x","^v(\\d+).(\\d+).\\d+$":"$1.$2"}},"sourcePullRequest":{"labels":["Team:ResponseOps","v9.0.0","Feature:Cases","release_note:feature","backport:prev-minor","v8.17.0"],"number":198377,"url":"https://github.com/elastic/kibana/pull/198377","mergeCommit":{"message":"[ResponseOps] [Cases] Attach file to case API (#198377)\n\nFixes #22832\r\n\r\n## Summary\r\n\r\nThis PR adds the possibility of adding Files/Attachments to Case in\r\nKibana via an API call.\r\n\r\n### How to test\r\n\r\nThe new API URL is `https://localhost:5601/api/cases/<CASE_ID>/files`.\r\nYou can either use postman or curl to test.\r\n\r\n1. Start by creating a case.\r\n2. Call the new API\r\n```\r\ncurl --location 'https://localhost:5601/api/cases/<CASE_ID>/files' \\\r\n--header 'kbn-xsrf: true' \\\r\n--header 'Authorization: Basic ZWxhc3RpYzpjaGFuZ2VtZQ==' \\\r\n--form 'filename=\"Notice\"' \\\r\n--form 'mimeType=\"text/plain\"' \\\r\n--form 'file=@\"<FULL_PATH_TO_THE_FILE_YOU_WANT_TO_UPLOAD>\"'\r\n```\r\n<img width=\"1090\" alt=\"Screenshot 2024-10-30 at 15 41 26\"\r\nsrc=\"https://github.com/user-attachments/assets/b018f92d-2603-4bf1-ac12-f01452f35303\">\r\n\r\n3. Confirm the user action was created.\r\n<img width=\"383\" alt=\"Screenshot 2024-10-30 at 15 48 45\"\r\nsrc=\"https://github.com/user-attachments/assets/04952b8f-e8fb-4f19-a72f-54030f496fe9\">\r\n\r\n4. Confirm the file exists in the case and:\r\n - it can be downloaded as expected.\r\n - it can be previewed as expected(not every MIME type allows this).\r\n\r\n\r\n### Release Notes\r\n\r\nFiles can now be attached to cases directly via API.\r\n\r\n---------\r\n\r\nCo-authored-by: kibanamachine <[email protected]>\r\nCo-authored-by: lcawl <[email protected]>","sha":"e2702ff5912ec440060d62fb323a9a03c4881143"}},"sourceBranch":"main","suggestedTargetBranches":["8.x"],"targetPullRequestStates":[{"branch":"main","label":"v9.0.0","labelRegex":"^v9.0.0$","isSourceBranch":true,"state":"MERGED","url":"https://github.com/elastic/kibana/pull/198377","number":198377,"mergeCommit":{"message":"[ResponseOps] [Cases] Attach file to case API (#198377)\n\nFixes #22832\r\n\r\n## Summary\r\n\r\nThis PR adds the possibility of adding Files/Attachments to Case in\r\nKibana via an API call.\r\n\r\n### How to test\r\n\r\nThe new API URL is `https://localhost:5601/api/cases/<CASE_ID>/files`.\r\nYou can either use postman or curl to test.\r\n\r\n1. Start by creating a case.\r\n2. Call the new API\r\n```\r\ncurl --location 'https://localhost:5601/api/cases/<CASE_ID>/files' \\\r\n--header 'kbn-xsrf: true' \\\r\n--header 'Authorization: Basic ZWxhc3RpYzpjaGFuZ2VtZQ==' \\\r\n--form 'filename=\"Notice\"' \\\r\n--form 'mimeType=\"text/plain\"' \\\r\n--form 'file=@\"<FULL_PATH_TO_THE_FILE_YOU_WANT_TO_UPLOAD>\"'\r\n```\r\n<img width=\"1090\" alt=\"Screenshot 2024-10-30 at 15 41 26\"\r\nsrc=\"https://github.com/user-attachments/assets/b018f92d-2603-4bf1-ac12-f01452f35303\">\r\n\r\n3. Confirm the user action was created.\r\n<img width=\"383\" alt=\"Screenshot 2024-10-30 at 15 48 45\"\r\nsrc=\"https://github.com/user-attachments/assets/04952b8f-e8fb-4f19-a72f-54030f496fe9\">\r\n\r\n4. Confirm the file exists in the case and:\r\n - it can be downloaded as expected.\r\n - it can be previewed as expected(not every MIME type allows this).\r\n\r\n\r\n### Release Notes\r\n\r\nFiles can now be attached to cases directly via API.\r\n\r\n---------\r\n\r\nCo-authored-by: kibanamachine <[email protected]>\r\nCo-authored-by: lcawl <[email protected]>","sha":"e2702ff5912ec440060d62fb323a9a03c4881143"}},{"branch":"8.x","label":"v8.17.0","labelRegex":"^v8.17.0$","isSourceBranch":false,"state":"NOT_CREATED"}]}] BACKPORT--> --------- Co-authored-by: kibanamachine <[email protected]>
Fixes elastic#22832 ## Summary This PR adds the possibility of adding Files/Attachments to Case in Kibana via an API call. ### How to test The new API URL is `https://localhost:5601/api/cases/<CASE_ID>/files`. You can either use postman or curl to test. 1. Start by creating a case. 2. Call the new API ``` curl --location 'https://localhost:5601/api/cases/<CASE_ID>/files' \ --header 'kbn-xsrf: true' \ --header 'Authorization: Basic ZWxhc3RpYzpjaGFuZ2VtZQ==' \ --form 'filename="Notice"' \ --form 'mimeType="text/plain"' \ --form 'file=@"<FULL_PATH_TO_THE_FILE_YOU_WANT_TO_UPLOAD>"' ``` <img width="1090" alt="Screenshot 2024-10-30 at 15 41 26" src="https://github.com/user-attachments/assets/b018f92d-2603-4bf1-ac12-f01452f35303"> 3. Confirm the user action was created. <img width="383" alt="Screenshot 2024-10-30 at 15 48 45" src="https://github.com/user-attachments/assets/04952b8f-e8fb-4f19-a72f-54030f496fe9"> 4. Confirm the file exists in the case and: - it can be downloaded as expected. - it can be previewed as expected(not every MIME type allows this). ### Release Notes Files can now be attached to cases directly via API. --------- Co-authored-by: kibanamachine <[email protected]> Co-authored-by: lcawl <[email protected]>
Fixes #22832
Summary
This PR adds the possibility of adding Files/Attachments to Case in Kibana via an API call.
How to test
The new API URL is
https://localhost:5601/api/cases/<CASE_ID>/files
. You can either use postman or curl to test.Release Notes
Files can now be attached to cases directly via API.