You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

61 lines
2.0 KiB

  1. /*
  2. * This program source code file is part of KiCad, a free EDA CAD application.
  3. *
  4. * Copyright (C) 2023 Jon Evans <jon@craftyjon.com>
  5. * Copyright (C) 2023 KiCad Developers, see AUTHORS.txt for contributors.
  6. *
  7. * This program is free software: you can redistribute it and/or modify it
  8. * under the terms of the GNU General Public License as published by the
  9. * Free Software Foundation, either version 3 of the License, or (at your
  10. * option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful, but
  13. * WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License along
  18. * with this program. If not, see <http://www.gnu.org/licenses/>.
  19. */
  20. #include <api/api_handler.h>
  21. #include <wx/wx.h>
  22. using kiapi::common::ApiRequest, kiapi::common::ApiResponse, kiapi::common::ApiResponseStatus;
  23. const wxString API_HANDLER::m_defaultCommitMessage = _( "Modification from API" );
  24. API_RESULT API_HANDLER::Handle( ApiRequest& aMsg )
  25. {
  26. ApiResponseStatus status;
  27. if( !aMsg.has_message() )
  28. {
  29. status.set_status( ApiStatusCode::AS_BAD_REQUEST );
  30. status.set_error_message( "request has no inner message" );
  31. return tl::unexpected( status );
  32. }
  33. std::string typeName;
  34. if( !google::protobuf::Any::ParseAnyTypeUrl( aMsg.message().type_url(), &typeName ) )
  35. {
  36. status.set_status( ApiStatusCode::AS_BAD_REQUEST );
  37. status.set_error_message( "could not parse inner message type" );
  38. return tl::unexpected( status );
  39. }
  40. auto it = m_handlers.find( typeName );
  41. if( it != m_handlers.end() )
  42. {
  43. REQUEST_HANDLER& handler = it->second;
  44. return handler( aMsg );
  45. }
  46. status.set_status( ApiStatusCode::AS_UNHANDLED );
  47. // This response is used internally; no need for an error message
  48. return tl::unexpected( status );
  49. }