Browse Source

initial ipc dev

logicp 4 years ago
parent
commit
aa4384a5ce
4 changed files with 288 additions and 164 deletions
  1. 3 1
      include/client/client.hpp
  2. 249 151
      mainwindow.ui
  3. 17 2
      src/client.cpp
  4. 19 10
      src/mainwindow.cpp

+ 3 - 1
include/client/client.hpp

@@ -76,13 +76,15 @@ class Client : public QDialog {
   void setSelectedApp(std::vector<QString> app_names);
   void sendFiles(Scheduler::Task* task);
   void ping();
+  void sendIPCMessage(const QString& s);
 
  signals:
   void messageReceived(int t, QString s, QVector<QString> args);
   void eventReceived(int t, std::string event, StringVec args);
 
  private:
-  void sendEncoded(std::string message);
+  template <typename T>
+  void sendEncoded(T message);
   void sendFileEncoded(QByteArray bytes);
   void sendTaskEncoded(Scheduler::Task* task);
   void processFileQueue();

+ 249 - 151
mainwindow.ui

@@ -6,7 +6,7 @@
    <rect>
     <x>0</x>
     <y>0</y>
-    <width>1080</width>
+    <width>960</width>
     <height>768</height>
    </rect>
   </property>
@@ -194,21 +194,21 @@ font-weight: 700;</string>
      <rect>
       <x>10</x>
       <y>50</y>
-      <width>1061</width>
+      <width>941</width>
       <height>651</height>
      </rect>
     </property>
-    <layout class="QHBoxLayout" name="horizontalLayout_4">
+    <layout class="QHBoxLayout" name="horizontalLayout_4" stretch="1">
      <property name="sizeConstraint">
       <enum>QLayout::SetMaximumSize</enum>
      </property>
      <item>
-      <layout class="QVBoxLayout" name="verticalLayout" stretch="0,0,0">
+      <layout class="QVBoxLayout" name="verticalLayout" stretch="0,0">
        <property name="spacing">
         <number>4</number>
        </property>
        <item>
-        <layout class="QGridLayout" name="gridLayout_2" rowstretch="5" columnstretch="0,0,0">
+        <layout class="QGridLayout" name="gridLayout_2" rowstretch="0" columnstretch="3,4" columnminimumwidth="0,0">
          <property name="sizeConstraint">
           <enum>QLayout::SetNoConstraint</enum>
          </property>
@@ -216,7 +216,7 @@ font-weight: 700;</string>
           <number>0</number>
          </property>
          <item row="0" column="0">
-          <layout class="QVBoxLayout" name="verticalLayout_2" stretch="0,0,0,0,2">
+          <layout class="QVBoxLayout" name="verticalLayout_2" stretch="0,0,0,0,0,2">
            <property name="spacing">
             <number>4</number>
            </property>
@@ -246,6 +246,9 @@ font-weight: 700;</string>
            </item>
            <item>
             <widget class="QComboBox" name="appList">
+             <property name="autoFillBackground">
+              <bool>true</bool>
+             </property>
              <property name="styleSheet">
               <string notr="true">font: 87 11pt &quot;Noto Sans&quot;;
 background-color: #2f535f;
@@ -253,6 +256,37 @@ color: rgb(131, 148, 150);
 font-weight: 700;
 </string>
              </property>
+             <property name="editable">
+              <bool>true</bool>
+             </property>
+             <property name="currentText">
+              <string>Available Processes</string>
+             </property>
+            </widget>
+           </item>
+           <item>
+            <widget class="QComboBox" name="ipcList">
+             <property name="autoFillBackground">
+              <bool>true</bool>
+             </property>
+             <property name="styleSheet">
+              <string notr="true">font: 87 11pt &quot;Noto Sans&quot;;
+background-color: #2f535f;
+color: rgb(131, 148, 150);
+font-weight: 700;
+</string>
+             </property>
+             <property name="editable">
+              <bool>true</bool>
+             </property>
+             <property name="currentText">
+              <string>Get Results</string>
+             </property>
+             <item>
+              <property name="text">
+               <string>Get Results</string>
+              </property>
+             </item>
             </widget>
            </item>
            <item>
@@ -351,6 +385,61 @@ padding: 4px;</string>
                </property>
               </widget>
              </item>
+             <item>
+              <widget class="QPushButton" name="ipc">
+               <property name="sizePolicy">
+                <sizepolicy hsizetype="Minimum" vsizetype="Fixed">
+                 <horstretch>100</horstretch>
+                 <verstretch>0</verstretch>
+                </sizepolicy>
+               </property>
+               <property name="font">
+                <font>
+                 <family>Noto Sans</family>
+                 <pointsize>11</pointsize>
+                 <weight>87</weight>
+                 <italic>false</italic>
+                 <bold>true</bold>
+                 <kerning>true</kerning>
+                </font>
+               </property>
+               <property name="autoFillBackground">
+                <bool>false</bool>
+               </property>
+               <property name="styleSheet">
+                <string notr="true">background-color: rgb(255, 85, 0);
+font: 87 11pt &quot;Noto Sans&quot;;
+color: rgb(0, 43, 54);
+font-weight: 700;
+padding: 4px;
+border-style: outset;
+border-width: 2px;
+border-radius: 4px;
+border-color: #00000f;
+min-width: 4em;
+padding: 4px;</string>
+               </property>
+               <property name="text">
+                <string>IPC</string>
+               </property>
+               <property name="icon">
+                <iconset resource="kres.qrc">
+                 <normaloff>:/icons/icons/execute.png</normaloff>:/icons/icons/execute.png</iconset>
+               </property>
+               <property name="checkable">
+                <bool>false</bool>
+               </property>
+               <property name="checked">
+                <bool>false</bool>
+               </property>
+               <property name="default">
+                <bool>false</bool>
+               </property>
+               <property name="flat">
+                <bool>false</bool>
+               </property>
+              </widget>
+             </item>
             </layout>
            </item>
            <item>
@@ -392,10 +481,7 @@ color: rgb(223, 252, 255);</string>
           </layout>
          </item>
          <item row="0" column="1">
-          <layout class="QGridLayout" name="gridLayout" rowstretch="1"/>
-         </item>
-         <item row="0" column="2">
-          <layout class="QVBoxLayout" name="verticalLayout_4" stretch="1,0">
+          <layout class="QVBoxLayout" name="verticalLayout_4" stretch="1,0,0">
            <property name="spacing">
             <number>4</number>
            </property>
@@ -465,7 +551,10 @@ item { border-bottom: 1px solid black; padding: 16px;} </string>
             </layout>
            </item>
            <item>
-            <layout class="QVBoxLayout" name="verticalLayout_6" stretch="0,1">
+            <layout class="QVBoxLayout" name="verticalLayout_6" stretch="0">
+             <property name="spacing">
+              <number>6</number>
+             </property>
              <property name="sizeConstraint">
               <enum>QLayout::SetMaximumSize</enum>
              </property>
@@ -515,27 +604,29 @@ color: rgb(223, 252, 255);</string>
                </item>
               </layout>
              </item>
+            </layout>
+           </item>
+           <item>
+            <layout class="QHBoxLayout" name="horizontalLayout_3" stretch="0,0">
+             <property name="spacing">
+              <number>4</number>
+             </property>
+             <property name="sizeConstraint">
+              <enum>QLayout::SetMinimumSize</enum>
+             </property>
              <item>
-              <layout class="QHBoxLayout" name="horizontalLayout_3" stretch="0,0,0">
-               <property name="spacing">
-                <number>4</number>
+              <widget class="QPushButton" name="disconnect">
+               <property name="sizePolicy">
+                <sizepolicy hsizetype="Maximum" vsizetype="Maximum">
+                 <horstretch>0</horstretch>
+                 <verstretch>0</verstretch>
+                </sizepolicy>
                </property>
-               <property name="sizeConstraint">
-                <enum>QLayout::SetMinimumSize</enum>
+               <property name="autoFillBackground">
+                <bool>false</bool>
                </property>
-               <item>
-                <widget class="QPushButton" name="disconnect">
-                 <property name="sizePolicy">
-                  <sizepolicy hsizetype="Maximum" vsizetype="Maximum">
-                   <horstretch>0</horstretch>
-                   <verstretch>0</verstretch>
-                  </sizepolicy>
-                 </property>
-                 <property name="autoFillBackground">
-                  <bool>false</bool>
-                 </property>
-                 <property name="styleSheet">
-                  <string notr="true">font: 87 11pt &quot;Noto Sans&quot;;
+               <property name="styleSheet">
+                <string notr="true">font: 87 11pt &quot;Noto Sans&quot;;
 color: rgb(0, 0, 0);
 background-color: rgb(255, 0, 4);
 font-weight: 700;
@@ -546,68 +637,32 @@ border-radius: 4px;
 border-color: #00000f;
 min-width: 4em;
 padding: 4px;</string>
-                 </property>
-                 <property name="text">
-                  <string>Disconnect</string>
-                 </property>
-                 <property name="icon">
-                  <iconset resource="kres.qrc">
-                   <normaloff>:/icons/disconnect.png</normaloff>:/icons/disconnect.png</iconset>
-                 </property>
-                 <property name="flat">
-                  <bool>false</bool>
-                 </property>
-                </widget>
-               </item>
-               <item>
-                <widget class="QPushButton" name="openMessages">
-                 <property name="sizePolicy">
-                  <sizepolicy hsizetype="Minimum" vsizetype="Maximum">
-                   <horstretch>0</horstretch>
-                   <verstretch>0</verstretch>
-                  </sizepolicy>
-                 </property>
-                 <property name="autoFillBackground">
-                  <bool>false</bool>
-                 </property>
-                 <property name="styleSheet">
-                  <string notr="true">background-color: rgb(255, 85, 0);
-font: 87 11pt &quot;Noto Sans&quot;;
-color: rgb(0, 43, 54);
-font-weight: 700;
-padding: 4px;
-border-style: outset;
-border-width: 2px;
-border-radius: 4px;
-border-color: #00000f;
-min-width: 4em;
-padding: 4px;</string>
-                 </property>
-                 <property name="text">
-                  <string>History</string>
-                 </property>
-                 <property name="icon">
-                  <iconset resource="kres.qrc">
-                   <normaloff>:/icons/icons/log.svg</normaloff>:/icons/icons/log.svg</iconset>
-                 </property>
-                 <property name="flat">
-                  <bool>false</bool>
-                 </property>
-                </widget>
-               </item>
-               <item>
-                <widget class="QPushButton" name="sendMessage">
-                 <property name="sizePolicy">
-                  <sizepolicy hsizetype="Preferred" vsizetype="Maximum">
-                   <horstretch>0</horstretch>
-                   <verstretch>0</verstretch>
-                  </sizepolicy>
-                 </property>
-                 <property name="autoFillBackground">
-                  <bool>false</bool>
-                 </property>
-                 <property name="styleSheet">
-                  <string notr="true">background-color: rgb(130, 255, 121);
+               </property>
+               <property name="text">
+                <string>Close</string>
+               </property>
+               <property name="icon">
+                <iconset resource="kres.qrc">
+                 <normaloff>:/icons/disconnect.png</normaloff>:/icons/disconnect.png</iconset>
+               </property>
+               <property name="flat">
+                <bool>false</bool>
+               </property>
+              </widget>
+             </item>
+             <item>
+              <widget class="QPushButton" name="sendMessage">
+               <property name="sizePolicy">
+                <sizepolicy hsizetype="Preferred" vsizetype="Maximum">
+                 <horstretch>0</horstretch>
+                 <verstretch>0</verstretch>
+                </sizepolicy>
+               </property>
+               <property name="autoFillBackground">
+                <bool>false</bool>
+               </property>
+               <property name="styleSheet">
+                <string notr="true">background-color: rgb(130, 255, 121);
 background-color: rgb(2, 180, 43);
 font: 87 11pt &quot;Noto Sans&quot;;
 color: rgb(0, 0, 0);
@@ -619,29 +674,27 @@ border-radius: 4px;
 border-color: #00000f;
 min-width: 4em;
 padding: 4px;</string>
-                 </property>
-                 <property name="text">
-                  <string>Send</string>
-                 </property>
-                 <property name="icon">
-                  <iconset resource="kres.qrc">
-                   <normaloff>:/icons/send-button.png</normaloff>:/icons/send-button.png</iconset>
-                 </property>
-                 <property name="checkable">
-                  <bool>false</bool>
-                 </property>
-                 <property name="autoDefault">
-                  <bool>false</bool>
-                 </property>
-                 <property name="default">
-                  <bool>false</bool>
-                 </property>
-                 <property name="flat">
-                  <bool>false</bool>
-                 </property>
-                </widget>
-               </item>
-              </layout>
+               </property>
+               <property name="text">
+                <string>Send</string>
+               </property>
+               <property name="icon">
+                <iconset resource="kres.qrc">
+                 <normaloff>:/icons/send-button.png</normaloff>:/icons/send-button.png</iconset>
+               </property>
+               <property name="checkable">
+                <bool>false</bool>
+               </property>
+               <property name="autoDefault">
+                <bool>false</bool>
+               </property>
+               <property name="default">
+                <bool>false</bool>
+               </property>
+               <property name="flat">
+                <bool>false</bool>
+               </property>
+              </widget>
              </item>
             </layout>
            </item>
@@ -650,51 +703,74 @@ padding: 4px;</string>
         </layout>
        </item>
        <item>
-        <layout class="QHBoxLayout" name="horizontalLayout_5">
-         <property name="spacing">
-          <number>4</number>
-         </property>
-        </layout>
-       </item>
-       <item>
-        <widget class="QProgressBar" name="progressBar">
-         <property name="sizePolicy">
-          <sizepolicy hsizetype="Minimum" vsizetype="Maximum">
-           <horstretch>0</horstretch>
-           <verstretch>0</verstretch>
-          </sizepolicy>
-         </property>
-         <property name="styleSheet">
-          <string notr="true">background-color: #2f535f;
+        <layout class="QHBoxLayout" name="horizontalLayout_7" stretch="3,1">
+         <item>
+          <widget class="QProgressBar" name="progressBar">
+           <property name="sizePolicy">
+            <sizepolicy hsizetype="Expanding" vsizetype="Maximum">
+             <horstretch>0</horstretch>
+             <verstretch>0</verstretch>
+            </sizepolicy>
+           </property>
+           <property name="minimumSize">
+            <size>
+             <width>0</width>
+             <height>0</height>
+            </size>
+           </property>
+           <property name="styleSheet">
+            <string notr="true">background-color: #2f535f;
 font: 87 11pt &quot;Noto Sans&quot;;
 color: rgb(0, 0, 0);</string>
-         </property>
-         <property name="value">
-          <number>0</number>
-         </property>
-        </widget>
+           </property>
+           <property name="value">
+            <number>0</number>
+           </property>
+          </widget>
+         </item>
+         <item>
+          <widget class="QPushButton" name="openMessages">
+           <property name="sizePolicy">
+            <sizepolicy hsizetype="Expanding" vsizetype="Maximum">
+             <horstretch>0</horstretch>
+             <verstretch>0</verstretch>
+            </sizepolicy>
+           </property>
+           <property name="autoFillBackground">
+            <bool>false</bool>
+           </property>
+           <property name="styleSheet">
+            <string notr="true">background-color: rgb(255, 85, 0);
+font: 87 11pt &quot;Noto Sans&quot;;
+color: rgb(0, 43, 54);
+font-weight: 700;
+padding: 4px;
+border-style: outset;
+border-width: 2px;
+border-radius: 4px;
+border-color: #00000f;
+min-width: 4em;
+padding: 4px;</string>
+           </property>
+           <property name="text">
+            <string>History</string>
+           </property>
+           <property name="icon">
+            <iconset resource="kres.qrc">
+             <normaloff>:/icons/icons/log.svg</normaloff>:/icons/icons/log.svg</iconset>
+           </property>
+           <property name="flat">
+            <bool>false</bool>
+           </property>
+          </widget>
+         </item>
+        </layout>
        </item>
       </layout>
      </item>
     </layout>
    </widget>
   </widget>
-  <widget class="QMenuBar" name="menuBar">
-   <property name="geometry">
-    <rect>
-     <x>0</x>
-     <y>0</y>
-     <width>1080</width>
-     <height>23</height>
-    </rect>
-   </property>
-   <widget class="QMenu" name="menuK_Y_GUI">
-    <property name="title">
-     <string>K Y GUI</string>
-    </property>
-   </widget>
-   <addaction name="menuK_Y_GUI"/>
-  </widget>
   <widget class="QToolBar" name="mainToolBar">
    <attribute name="toolBarArea">
     <enum>TopToolBarArea</enum>
@@ -715,6 +791,28 @@ color: rgb(0, 0, 0);</string>
     <bool>false</bool>
    </attribute>
   </widget>
+  <widget class="QMenuBar" name="menuBar">
+   <property name="geometry">
+    <rect>
+     <x>0</x>
+     <y>0</y>
+     <width>960</width>
+     <height>23</height>
+    </rect>
+   </property>
+   <widget class="QMenu" name="menuK_Y_GUI">
+    <property name="title">
+     <string>K Y GUI</string>
+    </property>
+   </widget>
+   <widget class="QMenu" name="menuKIQ_Services">
+    <property name="title">
+     <string>KIQ Services</string>
+    </property>
+   </widget>
+   <addaction name="menuK_Y_GUI"/>
+   <addaction name="menuKIQ_Services"/>
+  </widget>
  </widget>
  <layoutdefault spacing="6" margin="11"/>
  <customwidgets>

+ 17 - 2
src/client.cpp

@@ -291,7 +291,11 @@ void Client::sendMessage(const QString& s) {
  * @brief Client::sendEncoded
  * @param [in] {std::string message} The message to send
  */
-void Client::sendEncoded(std::string message) {
+template <typename T>
+void Client::sendEncoded(T message) {
+  if constexpr (!(std::is_same<T, std::string>::value ||
+                  std::is_same<T, QString>::value)) return;
+
   std::vector<uint8_t> fb_byte_vector{message.begin(), message.end()};
   auto byte_vector = builder.CreateVector(fb_byte_vector);
   auto k_message = CreateMessage(builder, 69, byte_vector);
@@ -412,7 +416,7 @@ void Client::sendPackets(uint8_t* data, int size) {
     ::send(m_client_socket_fd, packet, packet_size, 0);
     if (is_last_packet) {
       qDebug() << "Last packet of file sent";
-      file_was_sent = true;
+//      file_was_sent = true;
     }
   }
 }
@@ -560,3 +564,14 @@ void Client::sendFiles(Scheduler::Task* task) {
     qDebug() << "Still attempting to send a different file";
   }
 }
+
+/**
+ */
+void Client::sendIPCMessage(const QString& message) {
+  sendEncoded(createOperation(
+      "ipc",
+      {
+        message.toUtf8().constData()
+      }
+  ));
+}

+ 19 - 10
src/mainwindow.cpp

@@ -52,13 +52,13 @@ QString timestampPrefix() {
  * @param process
  * @return
  */
-QStandardItem* createProcessListItem(Process process) {
+QStandardItem* createProcessListItem(int index, Process process) {
 
-  QString processResultText{"%0 requested for execution. "
-      "ID: %1\n"
-      "Status: %2\n"
-      "Time: %3   "
-      "Done: %4\n"
+  QString processResultText{"%0. %1 requested for execution.\n"
+      "ID: %2\n"
+      "Status: %3\n"
+      "Time: %4   "
+      "Done: %5\n"
   };
 
   auto error = !process.error.isEmpty();
@@ -67,6 +67,7 @@ QStandardItem* createProcessListItem(Process process) {
     processResultText += "Errors: %5";
     return new QStandardItem{
       processResultText
+      .arg(index)
       .arg(process.name)
       .arg(process.id)
       .arg(ProcessNames[process.state - 1])
@@ -77,6 +78,7 @@ QStandardItem* createProcessListItem(Process process) {
   }
   return new QStandardItem{
     processResultText
+    .arg(index)
     .arg(process.name)
     .arg(process.id)
     .arg(ProcessNames[process.state - 1])
@@ -275,6 +277,10 @@ void MainWindow::connectClient() {
                      }
                    });
 
+  QObject::connect(ui->ipc, &QPushButton::clicked, this, [this]() {
+    q_client->sendIPCMessage(ui->ipcList->currentText());
+  });
+
   QTimer* timer = new QTimer(this);
   connect(timer, &QTimer::timeout, q_client, &Client::ping);
   timer->start(10000);
@@ -312,7 +318,7 @@ void MainWindow::onMessageReceived(int t, const QString& message, StringVec v) {
                                   .id = v.at(2)});
     int row = 0;
     for (const auto& process : m_processes) {
-      m_process_model->setItem(row, createProcessListItem(process));
+      m_process_model->setItem(row, createProcessListItem((row + 1), process));
       row++;
     }
   } else if (t == EVENT_UPDATE_TYPE) {  // Received event from server
@@ -452,7 +458,7 @@ void MainWindow::MessageParser::updateProcessResult(
           !error ? ProcessState::SUCCEEDED : ProcessState::FAILED;
       window->m_processes.at(i).result = result;
       window->m_process_model->setItem(
-          i, 0, createProcessListItem(window->m_processes.at(i)));
+          i, 0, createProcessListItem((i + 1), window->m_processes.at(i)));
       return;
     }
   }
@@ -494,9 +500,12 @@ QString MainWindow::MessageParser::handleEventMessage(QString message,
             new_process.result = v.at(2);
             new_process.end = new_process.start;
           }
+          auto index = window->m_process_model->rowCount();
           window->m_processes.push_back(new_process);
-          window->m_process_model->setItem(window->m_process_model->rowCount(),
-                                           createProcessListItem(new_process));
+          window->m_process_model->setItem(
+            index,
+            createProcessListItem((index + 1), new_process)
+          );
         }
         event_message += app_name;
         event_message += ": ";