Uploaded image for project: 'Document Management System'
  1. Document Management System
  2. DMS-1875

CBAT: API response codes. Activate and Deactivate company

    Details

    • Type: New Feature
    • Status: To Do
    • Priority: High
    • Resolution: Unresolved
    • Affects Version/s: None
    • Labels:
      None

      Description

      "Activate and Deactivate company" section and about API response codes. We need to differentiate when a company exists vs invalid payload content. Currently, both cases return 400 code which is not compliant with HTTP standards

        Attachments

          Activity

          samir Samir created issue -
          samir Samir made changes -
          Field Original Value New Value
          Fix Version/s Between Fall and Winter 2019 [ 10919 ]
          samir Samir made changes -
          Epic Link DMS-473 [ 75966 ]
          Hide
          samir Samir added a comment -
          Show
          samir Samir added a comment - Joris Berthelot
          samir Samir made changes -
          Assignee Samir [ samir ] Rohan J Khandave [ rohan.khandave ]
          Hide
          rohan.khandave Rohan J Khandave (Inactive) added a comment - - edited

          API Details :

          PUT : /api/companyStatus?isActive=true

          Company account-did needs to pass into header.

          As per current implementation system returning bad request code (400) in below scenarios

          1. Account did not exists into DMS System.[This is validation in system for all API]
          2. Company already activated / deactivated , still user want to perform same operation.
          3. Active company with same name already exists.

          We need to change status response to conflict in for point 2 & 3 scenarios only.

          Note: No changes required for scenario 1.

          CC – Joris Berthelot , Samir

          Show
          rohan.khandave Rohan J Khandave (Inactive) added a comment - - edited API Details : PUT : /api/companyStatus?isActive=true Company account-did needs to pass into header. As per current implementation system returning bad request code (400) in below scenarios Account did not exists into DMS System. [This is validation in system for all API] Company already activated / deactivated , still user want to perform same operation. Active company with same name already exists. We need to change status response to conflict in for point 2 & 3 scenarios only. Note: No changes required for scenario 1. CC – Joris Berthelot  , Samir
          rohan.khandave Rohan J Khandave (Inactive) made changes -
          Sprint DMS - Gap Fall & Win Sprint 3 [ 177 ]
          Remaining Estimate 4h [ 14400 ]
          Original Estimate 4h [ 14400 ]
          Ganesh.sadawarte Ganesh Sadawarte (Inactive) made changes -
          Assignee Rohan J Khandave [ rohan.khandave ] Raj Hawaldar [ raj.hawaldar ]
          Joris.Berthelot Joris Berthelot (Inactive) made changes -
          Assignee Raj Hawaldar [ raj.hawaldar ] Joris Berthelot [ joris.berthelot ]
          Hide
          Joris.Berthelot Joris Berthelot (Inactive) added a comment -

           Hi Rohan J Khandave,

          I believe scenario 1 should return 404 code instead of 400. 400 would mean the request is malformed which is not the case... 404 means the resource does not exist.

          However, if the account did header (or any required data) is not passed, it should return a 400 error.

          Scenario 2 & 3 should, IMO, always return 200 (or 202 if the action if delayed), unless some internal error occurs and, thus should return a 5xx error.

          Thanks!

          Show
          Joris.Berthelot Joris Berthelot (Inactive) added a comment -  Hi Rohan J Khandave , I believe scenario 1 should return 404 code instead of 400. 400 would mean the request is malformed which is not the case... 404 means the resource does not exist. However, if the account did header (or any required data) is not passed, it should return a 400 error. Scenario 2 & 3 should, IMO, always return 200 (or 202 if the action if delayed), unless some internal error occurs and, thus should return a 5xx error. Thanks!
          Hide
          rohan.khandave Rohan J Khandave (Inactive) added a comment -

          Hello Joris Berthelot,

          You are right , account-did is required in header. If it not passed or wrong input comes we show 400 error.

          Regarding point 2 & 3 ,

          • We can not pass 202 because all API are synchronous in execution.
          • For server error we always returns 500 as status code.
          • You needed status code 200 even if API returns some validation message to user , please confirm this ?

          Thanks,
          RohanK

          CC – Samir
           

          Show
          rohan.khandave Rohan J Khandave (Inactive) added a comment - Hello Joris Berthelot , You are right , account-did is required in header. If it not passed or wrong input comes we show 400 error. Regarding point 2 & 3 , We can not pass 202 because all API are synchronous in execution. For server error we always returns 500 as status code. You needed status code 200 even if API returns some validation message to user , please confirm this ? Thanks, RohanK CC – Samir  
          shashikant.mishra ShashiKant Mishra (Inactive) made changes -
          Sprint DMS - Gap Fall & Win Sprint 3 [ 177 ] DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4 [ 177, 179 ]
          Hide
          Joris.Berthelot Joris Berthelot (Inactive) added a comment -

          Hi Rohan J Khandave,

          Could you explain "You needed status code 200 even if API returns some validation message to user , please confirm this ?"?

          Maybe provide some example?

          Thanks!

          Show
          Joris.Berthelot Joris Berthelot (Inactive) added a comment - Hi Rohan J Khandave , Could you explain "You needed status code 200 even if API returns some validation message to user , please confirm this ?"? Maybe provide some example? Thanks!
          samir Samir made changes -
          Assignee Joris Berthelot [ joris.berthelot ] Rohan J Khandave [ rohan.khandave ]
          Hide
          rohan.khandave Rohan J Khandave (Inactive) added a comment -

          Hello Joris Berthelot,

          Currently API returns bad request in below scenarios

          1. Company already activated / deactivated , still user want to perform same operation.
          2. Active company with same name already exists.

          We are changing response code from Bad Request (400) to Conflict (409) , are you fine with this ? Or you want to OK (200) status for above mentioned scenarios. So we can do changes accordingly.

          Thanks,
          RohanK

          Show
          rohan.khandave Rohan J Khandave (Inactive) added a comment - Hello Joris Berthelot , Currently API returns bad request in below scenarios Company already activated / deactivated , still user want to perform same operation. Active company with same name already exists. We are changing response code from Bad Request (400) to Conflict (409) , are you fine with this ? Or you want to OK (200) status for above mentioned scenarios. So we can do changes accordingly. Thanks, RohanK
          rohan.khandave Rohan J Khandave (Inactive) made changes -
          Assignee Rohan J Khandave [ rohan.khandave ] Joris Berthelot [ joris.berthelot ]
          Hide
          Joris.Berthelot Joris Berthelot (Inactive) added a comment -

          Hi Rohan J Khandave,

          PUT HTTP verb is supposed to be idempotent so if you proceed the same call multiple time, the result should be the same: always return the same success response (200) unless an error occurs.

          https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods/PUT

          Applying several times the same  activation state is not a conflictual IMO and should be allowed.

          Does this make sense to you?

          Show
          Joris.Berthelot Joris Berthelot (Inactive) added a comment - Hi Rohan J Khandave , PUT HTTP verb is supposed to be idempotent so if you proceed the same call multiple time, the result should be the same: always return the same success response (200) unless an error occurs. https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods/PUT Applying several times the same  activation state is not a conflictual IMO and should be allowed. Does this make sense to you?
          rohan.khandave Rohan J Khandave (Inactive) made changes -
          Assignee Joris Berthelot [ joris.berthelot ] Rohan J Khandave [ rohan.khandave ]
          Hide
          rohan.khandave Rohan J Khandave (Inactive) added a comment -

          Hello Joris Berthelot,

          Thanks for sharing details.

          We will do the changes at our end and return 200 status in below scenarios.

          1. Activate already active company.
          2. Deactivate already deactivate company.

          There is no change in below scenarios, currently API returns Bad Request.

          1. Company not found.
          2. When user try to activate already deactivated and in system another active company exists with same name.

          Shamooka Mohapatra , please let us know if any changes needed at your end for above changes ? if no then we can start this change at our end.

          Thanks,
          RohanK

          Show
          rohan.khandave Rohan J Khandave (Inactive) added a comment - Hello Joris Berthelot , Thanks for sharing details. We will do the changes at our end and return 200 status in below scenarios. Activate already active company. Deactivate already deactivate company. There is no change in below scenarios, currently API returns Bad Request. Company not found. When user try to activate already deactivated and in system another active company exists with same name. Shamooka Mohapatra , please let us know if any changes needed at your end for above changes ? if no then we can start this change at our end. Thanks, RohanK
          rohan.khandave Rohan J Khandave (Inactive) made changes -
          Assignee Rohan J Khandave [ rohan.khandave ] Shamooka Mohapatra [ shamooka.mohapatra ]
          Hide
          Joris.Berthelot Joris Berthelot (Inactive) added a comment -

          Hi Rohan J Khandave,

          When a company is not found, it should return 404, not 400. That's the original request of this card

          When user try to activate already deactivated and in system another active company exists with same name

          I'm not sure to understand what you wrote here....

          Thanks!

           

          Show
          Joris.Berthelot Joris Berthelot (Inactive) added a comment - Hi Rohan J Khandave , When a company is not found, it should return 404, not 400. That's the original request of this card When user try to activate already deactivated and in system another active company exists with same name I'm not sure to understand what you wrote here.... Thanks!  
          Hide
          rohan.khandave Rohan J Khandave (Inactive) added a comment - - edited

          Hello Joris Berthelot,

           When user try to activate already deactivated and in system another active company exists with same name

          DMS has validation , company name must be unique for active companies, system validate company names among all active companies. So when some one try to activate company system validate any other active company has same name or not.

           When a company is not found, it should return 404, not 400. That's the original request of this card.

          We get account did into header ,we try to validate those header value when validation fails , returns bad request. If you still want to return Not Found (404). We can take this change. But this change will get applicable for all DMS API's.

          Thanks,
          RohanK

          Show
          rohan.khandave Rohan J Khandave (Inactive) added a comment - - edited Hello Joris Berthelot ,  When user try to activate already deactivated and in system another active company exists with same name DMS has validation , company name must be unique for active companies, system validate company names among all active companies. So when some one try to activate company system validate any other active company has same name or not.  When a company is not found, it should return 404, not 400. That's the original request of this card. We get account did into header ,we try to validate those header value when validation fails , returns bad request. If you still want to return Not Found (404). We can take this change. But this change will get applicable for all DMS API's. Thanks, RohanK
          Hide
          Joris.Berthelot Joris Berthelot (Inactive) added a comment - - edited

          Hi Rohan J Khandave,

          We get account did into header ,we try to validate those header value when validation fails , returns bad request. If you still want to return Not Found (404). We can take this change. But this change will get applicable for all DMS API's.

          Validation means user data input validation: if data is missing, empty, null, zero, not parseable, etc. -> return 400.

          If the data format is valid but when looking up into your database, there's no match -> return 404.

          This behavior should be indeed enforce on all API endpoints. There is very strong difference between "invalid input" and "missing requested resource".

          DMS has validation , company name must be unique for active companies, system validate company names among all active companies. So when some one try to activate company system validate any other active company has same name or not.

          This is a weird logic but why not. That case should return 409 and then we will ignore on our side meaning the company has been already deactivated.

          Thanks for your patience!

          Show
          Joris.Berthelot Joris Berthelot (Inactive) added a comment - - edited Hi Rohan J Khandave , We get account did into header ,we try to validate those header value when validation fails , returns bad request. If you still want to return Not Found (404). We can take this change. But this change will get applicable for all DMS API's. Validation means user data input validation: if data is missing, empty, null, zero, not parseable, etc. -> return 400. If the data format is valid but when looking up into your database, there's no match -> return 404. This behavior should be indeed enforce on all API endpoints. There is very strong difference between "invalid input" and "missing requested resource". DMS has validation , company name must be unique for active companies, system validate company names among all active companies. So when some one try to activate company system validate any other active company has same name or not. This is a weird logic but why not. That case should return 409 and then we will ignore on our side meaning the company has been already deactivated. Thanks for your patience!
          rohan.khandave Rohan J Khandave (Inactive) logged work - 19/Sep/19 07:06 AM
          • Time Spent:
            3h
             

            Analysis
            Reply to comments
            Coding
            Testng

          rohan.khandave Rohan J Khandave (Inactive) made changes -
          Remaining Estimate 4h [ 14400 ] 1h [ 3600 ]
          Time Spent 3h [ 10800 ]
          Worklog Id 201301 [ 201301 ]
          shashikant.mishra ShashiKant Mishra (Inactive) made changes -
          Sprint DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4 [ 177, 179 ] DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4, DMS - Gap Fall & Win Sprint 5 [ 177, 179, 181 ]
          narendra.kumar Narendra Kumar made changes -
          Fix Version/s Winter 2020 CBAT Integration [ 11316 ]
          Fix Version/s Between Fall and Winter 2019 [ 10919 ]
          narendra.kumar Narendra Kumar made changes -
          Sprint DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4, DMS - Gap Fall & Win Sprint 5 [ 177, 179, 181 ] DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4 [ 177, 179 ]
          narendra.kumar Narendra Kumar made changes -
          Sprint DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4 [ 177, 179 ] DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4, Winter-2020 Sprint 1 [ 177, 179, 183 ]
          samir Samir made changes -
          Sprint DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4, Winter-2020 Sprint 1 [ 177, 179, 183 ] DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4 [ 177, 179 ]
          Hide
          Joris.Berthelot Joris Berthelot (Inactive) added a comment -

          Hi Samir,

          I see this card is being spilled over again and again from a sprint to another. Can we get this done asap please?

          Thanks,

          cc. Amrendra Kumar

          Show
          Joris.Berthelot Joris Berthelot (Inactive) added a comment - Hi  Samir , I see this card is being spilled over again and again from a sprint to another. Can we get this done asap please? Thanks, cc. Amrendra Kumar
          narendra.kumar Narendra Kumar made changes -
          Assignee Shamooka Mohapatra [ shamooka.mohapatra ] Narendra Kumar [ narendra.kumar ]
          samir Samir made changes -
          Description "Activate and Deactivate company" section and about API response codes. We need to differentiate when a company exists vs invalid payload content. Currently, both cases return 400 code which is not compliant with HTTP standards. "Activate and Deactivate company" section and about API response codes. We need to differentiate when a company exists vs invalid payload content. Currently, both cases return 400 code which is not compliant with HTTP standards
          Hide
          Joris.Berthelot Joris Berthelot (Inactive) added a comment -

          Any update on this, please?

          cc Amrendra Kumar

          Show
          Joris.Berthelot Joris Berthelot (Inactive) added a comment - Any update on this, please? cc Amrendra Kumar
          narendra.kumar Narendra Kumar made changes -
          Sprint DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4 [ 177, 179 ] DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4, Spring-2020 - Sprint 3 [ 177, 179, 199 ]
          Hide
          samir Samir added a comment -

          Hi Joris Berthelot,

          Can we have a call to discuss this. Please let me know your availability?

          Regards,

          Samir

          Show
          samir Samir added a comment - Hi Joris Berthelot , Can we have a call to discuss this. Please let me know your availability? Regards, Samir
          narendra.kumar Narendra Kumar made changes -
          Sprint DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4, Spring-2020 - Sprint 3 [ 177, 179, 199 ] DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4, Spring-2020 - Sprint 3, Spring-2020 - Sprint 4 [ 177, 179, 199, 200 ]
          narendra.kumar Narendra Kumar made changes -
          Sprint DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4, Spring-2020 - Sprint 3, Spring-2020 - Sprint 4 [ 177, 179, 199, 200 ] DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4, Spring-2020 - Sprint 3, Spring-2020 - Sprint 4, Spring-2020 - Sprint 5 [ 177, 179, 199, 200, 202 ]
          narendra.kumar Narendra Kumar made changes -
          Assignee Narendra Kumar [ narendra.kumar ] Samir [ samir ]
          narendra.kumar Narendra Kumar made changes -
          Sprint DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4, Spring-2020 - Sprint 3, Spring-2020 - Sprint 4, Spring-2020 - Sprint 5 [ 177, 179, 199, 200, 202 ] DMS - Gap Fall & Win Sprint 3, DMS - Gap Fall & Win Sprint 4, Spring-2020 - Sprint 3, Spring-2020 - Sprint 4, Spring-2020 - Sprint 5, Spring-2020 - Sprint 6 [ 177, 179, 199, 200, 202, 203 ]
          Hide
          Joris.Berthelot Joris Berthelot (Inactive) added a comment -

          Hello,

          Has this card been fixed already? Because I'm getting 404 now when a system seems to not exist. Could you confirm?

          Thanks!

          Show
          Joris.Berthelot Joris Berthelot (Inactive) added a comment - Hello, Has this card been fixed already? Because I'm getting 404 now when a system seems to not exist. Could you confirm? Thanks!

            People

            Assignee:
            samir Samir
            Reporter:
            samir Samir
            Votes:
            0 Vote for this issue
            Watchers:
            2 Start watching this issue

              Dates

              Created:
              Updated:

                Time Tracking

                Estimated:
                Original Estimate - 4h
                4h
                Remaining:
                Time Spent - 3h Remaining Estimate - 1h
                1h
                Logged:
                Time Spent - 3h Remaining Estimate - 1h
                3h