author | Edward Pilatowicz <edward.pilatowicz@oracle.com> |
Mon, 16 Sep 2013 21:26:31 -0700 | |
changeset 2945 | 24196b483cc6 |
parent 1923 | 8d42b7caa49d |
permissions | -rw-r--r-- |
1923
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
1 |
.. CDDL HEADER START |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
2 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
3 |
.. The contents of this file are subject to the terms of the |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
4 |
Common Development and Distribution License (the "License"). |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
5 |
You may not use this file except in compliance with the License. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
6 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
7 |
.. You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
8 |
or http://www.opensolaris.org/os/licensing. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
9 |
See the License for the specific language governing permissions |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
10 |
and limitations under the License. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
11 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
12 |
.. When distributing Covered Code, include this CDDL HEADER in each |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
13 |
file and include the License file at usr/src/OPENSOLARIS.LICENSE. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
14 |
If applicable, add the following below this CDDL HEADER, with the |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
15 |
fields enclosed by brackets "[]" replaced with your own identifying |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
16 |
information: Portions Copyright [yyyy] [name of copyright owner] |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
17 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
18 |
.. CDDL HEADER END |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
19 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
20 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
21 |
.. Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
22 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
23 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
24 |
When communicating with the depot server via HTTP, operations are |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
25 |
presented via a URL-based mechanism that allows each to be versioned so |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
26 |
that changes in protocol can be hidden from older clients as the |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
27 |
interfaces to operations evolve. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
28 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
29 |
Operations made available by a |depotd1m| server can be accessed via |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
30 |
GET or POST, as appropriate for each operation, via a URL such as the |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
31 |
following: |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
32 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
33 |
http://pkg.opensolaris.org/release/manifest/0/SUNWvim%407.1.284%2C5.11-0.101%3A20081119T230659Z |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
34 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
35 |
The above example can be broken down into four basic components: |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
36 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
37 |
publisher_origin_url - http://pkg.opensolaris.org/release/ |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
38 |
operation_name - manifest |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
39 |
protocol_version - 0 |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
40 |
operation_arguments - SUNWvim%407.1.284%2C5.11-0.101%3A20081119T230659Z |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
41 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
42 |
Each of these components can be described as follows: |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
43 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
44 |
publisher_origin_url - A URL that can be used to access a depot |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
45 |
server's repository. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
46 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
47 |
operation_name - The name of the operation that the client is |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
48 |
wanting to initiate. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
49 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
50 |
protocol_version - An integer value representing the version of |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
51 |
the operation's protocol spoken by the client. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
52 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
53 |
operation_arguments - String data (such as a package FMRI) that is |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
54 |
parsed and then used to determine what |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
55 |
resource(s) will be used to perform an |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
56 |
operation. Some operations expect arguments |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
57 |
or data to be passed via POST-based form data, |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
58 |
headers, or the request body instead. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
59 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
60 |
Operation Types |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
61 |
--------------- |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
62 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
63 |
Each operation that the depot server provides is either designed to interact |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
64 |
with a pkg(5) repository, or with the depot server itself. These operations |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
65 |
can be categorized as follows: |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
66 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
67 |
- content |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
68 |
These operations are read-only, and retrieve file data that comprises |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
69 |
the content of a package in a repository. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
70 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
71 |
- depot |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
72 |
These operations are read-only, and permit retrieval of: the list of |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
73 |
operations that the depot server currently provides (including protocol |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
74 |
version and pkg(5) software version), statistics information, and other |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
75 |
depot information. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
76 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
77 |
- metadata |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
78 |
These operations are read-only, and retrieve metadata related to a |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
79 |
package FMRI, such as its name, version, etc. stored in a repository's |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
80 |
catalog. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
81 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
82 |
- publishing |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
83 |
These operations alter a repository's catalog, package metadata, and |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
84 |
allow storage of package content. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
85 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
86 |
Modes |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
87 |
----- |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
88 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
89 |
Which types of operations are available is dependent on which mode the |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
90 |
depot server is currently operating in: |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
91 |
|
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
92 |
- default |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
93 |
In default mode, the depot server allows content, depot, metadata, |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
94 |
and publishing operations. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
95 |
- readonly |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
96 |
In readonly mode, the depot server allows content, depot, and |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
97 |
metadata operations. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
98 |
- mirror |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
99 |
In mirror mode, the depot server allows content and depot |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
100 |
operations. |
8d42b7caa49d
16081 begin a developer guide for pkg(5)
Stephen Hahn <stephen.hahn@oracle.com>
parents:
diff
changeset
|
101 |