elog2labfolder/_build/html/installation_cups.html
changeset 15 523ca1dfd077
child 18 57431f642e82
equal deleted inserted replaced
13:a21f3604f1db 15:523ca1dfd077
       
     1 
       
     2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
       
     3   "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
       
     4 
       
     5 <html xmlns="http://www.w3.org/1999/xhtml">
       
     6   <head>
       
     7     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
       
     8     <title>Printing via CUPS and attaching files to labfolder logbooks &#8212; Labfolder at FHI 1.0 documentation</title>
       
     9     <link rel="stylesheet" href="_static/alabaster.css" type="text/css" />
       
    10     <link rel="stylesheet" href="_static/pygments.css" type="text/css" />
       
    11     <script type="text/javascript">
       
    12       var DOCUMENTATION_OPTIONS = {
       
    13         URL_ROOT:    './',
       
    14         VERSION:     '1.0',
       
    15         COLLAPSE_INDEX: false,
       
    16         FILE_SUFFIX: '.html',
       
    17         HAS_SOURCE:  true,
       
    18         SOURCELINK_SUFFIX: '.txt'
       
    19       };
       
    20     </script>
       
    21     <script type="text/javascript" src="_static/jquery.js"></script>
       
    22     <script type="text/javascript" src="_static/underscore.js"></script>
       
    23     <script type="text/javascript" src="_static/doctools.js"></script>
       
    24     <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.1/MathJax.js?config=TeX-AMS-MML_HTMLorMML"></script>
       
    25     <link rel="index" title="Index" href="genindex.html" />
       
    26     <link rel="search" title="Search" href="search.html" />
       
    27     <link rel="next" title="Groups, ownership and sharing in labfolder" href="groups.html" />
       
    28     <link rel="prev" title="Installation of labfolder" href="installation.html" />
       
    29    
       
    30   <link rel="stylesheet" href="_static/custom.css" type="text/css" />
       
    31   
       
    32   
       
    33   <meta name="viewport" content="width=device-width, initial-scale=0.9, maximum-scale=0.9" />
       
    34 
       
    35   </head>
       
    36   <body>
       
    37   
       
    38 
       
    39     <div class="document">
       
    40       <div class="documentwrapper">
       
    41         <div class="bodywrapper">
       
    42           <div class="body" role="main">
       
    43             
       
    44   <div class="section" id="printing-via-cups-and-attaching-files-to-labfolder-logbooks">
       
    45 <h1>Printing via CUPS and attaching files to labfolder logbooks<a class="headerlink" href="#printing-via-cups-and-attaching-files-to-labfolder-logbooks" title="Permalink to this headline">¶</a></h1>
       
    46 <p>Follow this guide to set up CUPS virtual printers to be able to print webpages and pictures/files (PDF, PNG, JPG, PS) to one of labfolder’s logbooks, thus, creating a new entry with an attachment. If you are an admin of the labfolder VM read the section <a class="reference internal" href="#section-cups-admin"><span class="std std-ref">Set up CUPS as labfolder admin</span></a>. Users of labfolder read the section <a class="reference internal" href="#section-cups-user"><span class="std std-ref">Printing to labfolder projects</span></a>.</p>
       
    47 <div class="section" id="set-up-cups-as-labfolder-admin">
       
    48 <span id="section-cups-admin"></span><h2>Set up CUPS as labfolder admin<a class="headerlink" href="#set-up-cups-as-labfolder-admin" title="Permalink to this headline">¶</a></h2>
       
    49 <p>First, you need to install CUPS on the virtual machine that runs labfolder:</p>
       
    50 <div class="highlight-default"><div class="highlight"><pre><span></span><span class="n">sudo</span> <span class="n">apt</span><span class="o">-</span><span class="n">get</span> <span class="n">install</span> <span class="n">cups</span> <span class="n">cups</span><span class="o">-</span><span class="n">client</span> <span class="n">cups</span><span class="o">-</span><span class="n">bsd</span>
       
    51 </pre></div>
       
    52 </div>
       
    53 <p>Next, configure <code class="docutils literal"><span class="pre">/etc/cups/cupsd.conf</span></code>:</p>
       
    54 <div class="highlight-default"><div class="highlight"><pre><span></span><span class="c1"># Sample configuration file for the CUPS scheduler.  See &quot;man cupsd.conf&quot; for a</span>
       
    55 <span class="c1"># complete description of this file.</span>
       
    56 
       
    57 <span class="c1"># Log general information in error_log - change &quot;warn&quot; to &quot;debug&quot;</span>
       
    58 <span class="c1"># for troubleshooting...</span>
       
    59 <span class="n">LogLevel</span> <span class="n">debug</span>
       
    60 
       
    61 <span class="c1"># Deactivate CUPS&#39; internal logrotating, as we provide a better one, especially</span>
       
    62 <span class="c1"># LogLevel debug2 gets usable now</span>
       
    63 <span class="n">MaxLogSize</span> <span class="mi">0</span>
       
    64 
       
    65 <span class="c1"># Administrator user group...</span>
       
    66 <span class="n">SystemGroup</span> <span class="n">lpadmin</span>
       
    67 <span class="n">ServerAdmin</span> <span class="o">&lt;</span><span class="n">name</span><span class="o">&gt;</span><span class="nd">@fhi</span><span class="o">-</span><span class="n">berlin</span><span class="o">.</span><span class="n">mpg</span><span class="o">.</span><span class="n">de</span>
       
    68 
       
    69 <span class="n">HostNameLookups</span> <span class="n">On</span>
       
    70 <span class="n">ServerAlias</span> <span class="o">*</span>
       
    71 
       
    72 <span class="c1"># Only listen for connections from the local machine.</span>
       
    73 <span class="n">Listen</span> <span class="n">lftest</span><span class="o">.</span><span class="n">rz</span><span class="o">-</span><span class="n">berlin</span><span class="o">.</span><span class="n">mpg</span><span class="o">.</span><span class="n">de</span><span class="p">:</span><span class="mi">631</span>
       
    74 <span class="n">Listen</span> <span class="o">/</span><span class="n">var</span><span class="o">/</span><span class="n">run</span><span class="o">/</span><span class="n">cups</span><span class="o">/</span><span class="n">cups</span><span class="o">.</span><span class="n">sock</span>
       
    75 
       
    76 <span class="c1"># Show shared printers on the local network.</span>
       
    77 <span class="n">Browsing</span> <span class="n">Off</span>
       
    78 <span class="n">BrowseOrder</span> <span class="n">allow</span><span class="p">,</span><span class="n">deny</span>
       
    79 <span class="n">BrowseAllow</span> <span class="nb">all</span>
       
    80 <span class="n">BrowseLocalProtocols</span> <span class="n">CUPS</span> <span class="n">dnssd</span>
       
    81 <span class="n">BrowseAddress</span> <span class="nd">@LOCAL</span>
       
    82 
       
    83 <span class="c1"># Default authentication type, when authentication is required...</span>
       
    84 <span class="n">DefaultAuthType</span> <span class="n">Basic</span>
       
    85 
       
    86 <span class="c1"># Web interface setting...</span>
       
    87 <span class="n">WebInterface</span> <span class="n">Yes</span>
       
    88 
       
    89 <span class="c1"># Restrict access to the server...</span>
       
    90 <span class="o">&lt;</span><span class="n">Location</span> <span class="o">/&gt;</span>
       
    91   <span class="n">Satisfy</span> <span class="n">All</span>
       
    92   <span class="n">Allow</span> <span class="n">localhost</span>
       
    93   <span class="n">Allow</span> <span class="mf">141.14</span><span class="o">.*</span>
       
    94   <span class="n">Allow</span> <span class="mf">172.16</span><span class="o">.*</span>
       
    95   <span class="n">Allow</span> <span class="mf">192.</span><span class="o">*</span>
       
    96   <span class="n">Allow</span> <span class="nb">all</span>
       
    97   <span class="c1"># Allow shared printing and remote administration...</span>
       
    98   <span class="n">Order</span> <span class="n">allow</span><span class="p">,</span><span class="n">deny</span>
       
    99   <span class="n">Allow</span> <span class="nb">all</span>
       
   100 <span class="o">&lt;/</span><span class="n">Location</span><span class="o">&gt;</span>
       
   101 
       
   102 <span class="c1"># Restrict access to the admin pages...</span>
       
   103 <span class="o">&lt;</span><span class="n">Location</span> <span class="o">/</span><span class="n">admin</span><span class="o">&gt;</span>
       
   104   <span class="n">Order</span> <span class="n">deny</span><span class="p">,</span><span class="n">allow</span>
       
   105   <span class="n">Satisfy</span> <span class="n">All</span>
       
   106   <span class="n">AuthType</span> <span class="n">Basic</span>
       
   107   <span class="n">Require</span> <span class="n">user</span> <span class="nd">@SYSTEM</span>
       
   108   <span class="n">Deny</span> <span class="n">All</span>
       
   109   <span class="n">Allow</span> <span class="n">localhost</span>
       
   110   <span class="n">Allow</span> <span class="mf">141.14</span><span class="o">.*</span>
       
   111   <span class="n">Allow</span> <span class="mf">172.16</span><span class="o">.*</span>
       
   112 <span class="o">&lt;/</span><span class="n">Location</span><span class="o">&gt;</span>
       
   113 
       
   114 <span class="c1"># Restrict access to configuration files...</span>
       
   115 <span class="o">&lt;</span><span class="n">Location</span> <span class="o">/</span><span class="n">admin</span><span class="o">/</span><span class="n">conf</span><span class="o">&gt;</span>
       
   116   <span class="n">Order</span> <span class="n">deny</span><span class="p">,</span><span class="n">allow</span>
       
   117   <span class="n">AuthType</span> <span class="n">Default</span>
       
   118   <span class="n">Require</span> <span class="n">user</span> <span class="nd">@SYSTEM</span>
       
   119   <span class="n">Satisfy</span> <span class="n">All</span>
       
   120   <span class="n">Require</span> <span class="n">user</span> <span class="n">root</span>
       
   121   <span class="n">Deny</span> <span class="n">All</span>
       
   122   <span class="n">Allow</span> <span class="mf">127.0</span><span class="o">.</span><span class="mf">0.1</span>
       
   123   <span class="n">Allow</span> <span class="mf">141.14</span><span class="o">.*</span>
       
   124   <span class="n">Allow</span> <span class="mf">172.16</span><span class="o">.*</span>
       
   125 <span class="o">&lt;/</span><span class="n">Location</span><span class="o">&gt;</span>
       
   126 
       
   127 <span class="c1"># Set the default printer/job policies...</span>
       
   128 <span class="o">&lt;</span><span class="n">Policy</span> <span class="n">default</span><span class="o">&gt;</span>
       
   129   <span class="o">...</span> <span class="c1"># probably as in the original</span>
       
   130 <span class="o">&lt;/</span><span class="n">Policy</span><span class="o">&gt;</span>
       
   131 </pre></div>
       
   132 </div>
       
   133 <p>Change the <em>Server Admin</em>’s e-mail address and the server that shall be listened to (see the <code class="docutils literal"><span class="pre">Listen</span></code> statement). Set <code class="docutils literal"><span class="pre">FileDevice</span> <span class="pre">Yes</span></code> in <code class="docutils literal"><span class="pre">/etc/cups/cups-files.conf</span></code>. Now, create a directory where all printers will go, e.g. <code class="docutils literal"><span class="pre">/usr/local/labfolder/printers</span></code>.</p>
       
   134 <p>Get the package for creating new printers from git:</p>
       
   135 <div class="highlight-default"><div class="highlight"><pre><span></span>labfolder@lftest:~$ git clone https://github.molgen.mpg.de/weiher/cupsPrinters
       
   136 labfolder@lftest:~$ ls
       
   137 cupsPrinters  labfolder
       
   138 </pre></div>
       
   139 </div>
       
   140 <p>The only file you need to adapt is <code class="docutils literal"><span class="pre">newPrinter.sh</span></code>. It is not a must but it is suggested to name the printers like the projects. For example, the FEL projects <em>operating</em> and <em>installation</em> could be placed at <code class="docutils literal"><span class="pre">.../printers/FEL/operating</span></code> and <code class="docutils literal"><span class="pre">.../printers/FEL/installation</span></code>. Execute the script with sudo rights:</p>
       
   141 <div class="highlight-default"><div class="highlight"><pre><span></span>labfolder@lftest:~/cupsPrinters$ sudo ./newPrinter.sh
       
   142 </pre></div>
       
   143 </div>
       
   144 <p>To prevent <code class="docutils literal"><span class="pre">DENIED</span></code> errors from apparmor install and set the following and restart the CUPS server:</p>
       
   145 <div class="highlight-default"><div class="highlight"><pre><span></span>$ sudo apt-get install apparmor-utils apparmor-profiles
       
   146 $ sudo aa-complain cupsd
       
   147 $ sudo service cups restart
       
   148 </pre></div>
       
   149 </div>
       
   150 <p>In case you need to debug some logfiles can be found here: <em>/var/log/syslog</em>, <em>/var/log/cups/error_log</em> and <em>/var/log/cups/acces_log</em></p>
       
   151 <p>One last change is that you need to once add a user named <em>Printer Print</em> (firstname lastname) to the labfolder database. This can be done manually inside the DB by this command:</p>
       
   152 <div class="highlight-default"><div class="highlight"><pre><span></span>$ mysql -u root -p
       
   153 Enter password:
       
   154 ...
       
   155 mysql&gt; use labfolder;
       
   156 mysql&gt; INSERT INTO user (email, password, firstname, lastname, signupTimestamp, maxStorage) VALUES (&#39;printer@fhi-berlin.mpg.de&#39;, &#39;91a13f2aba4a35b00c35dfacadd1d75f4a5171dfa7a465fca9c40e6b007ce982&#39;, &#39;Printer&#39;, &#39;Print&#39;, &#39;2018-03-21 10:54:00&#39;, &#39;10000000&#39;);
       
   157 </pre></div>
       
   158 </div>
       
   159 </div>
       
   160 <div class="section" id="printing-to-labfolder-projects">
       
   161 <span id="section-cups-user"></span><h2>Printing to labfolder projects<a class="headerlink" href="#printing-to-labfolder-projects" title="Permalink to this headline">¶</a></h2>
       
   162 <p>The last thing you need to do is to set up a printer <em>operating</em> on your local machine. In Ubuntu Gnome hit Alt+F2 keys and enter <code class="docutils literal"><span class="pre">system-config-printer</span></code>. In this printer config interface add a new printer <em>operating</em> as follows:</p>
       
   163 <a class="reference internal image-reference" href="_images/create_local_printer01.png"><img alt="_images/create_local_printer01.png" class="align-center" src="_images/create_local_printer01.png" style="width: 70%;" /></a>
       
   164 <a class="reference internal image-reference" href="_images/create_local_printer02.png"><img alt="_images/create_local_printer02.png" class="align-center" src="_images/create_local_printer02.png" style="width: 70%;" /></a>
       
   165 <a class="reference internal image-reference" href="_images/create_local_printer03.png"><img alt="_images/create_local_printer03.png" class="align-center" src="_images/create_local_printer03.png" style="width: 70%;" /></a>
       
   166 <a class="reference internal image-reference" href="_images/create_local_printer04.png"><img alt="_images/create_local_printer04.png" class="align-center" src="_images/create_local_printer04.png" style="width: 70%;" /></a>
       
   167 <a class="reference internal image-reference" href="_images/create_local_printer05.png"><img alt="_images/create_local_printer05.png" class="align-center" src="_images/create_local_printer05.png" style="width: 70%;" /></a>
       
   168 <a class="reference internal image-reference" href="_images/create_local_printer06.png"><img alt="_images/create_local_printer06.png" class="align-center" src="_images/create_local_printer06.png" style="width: 70%;" /></a>
       
   169 <a class="reference internal image-reference" href="_images/create_local_printer07.png"><img alt="_images/create_local_printer07.png" class="align-center" src="_images/create_local_printer07.png" style="width: 70%;" /></a>
       
   170 </div>
       
   171 </div>
       
   172 
       
   173 
       
   174           </div>
       
   175         </div>
       
   176       </div>
       
   177       <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
       
   178         <div class="sphinxsidebarwrapper"><div class="relations">
       
   179 <h3>Related Topics</h3>
       
   180 <ul>
       
   181   <li><a href="index.html">Documentation overview</a><ul>
       
   182       <li>Previous: <a href="installation.html" title="previous chapter">Installation of labfolder</a></li>
       
   183       <li>Next: <a href="groups.html" title="next chapter">Groups, ownership and sharing in labfolder</a></li>
       
   184   </ul></li>
       
   185 </ul>
       
   186 </div>
       
   187 <div id="searchbox" style="display: none" role="search">
       
   188   <h3>Quick search</h3>
       
   189     <form class="search" action="search.html" method="get">
       
   190       <div><input type="text" name="q" /></div>
       
   191       <div><input type="submit" value="Go" /></div>
       
   192       <input type="hidden" name="check_keywords" value="yes" />
       
   193       <input type="hidden" name="area" value="default" />
       
   194     </form>
       
   195 </div>
       
   196 <script type="text/javascript">$('#searchbox').show(0);</script>
       
   197         </div>
       
   198       </div>
       
   199       <div class="clearer"></div>
       
   200     </div>
       
   201     <div class="footer">
       
   202       &copy;2018, Stefan Weiher.
       
   203       
       
   204       |
       
   205       Powered by <a href="http://sphinx-doc.org/">Sphinx 1.6.6</a>
       
   206       &amp; <a href="https://github.com/bitprophet/alabaster">Alabaster 0.7.10</a>
       
   207       
       
   208       |
       
   209       <a href="_sources/installation_cups.rst.txt"
       
   210           rel="nofollow">Page source</a>
       
   211     </div>
       
   212 
       
   213     
       
   214 
       
   215     
       
   216   </body>
       
   217 </html>