Also provide static methods to retrieve base product and registration data.
[platform/upstream/libzypp.git] / zypp / target / TargetImpl.h
1 /*---------------------------------------------------------------------\
2 |                          ____ _   __ __ ___                          |
3 |                         |__  / \ / / . \ . \                         |
4 |                           / / \ V /|  _/  _/                         |
5 |                          / /__ | | | | | |                           |
6 |                         /_____||_| |_| |_|                           |
7 |                                                                      |
8 \---------------------------------------------------------------------*/
9 /** \file       zypp/target/TargetImpl.h
10  *
11 */
12 #ifndef ZYPP_TARGET_TARGETIMPL_H
13 #define ZYPP_TARGET_TARGETIMPL_H
14
15 #include <iosfwd>
16 #include <list>
17 #include <set>
18
19 #include "zypp/base/ReferenceCounted.h"
20 #include "zypp/base/NonCopyable.h"
21 #include "zypp/base/PtrTypes.h"
22 #include "zypp/PoolItem.h"
23 #include "zypp/ZYppCommit.h"
24
25 #include "zypp/Pathname.h"
26 #include "zypp/media/MediaAccess.h"
27 #include "zypp/Target.h"
28 #include "zypp/target/rpm/RpmDb.h"
29 #include "zypp/target/TargetException.h"
30 #include "zypp/target/RequestedLocalesFile.h"
31 #include "zypp/target/SoftLocksFile.h"
32 #include "zypp/target/HardLocksFile.h"
33
34 ///////////////////////////////////////////////////////////////////
35 namespace zypp
36 { /////////////////////////////////////////////////////////////////
37   ///////////////////////////////////////////////////////////////////
38   namespace target
39   { /////////////////////////////////////////////////////////////////
40
41     DEFINE_PTR_TYPE(TargetImpl);
42     class CommitPackageCache;
43
44     ///////////////////////////////////////////////////////////////////
45     //
46     //  CLASS NAME : TargetImpl
47     //
48     /** Base class for concrete Target implementations.
49      *
50      * Constructed by \ref TargetFactory. Public access via \ref Target
51      * interface.
52     */
53     class TargetImpl : public base::ReferenceCounted, private base::NonCopyable
54     {
55       friend std::ostream & operator<<( std::ostream & str, const TargetImpl & obj );
56
57     public:
58       /** list of pool items  */
59       typedef std::list<PoolItem> PoolItemList;
60
61       /** set of pool items  */
62       typedef std::set<PoolItem> PoolItemSet;
63
64     public:
65       /** Ctor. */
66       TargetImpl(const Pathname & root_r = "/", bool doRebuild_r = false );
67       /** Dtor. */
68       virtual ~TargetImpl();
69
70       /** Null implementation */
71       static TargetImpl_Ptr nullimpl();
72
73       /**
74        * generates the unique anonymous id which is called
75        * when creating the target
76        */
77       void createAnonymousId() const;
78
79       /**
80        * generates a cache of the last product flavor
81        */
82       void createLastDistributionFlavorCache() const;
83
84       /** \name Solv file handling.
85        * If target solv file is outdated, but (non-root-)user has
86        * no permission to  create it at the default location, we
87        * use a temporary one.
88        */
89       //@{
90     private:
91       /** The systems default solv file location. */
92       Pathname defaultSolvfilesPath() const;
93
94       /** The solv file location actually in use (default or temp). */
95       Pathname solvfilesPath() const
96       { return solvfilesPathIsTemp() ? _tmpSolvfilesPath : defaultSolvfilesPath(); }
97
98       /** Whether we're using a temp. solvfile. */
99       bool solvfilesPathIsTemp() const
100       { return ! _tmpSolvfilesPath.empty(); }
101
102       Pathname _tmpSolvfilesPath;
103
104     public:
105       void load();
106
107       void unload();
108
109       void clearCache();
110
111       void buildCache();
112       //@}
113
114     public:
115
116       /** The root set for this target */
117       Pathname root() const
118       { return _root; }
119
120       /** The directory to store things. */
121       Pathname home() const
122       { return _root / "/var/lib/zypp"; }
123
124       /** Commit changes in the pool */
125       ZYppCommitResult commit( ResPool pool_r, const ZYppCommitPolicy & policy_r );
126
127       /** Install a source package on the Target. */
128       void installSrcPackage( const SrcPackage_constPtr & srcPackage_r );
129
130       /** Overload to realize stream output. */
131       virtual std::ostream & dumpOn( std::ostream & str ) const
132       {
133         return str << "TargetImpl";
134       }
135
136       /** The RPM database */
137       rpm::RpmDb & rpm();
138
139       /** If the package is installed and provides the file
140       Needed to evaluate split provides during Resolver::Upgrade() */
141       bool providesFile (const std::string & path_str, const std::string & name_str) const;
142
143       /** Return name of package owning \a path_str
144        * or empty string if no installed package owns \a path_str. */
145       std::string whoOwnsFile (const std::string & path_str) const
146       { return _rpm.whoOwnsFile (path_str); }
147
148       /** return the last modification date of the target */
149       Date timestamp() const;
150
151       /** \copydoc Target::baseProduct() */
152       Product::constPtr baseProduct() const;
153
154
155       /** \copydoc Target::targetDistribution() */
156       std::string targetDistribution() const;
157       /** \overload */
158       static std::string targetDistribution( const Pathname & root_r );
159
160       /** \copydoc Target::targetDistributionRelease()*/
161       std::string targetDistributionRelease() const;
162       /** \overload */
163       static std::string targetDistributionRelease( const Pathname & root_r );
164
165       /** \copydoc Target::distributionVersion()*/
166       std::string distributionVersion() const;
167       /** \overload */
168       static std::string distributionVersion( const Pathname & root_r );
169
170       /** \copydoc Target::distributionFlavor() */
171       std::string distributionFlavor() const;
172       /** \overload */
173       static std::string distributionFlavor( const Pathname & root_r );
174
175       /** \copydoc Target::anonymousUniqueId() */
176       std::string anonymousUniqueId() const;
177       /** \overload */
178       static std::string anonymousUniqueId( const Pathname & root_r );
179
180     private:
181       /** Commit ordered changes (internal helper) */
182       PoolItemList commit( const PoolItemList & items_r,
183                            const ZYppCommitPolicy & policy_r,
184                            ZYppCommitResult & result_r,
185                            CommitPackageCache & packageCache_r );
186
187     protected:
188       /** Path to the target */
189       Pathname _root;
190       /** RPM database */
191       rpm::RpmDb _rpm;
192       /** Requested Locales database */
193       RequestedLocalesFile _requestedLocalesFile;
194       /** Soft-locks database */
195       SoftLocksFile _softLocksFile;
196       /** Hard-Locks database */
197       HardLocksFile _hardLocksFile;
198       /** Cache distributionVersion */
199       mutable std::string _distributionVersion;
200
201     private:
202       /** Null implementation */
203       static TargetImpl_Ptr _nullimpl;
204     };
205     ///////////////////////////////////////////////////////////////////
206
207     /** \relates TargetImpl Stream output */
208     inline std::ostream & operator<<( std::ostream & str, const TargetImpl & obj )
209     {
210       return obj.dumpOn( str );
211     }
212
213     /////////////////////////////////////////////////////////////////
214   } // namespace target
215   ///////////////////////////////////////////////////////////////////
216   /////////////////////////////////////////////////////////////////
217 } // namespace zypp
218 ///////////////////////////////////////////////////////////////////
219 #endif // ZYPP_TARGET_TARGETIMPL_H