diff --git a/reportservice/automatic_run.py b/reportservice/automatic_run.py
index 76242dc075d49e6b10202c7eb124da29124a24c6..b6aba1f5e20378a9d90adfa8fa2b1448abba5c65 100644
--- a/reportservice/automatic_run.py
+++ b/reportservice/automatic_run.py
@@ -73,7 +73,7 @@ if __name__ == "__main__":
     args = vars(arg_parser.parse_args())
     conf_file = args["config_file"]
     with open(conf_file, "r") as f:
-        cfg = yaml.load(f.read())
+        cfg = yaml.load(f.read(), Loader=yaml.FullLoader)
 
     logfile = args["log_file"]
     fmt = '%(asctime)s - %(name)s - %(levelname)s - %(message)s'
diff --git a/reportservice/manual_run.py b/reportservice/manual_run.py
index bf0ddf2a312b8e51484d4abc49cbdaf73d7346ab..d57248838e2ebff45d32523c0bb0f135b2bf0ce1 100644
--- a/reportservice/manual_run.py
+++ b/reportservice/manual_run.py
@@ -35,11 +35,11 @@ def manual_run(request, cfg):
 arg_parser = argparse.ArgumentParser(description='Manual Launch')
 arg_parser.add_argument('--instrument', default=['all'], nargs='+',
                         help='select the requested instruments. '
-                             'Default=None. "all" can be used for selecting'
+                             'Default=\"all\", which can be used for selecting'
                              ' all instruments')
 arg_parser.add_argument('--gitpush', dest='Push to git', action='store_true',
                         help='required for pushing the generated figures '
-                             'to the DC git repository')
+                             'to the DC git repository. Default=bool(False)')
 arg_parser.set_defaults(gitpush=False)
 arg_parser.add_argument('--config-file', type=str, 
                         default='./report_conf.yaml',
@@ -56,7 +56,7 @@ if __name__ == "__main__":
     args = vars(arg_parser.parse_args())
     conf_file = args["config_file"]
     with open(conf_file, "r") as f:
-        cfg = yaml.load(f.read())
+        cfg = yaml.load(f.read(), Loader=yaml.FullLoader)
 
     logfile = args["log_file"]
     fmt = '%(asctime)s - %(name)s - %(levelname)s - %(message)s'
diff --git a/reportservice/report_service.py b/reportservice/report_service.py
index 254f854537ed10ca452d249b34bd99653f04a5b7..3d2d02a25ad6169669abced8ba41be45b7930f4c 100644
--- a/reportservice/report_service.py
+++ b/reportservice/report_service.py
@@ -156,7 +156,7 @@ async def server_runner(conf_file):
     be accessed through ReadTheDocs.
     """
     with open(conf_file, "r") as f:
-        config = yaml.load(f.read())
+        config = yaml.load(f.read(), Loader=yaml.FullLoader)
 
     # perform git-dir checks and pull the project for updates.
     init_config_repo(config['GLOBAL']['git'])
@@ -263,57 +263,60 @@ async def server_runner(conf_file):
                     logging.error('Jobs have timed-out!')
                     logging.error('{}/temp has not been deleted.'.format(
                                   os.path.dirname(os.path.abspath(__file__))))
+                # Avoid copying files if no git-push is planned
+                # to avoid causing local git repository errors.
+                if git_push:
+                    # Copy all plots
+                    for det_name, det_conf in instrument.items():
 
-                # Copy all plots
-                for det_name, det_conf in instrument.items():
-                    
-                    out_folder = det_conf['out-folder'].format(
-                                          instrument=instr_name,
-                                          detector=det_name)
+                        out_folder = det_conf['out-folder'].format(
+                                              instrument=instr_name,
+                                              detector=det_name)
 
-                    figures = glob.glob("{}/*png".format(out_folder))
+                        figures = glob.glob("{}/*png".format(out_folder))
 
-                    det_new_files = {}
+                        det_new_files = {}
 
-                    for f in figures:
-                        const = f.split('/')[-1].split('_')[0]
-                        fpath = '{}/{}/{}/{}'.format(fig_local, instr_name,
-                                                     det_name, const)
+                        for f in figures:
+                            const = f.split('/')[-1].split('_')[0]
+                            fpath = '{}/{}/{}/{}'.format(fig_local, instr_name,
+                                                         det_name, const)
 
-                        os.makedirs(fpath, exist_ok=True)
-                        det_new_files[f] = fpath
+                            os.makedirs(fpath, exist_ok=True)
+                            det_new_files[f] = fpath
 
-                        # Set concurrency limitation.
-                        # 50 have been chosen by trial 
-                        # Note: This is not the max limitation.
-                        sem = asyncio.Semaphore(50)
-                        all_new_files.append(
-                            '{}/{}'.format(fpath, f.split('/')[-1]))
+                            # Set concurrency limitation.
+                            # 50 have been chosen by trial
+                            # Note: This is not the max limitation.
+                            sem = asyncio.Semaphore(50)
+                            all_new_files.append(
+                                '{}/{}'.format(fpath, f.split('/')[-1]))
 
-                    await asyncio.gather(*[copy_files(k, v, sem)
-                                        for k, v in det_new_files.items()])
+                        await asyncio.gather(*[copy_files(k, v, sem)
+                                            for k, v in det_new_files.items()])
 
-                    logging.info('{} figures of {} are copied into {}'.format(
-                                           len(figures), det_name, fig_local))
+                        logging.info('{} figures of {} are copied into {}'.format(
+                                               len(figures), det_name, fig_local))
 
-            # Remove sensitive information from the config file.
-            del cfg['GLOBAL']
-            # Write the requested cfg.yaml before pushing all figures.
-            with open('{}/report_conf.yaml'.format(
-                                          fig_local), 'w') as outfile:
-                yaml.dump(cfg, outfile, default_flow_style=False)
+            if git_push:
+                # Remove sensitive information from the config file.
+                del cfg['GLOBAL']
+                # Write the requested cfg.yaml before pushing all figures.
+                with open('{}/report_conf.yaml'.format(
+                                              fig_local), 'w') as outfile:
+                    yaml.dump(cfg, outfile, default_flow_style=False)
 
-            all_new_files.append('{}/report_conf.yaml'.format(fig_local))
+                all_new_files.append('{}/report_conf.yaml'.format(fig_local))
 
-            if git_push:
                 asyncio.ensure_future(push_figures(local_repo, all_new_files))
 
-            # TODO:delete out-folder
-            #try:
-                # asyncio.ensure_future(del_folder(out_folder))
-            #except:
-                #logging.error(str(e))
-            logging.info('All done')
+                # TODO:delete out-folder
+                #try:
+                    # asyncio.ensure_future(del_folder(out_folder))
+                #except:
+                    #logging.error(str(e))
+
+            logging.info('Generating requested plots is finished!')
 
             return