|
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 — 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 "man cupsd.conf" 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 "warn" to "debug"</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' 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"><</span><span class="n">name</span><span class="o">></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"><</span><span class="n">Location</span> <span class="o">/></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"></</span><span class="n">Location</span><span class="o">></span> |
|
101 |
|
102 <span class="c1"># Restrict access to the admin pages...</span> |
|
103 <span class="o"><</span><span class="n">Location</span> <span class="o">/</span><span class="n">admin</span><span class="o">></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"></</span><span class="n">Location</span><span class="o">></span> |
|
113 |
|
114 <span class="c1"># Restrict access to configuration files...</span> |
|
115 <span class="o"><</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">></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"></</span><span class="n">Location</span><span class="o">></span> |
|
126 |
|
127 <span class="c1"># Set the default printer/job policies...</span> |
|
128 <span class="o"><</span><span class="n">Policy</span> <span class="n">default</span><span class="o">></span> |
|
129 <span class="o">...</span> <span class="c1"># probably as in the original</span> |
|
130 <span class="o"></</span><span class="n">Policy</span><span class="o">></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> use labfolder; |
|
156 mysql> INSERT INTO user (email, password, firstname, lastname, signupTimestamp, maxStorage) VALUES ('printer@fhi-berlin.mpg.de', '91a13f2aba4a35b00c35dfacadd1d75f4a5171dfa7a465fca9c40e6b007ce982', 'Printer', 'Print', '2018-03-21 10:54:00', '10000000'); |
|
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 ©2018, Stefan Weiher. |
|
203 |
|
204 | |
|
205 Powered by <a href="http://sphinx-doc.org/">Sphinx 1.6.6</a> |
|
206 & <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> |