This file is indexed.

/usr/share/doc/libosgi-compendium-java/api/org/osgi/service/http/HttpService.html is in libosgi-compendium-java-doc 5.0.0-5.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<!-- NewPage -->
<html>
<head>
<!-- Generated by javadoc -->
<title>HttpService</title>
<link rel="stylesheet" type="text/css" href="../../../../stylesheet.css" title="Style">
<script type="text/javascript" src="../../../../script.js"></script>
</head>
<body>
<script type="text/javascript"><!--
    try {
        if (location.href.indexOf('is-external=true') == -1) {
            parent.document.title="HttpService";
        }
    }
    catch(err) {
    }
//-->
var methods = {"i0":6,"i1":6,"i2":6,"i3":6};
var tabs = {65535:["t0","All Methods"],2:["t2","Instance Methods"],4:["t3","Abstract Methods"]};
var altColor = "altColor";
var rowColor = "rowColor";
var tableTab = "tableTab";
var activeTableTab = "activeTableTab";
</script>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
<!-- ========= START OF TOP NAVBAR ======= -->
<div class="topNav"><a name="navbar.top">
<!--   -->
</a>
<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation links">Skip navigation links</a></div>
<a name="navbar.top.firstrow">
<!--   -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../../overview-summary.html">Overview</a></li>
<li><a href="package-summary.html">Package</a></li>
<li class="navBarCell1Rev">Class</li>
<li><a href="package-tree.html">Tree</a></li>
<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
<li><a href="../../../../index-all.html">Index</a></li>
<li><a href="../../../../help-doc.html">Help</a></li>
</ul>
</div>
<div class="subNav">
<ul class="navList">
<li><a href="../../../../org/osgi/service/http/HttpContext.html" title="interface in org.osgi.service.http"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
<li><a href="../../../../org/osgi/service/http/NamespaceException.html" title="class in org.osgi.service.http"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../../index.html?org/osgi/service/http/HttpService.html" target="_top">Frames</a></li>
<li><a href="HttpService.html" target="_top">No&nbsp;Frames</a></li>
</ul>
<ul class="navList" id="allclasses_navbar_top">
<li><a href="../../../../allclasses-noframe.html">All&nbsp;Classes</a></li>
</ul>
<div>
<script type="text/javascript"><!--
  allClassesLink = document.getElementById("allclasses_navbar_top");
  if(window==top) {
    allClassesLink.style.display = "block";
  }
  else {
    allClassesLink.style.display = "none";
  }
  //-->
</script>
</div>
<div>
<ul class="subNavList">
<li>Summary:&nbsp;</li>
<li>Nested&nbsp;|&nbsp;</li>
<li>Field&nbsp;|&nbsp;</li>
<li>Constr&nbsp;|&nbsp;</li>
<li><a href="#method.summary">Method</a></li>
</ul>
<ul class="subNavList">
<li>Detail:&nbsp;</li>
<li>Field&nbsp;|&nbsp;</li>
<li>Constr&nbsp;|&nbsp;</li>
<li><a href="#method.detail">Method</a></li>
</ul>
</div>
<a name="skip.navbar.top">
<!--   -->
</a></div>
<!-- ========= END OF TOP NAVBAR ========= -->
<!-- ======== START OF CLASS DATA ======== -->
<div class="header">
<div class="subTitle">org.osgi.service.http</div>
<h2 title="Interface HttpService" class="title">Interface HttpService</h2>
</div>
<div class="contentContainer">
<div class="description">
<ul class="blockList">
<li class="blockList">
<hr>
<br>
<pre>public interface <span class="typeNameLabel">HttpService</span></pre>
<div class="block">The Http Service allows other bundles in the OSGi environment to dynamically
 register resources and servlets into the URI namespace of Http Service. A
 bundle may later unregister its resources or servlets.</div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
<dd><a href="../../../../org/osgi/service/http/HttpContext.html" title="interface in org.osgi.service.http"><code>HttpContext</code></a></dd>
</dl>
</li>
</ul>
</div>
<div class="summary">
<ul class="blockList">
<li class="blockList">
<!-- ========== METHOD SUMMARY =========== -->
<ul class="blockList">
<li class="blockList"><a name="method.summary">
<!--   -->
</a>
<h3>Method Summary</h3>
<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="Method Summary table, listing methods, and an explanation">
<caption><span id="t0" class="activeTableTab"><span>All Methods</span><span class="tabEnd">&nbsp;</span></span><span id="t2" class="tableTab"><span><a href="javascript:show(2);">Instance Methods</a></span><span class="tabEnd">&nbsp;</span></span><span id="t3" class="tableTab"><span><a href="javascript:show(4);">Abstract Methods</a></span><span class="tabEnd">&nbsp;</span></span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colLast" scope="col">Method and Description</th>
</tr>
<tr id="i0" class="altColor">
<td class="colFirst"><code><a href="../../../../org/osgi/service/http/HttpContext.html" title="interface in org.osgi.service.http">HttpContext</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../org/osgi/service/http/HttpService.html#createDefaultHttpContext--">createDefaultHttpContext</a></span>()</code>
<div class="block">Creates a default <code>HttpContext</code> for registering servlets or
 resources with the HttpService, a new <code>HttpContext</code> object is
 created each time this method is called.</div>
</td>
</tr>
<tr id="i1" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../org/osgi/service/http/HttpService.html#registerResources-java.lang.String-java.lang.String-org.osgi.service.http.HttpContext-">registerResources</a></span>(java.lang.String&nbsp;alias,
                 java.lang.String&nbsp;name,
                 <a href="../../../../org/osgi/service/http/HttpContext.html" title="interface in org.osgi.service.http">HttpContext</a>&nbsp;context)</code>
<div class="block">Registers resources into the URI namespace.</div>
</td>
</tr>
<tr id="i2" class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../org/osgi/service/http/HttpService.html#registerServlet-java.lang.String-javax.servlet.Servlet-java.util.Dictionary-org.osgi.service.http.HttpContext-">registerServlet</a></span>(java.lang.String&nbsp;alias,
               javax.servlet.Servlet&nbsp;servlet,
               java.util.Dictionary&nbsp;initparams,
               <a href="../../../../org/osgi/service/http/HttpContext.html" title="interface in org.osgi.service.http">HttpContext</a>&nbsp;context)</code>
<div class="block">Registers a servlet into the URI namespace.</div>
</td>
</tr>
<tr id="i3" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../org/osgi/service/http/HttpService.html#unregister-java.lang.String-">unregister</a></span>(java.lang.String&nbsp;alias)</code>
<div class="block">Unregisters a previous registration done by <code>registerServlet</code> or
 <code>registerResources</code> methods.</div>
</td>
</tr>
</table>
</li>
</ul>
</li>
</ul>
</div>
<div class="details">
<ul class="blockList">
<li class="blockList">
<!-- ============ METHOD DETAIL ========== -->
<ul class="blockList">
<li class="blockList"><a name="method.detail">
<!--   -->
</a>
<h3>Method Detail</h3>
<a name="registerServlet-java.lang.String-javax.servlet.Servlet-java.util.Dictionary-org.osgi.service.http.HttpContext-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>registerServlet</h4>
<pre>void&nbsp;registerServlet(java.lang.String&nbsp;alias,
                     javax.servlet.Servlet&nbsp;servlet,
                     java.util.Dictionary&nbsp;initparams,
                     <a href="../../../../org/osgi/service/http/HttpContext.html" title="interface in org.osgi.service.http">HttpContext</a>&nbsp;context)
              throws javax.servlet.ServletException,
                     <a href="../../../../org/osgi/service/http/NamespaceException.html" title="class in org.osgi.service.http">NamespaceException</a></pre>
<div class="block">Registers a servlet into the URI namespace.
 
 <p>
 The alias is the name in the URI namespace of the Http Service at which
 the registration will be mapped.
 
 <p>
 An alias must begin with slash ('/') and must not end with slash ('/'),
 with the exception that an alias of the form &quot;/&quot; is used to
 denote the root alias. See the specification text for details on how HTTP
 requests are mapped to servlet and resource registrations.
 
 <p>
 The Http Service will call the servlet's <code>init</code> method before
 returning.
 
 <pre>
 httpService.registerServlet(&quot;/myservlet&quot;, servlet, initparams, context);
 </pre>
 
 <p>
 Servlets registered with the same <code>HttpContext</code> object will share
 the same <code>ServletContext</code>. The Http Service will call the
 <code>context</code> argument to support the <code>ServletContext</code> methods
 <code>getResource</code>,<code>getResourceAsStream</code> and <code>getMimeType</code>,
 and to handle security for requests. If the <code>context</code> argument is
 <code>null</code>, a default <code>HttpContext</code> object is used (see
 <a href="../../../../org/osgi/service/http/HttpService.html#createDefaultHttpContext--"><code>createDefaultHttpContext()</code></a>).</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>alias</code> - name in the URI namespace at which the servlet is registered</dd>
<dd><code>servlet</code> - the servlet object to register</dd>
<dd><code>initparams</code> - initialization arguments for the servlet or
        <code>null</code> if there are none. This argument is used by the
        servlet's <code>ServletConfig</code> object.</dd>
<dd><code>context</code> - the <code>HttpContext</code> object for the registered servlet,
        or <code>null</code> if a default <code>HttpContext</code> is to be created
        and used.</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code><a href="../../../../org/osgi/service/http/NamespaceException.html" title="class in org.osgi.service.http">NamespaceException</a></code> - if the registration fails because the alias is
         already in use.</dd>
<dd><code>javax.servlet.ServletException</code> - if the servlet's <code>init</code>
         method throws an exception, or the given servlet object has
         already been registered at a different alias.</dd>
<dd><code>java.lang.IllegalArgumentException</code> - if any of the arguments are
         invalid</dd>
</dl>
</li>
</ul>
<a name="registerResources-java.lang.String-java.lang.String-org.osgi.service.http.HttpContext-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>registerResources</h4>
<pre>void&nbsp;registerResources(java.lang.String&nbsp;alias,
                       java.lang.String&nbsp;name,
                       <a href="../../../../org/osgi/service/http/HttpContext.html" title="interface in org.osgi.service.http">HttpContext</a>&nbsp;context)
                throws <a href="../../../../org/osgi/service/http/NamespaceException.html" title="class in org.osgi.service.http">NamespaceException</a></pre>
<div class="block">Registers resources into the URI namespace.
 
 <p>
 The alias is the name in the URI namespace of the Http Service at which
 the registration will be mapped. An alias must begin with slash ('/') and
 must not end with slash ('/'), with the exception that an alias of the
 form &quot;/&quot; is used to denote the root alias. The name parameter
 must also not end with slash ('/') with the exception that a name of the
 form &quot;/&quot; is used to denote the root of the bundle. See the
 specification text for details on how HTTP requests are mapped to servlet
 and resource registrations.
 <p>
 For example, suppose the resource name /tmp is registered to the alias
 /files. A request for /files/foo.txt will map to the resource name
 /tmp/foo.txt.
 
 <pre>
 httpservice.registerResources(&quot;/files&quot;, &quot;/tmp&quot;, context);
 </pre>
 
 The Http Service will call the <code>HttpContext</code> argument to map
 resource names to URLs and MIME types and to handle security for
 requests. If the <code>HttpContext</code> argument is <code>null</code>, a default
 <code>HttpContext</code> is used (see <a href="../../../../org/osgi/service/http/HttpService.html#createDefaultHttpContext--"><code>createDefaultHttpContext()</code></a>).</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>alias</code> - name in the URI namespace at which the resources are
        registered</dd>
<dd><code>name</code> - the base name of the resources that will be registered</dd>
<dd><code>context</code> - the <code>HttpContext</code> object for the registered
        resources, or <code>null</code> if a default <code>HttpContext</code> is to
        be created and used.</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code><a href="../../../../org/osgi/service/http/NamespaceException.html" title="class in org.osgi.service.http">NamespaceException</a></code> - if the registration fails because the alias is
         already in use.</dd>
<dd><code>java.lang.IllegalArgumentException</code> - if any of the parameters are
         invalid</dd>
</dl>
</li>
</ul>
<a name="unregister-java.lang.String-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>unregister</h4>
<pre>void&nbsp;unregister(java.lang.String&nbsp;alias)</pre>
<div class="block">Unregisters a previous registration done by <code>registerServlet</code> or
 <code>registerResources</code> methods.
 
 <p>
 After this call, the registered alias in the URI name-space will no
 longer be available. If the registration was for a servlet, the Http
 Service must call the <code>destroy</code> method of the servlet before
 returning.
 <p>
 If the bundle which performed the registration is stopped or otherwise
 "unget"s the Http Service without calling <a href="../../../../org/osgi/service/http/HttpService.html#unregister-java.lang.String-"><code>unregister(String)</code></a>
 then Http Service must automatically unregister the registration.
 However, if the registration was for a servlet, the <code>destroy</code>
 method of the servlet will not be called in this case since the bundle
 may be stopped. <a href="../../../../org/osgi/service/http/HttpService.html#unregister-java.lang.String-"><code>unregister(String)</code></a> must be explicitly called to
 cause the <code>destroy</code> method of the servlet to be called. This can be
 done in the <code>BundleActivator.stop</code> method of the bundle registering
 the servlet.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>alias</code> - name in the URI name-space of the registration to unregister</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - if there is no registration
         for the alias or the calling bundle was not the bundle which
         registered the alias.</dd>
</dl>
</li>
</ul>
<a name="createDefaultHttpContext--">
<!--   -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>createDefaultHttpContext</h4>
<pre><a href="../../../../org/osgi/service/http/HttpContext.html" title="interface in org.osgi.service.http">HttpContext</a>&nbsp;createDefaultHttpContext()</pre>
<div class="block">Creates a default <code>HttpContext</code> for registering servlets or
 resources with the HttpService, a new <code>HttpContext</code> object is
 created each time this method is called.
 
 <p>
 The behavior of the methods on the default <code>HttpContext</code> is defined
 as follows:
 <ul>
 <li><code>getMimeType</code> - Does not define any customized MIME types for
 the Content-Type header in the response, and always returns <code>null</code>.
 </li>
 <li><code>handleSecurity</code> - Performs implementation-defined
 authentication on the request.</li>
 <li><code>getResource</code> - Assumes the named resource is in the context
 bundle; this method calls the context bundle's <code>Bundle.getResource</code>
 method, and returns the appropriate URL to access the resource. On a Java
 runtime environment that supports permissions, the Http Service needs to
 be granted <code>org.osgi.framework.AdminPermission[*,RESOURCE]</code>.</li>
 </ul></div>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>a default <code>HttpContext</code> object.</dd>
<dt><span class="simpleTagLabel">Since:</span></dt>
<dd>1.1</dd>
</dl>
</li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
</div>
<!-- ========= END OF CLASS DATA ========= -->
<!-- ======= START OF BOTTOM NAVBAR ====== -->
<div class="bottomNav"><a name="navbar.bottom">
<!--   -->
</a>
<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation links">Skip navigation links</a></div>
<a name="navbar.bottom.firstrow">
<!--   -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../../overview-summary.html">Overview</a></li>
<li><a href="package-summary.html">Package</a></li>
<li class="navBarCell1Rev">Class</li>
<li><a href="package-tree.html">Tree</a></li>
<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
<li><a href="../../../../index-all.html">Index</a></li>
<li><a href="../../../../help-doc.html">Help</a></li>
</ul>
</div>
<div class="subNav">
<ul class="navList">
<li><a href="../../../../org/osgi/service/http/HttpContext.html" title="interface in org.osgi.service.http"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
<li><a href="../../../../org/osgi/service/http/NamespaceException.html" title="class in org.osgi.service.http"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../../index.html?org/osgi/service/http/HttpService.html" target="_top">Frames</a></li>
<li><a href="HttpService.html" target="_top">No&nbsp;Frames</a></li>
</ul>
<ul class="navList" id="allclasses_navbar_bottom">
<li><a href="../../../../allclasses-noframe.html">All&nbsp;Classes</a></li>
</ul>
<div>
<script type="text/javascript"><!--
  allClassesLink = document.getElementById("allclasses_navbar_bottom");
  if(window==top) {
    allClassesLink.style.display = "block";
  }
  else {
    allClassesLink.style.display = "none";
  }
  //-->
</script>
</div>
<div>
<ul class="subNavList">
<li>Summary:&nbsp;</li>
<li>Nested&nbsp;|&nbsp;</li>
<li>Field&nbsp;|&nbsp;</li>
<li>Constr&nbsp;|&nbsp;</li>
<li><a href="#method.summary">Method</a></li>
</ul>
<ul class="subNavList">
<li>Detail:&nbsp;</li>
<li>Field&nbsp;|&nbsp;</li>
<li>Constr&nbsp;|&nbsp;</li>
<li><a href="#method.detail">Method</a></li>
</ul>
</div>
<a name="skip.navbar.bottom">
<!--   -->
</a></div>
<!-- ======== END OF BOTTOM NAVBAR ======= -->
</body>
</html>