diff --git a/notebooks/LPD/Inject_calibration_constants_from_h5files.ipynb b/notebooks/LPD/Inject_calibration_constants_from_h5files.ipynb
index 1a2adc72dfe16697eb032d0f409b6330d1422316..2da696d06a67d80e82c21447917e4c09bd82e16e 100644
--- a/notebooks/LPD/Inject_calibration_constants_from_h5files.ipynb
+++ b/notebooks/LPD/Inject_calibration_constants_from_h5files.ipynb
@@ -13,13 +13,13 @@
   },
   {
    "cell_type": "code",
-   "execution_count": 1,
+   "execution_count": null,
    "metadata": {},
    "outputs": [],
    "source": [
     "# calibration constant parameters:\n",
-    "constant_names = [\"GainMap\", \"GainAmpMap\", \"FFMap\"]  # calibration constant name, required.\n",
-    "in_folder = \"/gpfs/exfel/data/scratch/yousefh/LPD_CalinConst_Provisional/\"  # calibration constant file, required.\n",
+    "constant_names = [\"\"]  # calibration constant name, required.\n",
+    "in_folder = \"\"  # calibration constants folder, required.\n",
     "out_folder = \"\"  # output folder to store report path in case the notebook is executed by CLI, required.\n",
     "proposal = \"\" # Add proposal number to be sent to the database as a part of Raw data location.\n",
     "runs = [\"\"] # Add list of runs to be sent to the database as a part of Raw data location.\n",
@@ -27,7 +27,6 @@
     "# detector parameters:\n",
     "karabo_id = \"FXE_DET_LPD1M-1\"  # detector identifier.\n",
     "karabo_da = [\"all\"]  # karabo data aggregators. default \"all\" for all 16 karabo data aggregator names.\n",
-    "modules = [-1]  # List of module indicies to inject the constants for. default -1 for all 16 modules.\n",
     "\n",
     "# calibration database parameters:\n",
     "cal_db_interface = \"tcp://max-exfl017:8015#8045\"  # calibration DB zmq address.\n",
@@ -36,12 +35,14 @@
     "memory_cells = 512  # Number of memory cells. Used for constant conditions.\n",
     "bias_voltage = 250  # bias voltage value. Used for constant conditions.\n",
     "capacitor = 5  # capacitor value. Used for constant conditions.\n",
+    "category = 0 # calibration constant source category, 0 for European XFEl and 1 for RAL. Used for constant conditions.\n",
+    "photon_energy = 9.2 # calibration constant photon energy. Used for constant conditions.\n",
     "creation_time = '2020-01-20T14:12:06'  # creation time for the injected constants. required format '2019-01-20T14:12:06'"
    ]
   },
   {
    "cell_type": "code",
-   "execution_count": 2,
+   "execution_count": null,
    "metadata": {},
    "outputs": [],
    "source": [
@@ -64,23 +65,21 @@
   },
   {
    "cell_type": "code",
-   "execution_count": 3,
+   "execution_count": null,
    "metadata": {},
    "outputs": [],
    "source": [
     "pixels_x = pixels_y = 256\n",
     "\n",
     "if karabo_da[0].lower() == \"all\":\n",
-    "    if modules[0] == -1:\n",
-    "        modules = list(range(16))\n",
-    "    karabo_da = [f\"LPD{i:02d}\" for i in modules]\n",
+    "    karabo_da = [f\"LPD{i:02d}\" for i in range(16)]\n",
     "\n",
     "# if proposal or runs are given assign file_loc \n",
     "# for calibration constant versions metadata.\n",
     "file_loc = \"\"\n",
     "if proposal:\n",
     "    file_loc += f\"proposal:{proposal}\"\n",
-    "if len(runs) > 0:\n",
+    "if runs[0] == \"\":\n",
     "    file_loc += f\"runs: {runs}\"\n",
     "\n",
     "if file_loc == \"\":\n",
@@ -92,7 +91,7 @@
   },
   {
    "cell_type": "code",
-   "execution_count": 4,
+   "execution_count": null,
    "metadata": {},
    "outputs": [],
    "source": [
@@ -122,7 +121,7 @@
   },
   {
    "cell_type": "code",
-   "execution_count": 5,
+   "execution_count": null,
    "metadata": {},
    "outputs": [],
    "source": [
@@ -165,90 +164,9 @@
   },
   {
    "cell_type": "code",
-   "execution_count": 6,
+   "execution_count": null,
    "metadata": {},
-   "outputs": [
-    {
-     "name": "stdout",
-     "output_type": "stream",
-     "text": [
-      "/gpfs/exfel/data/scratch/yousefh/LPD_CalinConst_Provisional 2020-01-20 14:12:06\n",
-      "Physical detector units retrieved are:  {'LPD00': 'LPD_SIV1_LPDV2_SM015', 'LPD01': 'LPD_SIV1_LPDV2_SM012', 'LPD02': 'LPD_SIV1_LPDV2_SM011', 'LPD03': 'LPD_SIV1_LPDV2_SM014', 'LPD04': 'LPD_SIV1_LPDV2_SM001', 'LPD05': None, 'LPD06': 'LPD_SIV1_LPDV2_SM004', 'LPD07': 'LPD_SIV1_LPDV2_SM002', 'LPD08': 'LPD_SIV1_LPDV2_SM009', 'LPD09': 'LPD_SIV1_LPDV2_SM006', 'LPD10': 'LPD_SIV1_LPDV2_SM007', 'LPD11': 'LPD_SIV1_LPDV2_SM005', 'LPD12': 'LPD_SIV1_LPDV2_SM000', 'LPD13': 'LPD_SIV1_LPDV2_SM010', 'LPD14': 'LPD_SIV1_LPDV2_SM008', 'LPD15': 'LPD_SIV1_LPDV2_SM013'} \n",
-      "\n",
-      "GainMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "GainAmpMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "FFMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n",
-      "Can't decrement id ref count (write to backing store failed: time = Wed Apr 21 13:10:25 2021\n",
-      ", filename = '/tmp/tmprj0cpuu3', file descriptor = 69, errno = 28, error message = 'No space left on device', ptr = 0x2b17524ae010, total write size = 498432672, bytes this sub-write = 498432672, bytes actually written = 18446744073709551615, offset = 306892800)\n",
-      "\n",
-      "GainMap is injected with creation-time: 2020-01-20 14:12:06\n",
-      "\n"
-     ]
-    },
-    {
-     "ename": "KeyboardInterrupt",
-     "evalue": "",
-     "output_type": "error",
-     "traceback": [
-      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
-      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
-      "\u001b[0;32m<ipython-input-6-65188278bae1>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     40\u001b[0m \u001b[0mprocess\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mkarabo_da\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mconstant_names\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     41\u001b[0m \u001b[0;32mwith\u001b[0m \u001b[0mmultiprocessing\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mPool\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mprocesses\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m16\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mpool\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 42\u001b[0;31m     \u001b[0mresults\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpool\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstarmap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minject_constants\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0minp\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
-      "\u001b[0;32m/software/anaconda3/5.2/lib/python3.6/multiprocessing/pool.py\u001b[0m in \u001b[0;36mstarmap\u001b[0;34m(self, func, iterable, chunksize)\u001b[0m\n\u001b[1;32m    294\u001b[0m         \u001b[0;31m`\u001b[0m\u001b[0mfunc\u001b[0m\u001b[0;31m`\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mb\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0mbecomes\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mb\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    295\u001b[0m         '''\n\u001b[0;32m--> 296\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_map_async\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfunc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0miterable\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mstarmapstar\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mchunksize\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    297\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    298\u001b[0m     def starmap_async(self, func, iterable, chunksize=None, callback=None,\n",
-      "\u001b[0;32m/software/anaconda3/5.2/lib/python3.6/multiprocessing/pool.py\u001b[0m in \u001b[0;36mget\u001b[0;34m(self, timeout)\u001b[0m\n\u001b[1;32m    662\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    663\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mget\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtimeout\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 664\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mwait\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtimeout\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    665\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mready\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    666\u001b[0m             \u001b[0;32mraise\u001b[0m \u001b[0mTimeoutError\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
-      "\u001b[0;32m/software/anaconda3/5.2/lib/python3.6/multiprocessing/pool.py\u001b[0m in \u001b[0;36mwait\u001b[0;34m(self, timeout)\u001b[0m\n\u001b[1;32m    659\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    660\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mwait\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtimeout\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 661\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_event\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mwait\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtimeout\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    662\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    663\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mget\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtimeout\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
-      "\u001b[0;32m/software/anaconda3/5.2/lib/python3.6/threading.py\u001b[0m in \u001b[0;36mwait\u001b[0;34m(self, timeout)\u001b[0m\n\u001b[1;32m    549\u001b[0m             \u001b[0msignaled\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_flag\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    550\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0msignaled\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 551\u001b[0;31m                 \u001b[0msignaled\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_cond\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mwait\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtimeout\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    552\u001b[0m             \u001b[0;32mreturn\u001b[0m \u001b[0msignaled\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    553\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
-      "\u001b[0;32m/software/anaconda3/5.2/lib/python3.6/threading.py\u001b[0m in \u001b[0;36mwait\u001b[0;34m(self, timeout)\u001b[0m\n\u001b[1;32m    293\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m    \u001b[0;31m# restore state no matter what (e.g., KeyboardInterrupt)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    294\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mtimeout\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 295\u001b[0;31m                 \u001b[0mwaiter\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0macquire\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    296\u001b[0m                 \u001b[0mgotit\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    297\u001b[0m             \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
-      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
-     ]
-    }
-   ],
+   "outputs": [],
    "source": [
     "c_folder, creation_time = validate_input_paths(in_folder, creation_time)\n",
     "print(c_folder, creation_time)\n",
@@ -259,12 +177,14 @@
     ")\n",
     "\n",
     "# Calibration constants condition object.\n",
-    "condition = Conditions.Dark.LPD(\n",
+    "condition = Conditions.Illuminated.LPD(\n",
     "    memory_cells=memory_cells,\n",
     "    bias_voltage=bias_voltage,\n",
+    "    photon_energy=photon_energy,\n",
     "    pixels_x=pixels_x,\n",
     "    pixels_y=pixels_y,\n",
     "    capacitor=capacitor,\n",
+    "    category=category,\n",
     ")\n",
     "\n",
     "# Retrieve all physical detector units for the given karabo_da list.\n",
@@ -276,37 +196,25 @@
     "    cal_db_interface=cal_db_interface,\n",
     "    snapshot_at=creation_time\n",
     ")\n",
+    "\n",
     "mod_mapping = dict(zip(karabo_da, physical_units))\n",
     "print(\"Physical detector units retrieved are: \", mod_mapping, \"\\n\")\n",
     "\n",
     "inp = []\n",
     "for const in constant_names:\n",
     "    for k_da, pdu in mod_mapping.items():\n",
-    "        inp.append(\n",
-    "            (const,\n",
-    "             k_da,\n",
-    "             pdu,\n",
-    "            )\n",
-    "        )\n",
+    "        inp.append((const, k_da, pdu))\n",
     "\n",
-    "process = int(len(karabo_da)*len(constant_names))\n",
     "with multiprocessing.Pool(processes=16) as pool:\n",
     "    results = pool.starmap(inject_constants, inp)"
    ]
-  },
-  {
-   "cell_type": "code",
-   "execution_count": null,
-   "metadata": {},
-   "outputs": [],
-   "source": []
   }
  ],
  "metadata": {
   "kernelspec": {
-   "display_name": "cal_venv",
+   "display_name": "Python 3",
    "language": "python",
-   "name": "cal_venv"
+   "name": "python3"
   },
   "language_info": {
    "codemirror_mode": {
diff --git a/src/cal_tools/tools.py b/src/cal_tools/tools.py
index 7f6a1037839a98d6162feee0cfc12c1bd2ed6a8a..9021160723f536247e2e8dc42746ab7cf04b71a2 100644
--- a/src/cal_tools/tools.py
+++ b/src/cal_tools/tools.py
@@ -562,6 +562,8 @@ def get_from_db(karabo_id: str, karabo_da: str,
     else:
         return empty_constant, None
 
+already_printed = []
+
 
 def send_to_db(db_module: str, karabo_id: str, constant, condition,
                file_loc: str, report_path: str, cal_db_interface: str,
@@ -624,9 +626,11 @@ def send_to_db(db_module: str, karabo_id: str, constant, condition,
             except Exception as e:
                 # TODO: refactor to use custom exception class
                 if "has already been taken" in str(e):
-                    print(f"WARNING: {constant.name} has already been "
-                          "injected with the same parameter "
-                          "conditions\n")
+                    print(
+                        f"WARNING: {constant.name} for {db_module}"
+                        " has already been injected with the same "
+                        "parameter conditions."
+                    )
                 else:
                     print(f"{e}\n")
 
@@ -638,8 +642,11 @@ def send_to_db(db_module: str, karabo_id: str, constant, condition,
                     raise RuntimeError(f'{e}')
 
         if success:
-            print(f"{constant.name} is injected with creation-time: "
-                  f"{metadata.calibration_constant_version.begin_at}\n")
+            if constant.name not in already_printed:
+                print(
+                    f"{constant.name} is injected with creation-time: "
+                    f"{metadata.calibration_constant_version.begin_at}."
+                )
     return metadata