blob: 8625c63e5e81e3debe85e6a0f2d4860228b1bdb9 [file] [log] [blame]
AppaRao Puli5e44e3d2021-03-16 15:37:24 +00001#pragma once
2
Ed Tanousf80a87f2024-06-16 12:10:33 -07003#include "filter_expr_executor.hpp"
Ed Tanous5b904292024-04-16 11:10:17 -07004#include "privileges.hpp"
5#include "registries/privilege_registry.hpp"
6
AppaRao Puli5e44e3d2021-03-16 15:37:24 +00007#include <app.hpp>
8#include <event_service_manager.hpp>
9
Ed Tanous5b904292024-04-16 11:10:17 -070010#include <memory>
11#include <string>
12
AppaRao Puli5e44e3d2021-03-16 15:37:24 +000013namespace redfish
14{
15
Ed Tanousf80a87f2024-06-16 12:10:33 -070016inline void createSubscription(crow::sse_socket::Connection& conn,
17 const crow::Request& req)
AppaRao Puli5e44e3d2021-03-16 15:37:24 +000018{
19 EventServiceManager& manager =
20 EventServiceManager::getInstance(&conn.getIoContext());
21 if ((manager.getNumberOfSubscriptions() >= maxNoOfSubscriptions) ||
22 manager.getNumberOfSSESubscriptions() >= maxNoOfSSESubscriptions)
23 {
Ed Tanous62598e32023-07-17 17:06:25 -070024 BMCWEB_LOG_WARNING("Max SSE subscriptions reached");
AppaRao Puli5e44e3d2021-03-16 15:37:24 +000025 conn.close("Max SSE subscriptions reached");
26 return;
27 }
Ed Tanousf80a87f2024-06-16 12:10:33 -070028
29 std::optional<filter_ast::LogicalAnd> filter;
30
31 boost::urls::params_base::iterator filterIt =
32 req.url().params().find("$filter");
33
34 if (filterIt != req.url().params().end())
35 {
36 std::string_view filterValue = (*filterIt).value;
37 filter = parseFilter(filterValue);
38 if (!filter)
39 {
40 conn.close(std::format("Bad $filter param: {}", filterValue));
41 return;
42 }
43 }
44
45 std::string lastEventId(req.getHeaderValue("Last-Event-Id"));
46
Ed Tanous4b712a22023-08-02 12:56:52 -070047 std::shared_ptr<Subscription> subValue =
48 std::make_shared<Subscription>(conn);
AppaRao Puli5e44e3d2021-03-16 15:37:24 +000049
Myung Bae5fe4ef32024-10-19 09:56:02 -040050 if (subValue->userSub == nullptr)
51 {
52 BMCWEB_LOG_ERROR("Subscription data is null");
53 conn.close("Internal Error");
54 return;
55 }
AppaRao Puli5e44e3d2021-03-16 15:37:24 +000056
Myung Bae5fe4ef32024-10-19 09:56:02 -040057 // GET on this URI means, Its SSE subscriptionType.
58 subValue->userSub->subscriptionType = redfish::subscriptionTypeSSE;
59
60 subValue->userSub->protocol = "Redfish";
61 subValue->userSub->retryPolicy = "TerminateAfterRetries";
62 subValue->userSub->eventFormatType = "Event";
AppaRao Puli5e44e3d2021-03-16 15:37:24 +000063
Ed Tanousf80a87f2024-06-16 12:10:33 -070064 std::string id = manager.addSSESubscription(subValue, lastEventId);
AppaRao Puli5e44e3d2021-03-16 15:37:24 +000065 if (id.empty())
66 {
67 conn.close("Internal Error");
68 }
69}
70
71inline void deleteSubscription(crow::sse_socket::Connection& conn)
72{
73 redfish::EventServiceManager::getInstance(&conn.getIoContext())
74 .deleteSseSubscription(conn);
75}
76
77inline void requestRoutesEventServiceSse(App& app)
78{
79 // Note, this endpoint is given the same privilege level as creating a
80 // subscription, because functionally, that's the operation being done
81 BMCWEB_ROUTE(app, "/redfish/v1/EventService/SSE")
82 .privileges(redfish::privileges::postEventDestinationCollection)
83 .serverSentEvent()
84 .onopen(createSubscription)
85 .onclose(deleteSubscription);
86}
87} // namespace redfish