18 #include <zypp-core/base/DefaultIntegral> 22 #include <zypp-common/PublicKey.h> 34 #include <zypp-core/base/InputStream> 56 repo::RepoType probeCache(
const Pathname & path_r )
59 if ( PathInfo(path_r).isDir() )
61 if ( PathInfo(path_r/
"/repodata/repomd.xml").isFile() )
63 else if ( PathInfo(path_r/
"/content").isFile() )
65 else if ( PathInfo(path_r/
"/cookie").isFile() )
68 DBG <<
"Probed cached type " << ret <<
" at " << path_r << endl;
85 ,
_type(repo::RepoType::NONE_e)
123 std::string licenseStem(
"license" );
124 if ( !name_r.empty() )
127 licenseStem += name_r;
181 bool isAutoMirrorList =
false;
192 MIL <<
"Detected opensuse.org baseUrl with no mirrors, requesting them from : " << mlurl.
asString() << std::endl;
193 isAutoMirrorList =
true;
214 MIL <<
"Mirrorlist failed, repo either returns invalid data or has no mirrors at all, falling back to only baseUrl!" << std::endl;
215 if ( !isAutoMirrorList ) {
217 data.
set(
"error", e );
229 std::vector<std::vector<Url>> urlGroups;
235 urlGroups.push_back ( {
url } );
239 if ( dlUrlIndex >= 0) {
240 urlGroups[dlUrlIndex].push_back (
url );
245 urlGroups.push_back ( {
url} );
246 dlUrlIndex = urlGroups.size() - 1;
270 return (*
baseUrls().transformedBegin()).asString();
271 return std::string();
304 [
this](
int num_r,
const std::string& line_r )->
bool 308 std::vector<std::string> words;
309 if (
str::split( line_r, std::back_inserter(words) ) > 1
310 && words[0].length() == 12 )
312 this->
_keywords.second.insert( ++words.begin(), words.end() );
343 return indeterminate;
351 if (
PathInfo(gpgcheckFile).isExist() )
353 TriBool linkval( indeterminate );
376 static const Pathname truePath(
"true" );
377 static const Pathname falsePath(
"false" );
378 static const Pathname indeterminatePath(
"indeterminate" );
381 static const ssize_t bufsiz = 63;
382 static char buf[bufsiz+1];
384 buf[ret == -1 ? 0 : ret] =
'\0';
389 if ( linkval == truePath )
391 else if ( linkval == falsePath )
393 else if ( linkval == indeterminatePath )
394 ret_r = indeterminate;
494 mutable std::pair<FalseBool, std::set<std::string> >
_keywords;
498 friend Impl * rwcowClone<Impl>(
const Impl * rhs );
501 {
return new Impl( *
this ); }
508 return str <<
"RepoInfo::Impl";
520 : _pimpl( new
Impl() )
596 {
if ( ! sameTriboolState( lhs, rhs ) ) { lhs = rhs;
return true; }
return false; }
600 bool changed =
false;
601 if ( changeGpgCheckTo( ogpg[0], g ) ) changed =
true;
602 if ( changeGpgCheckTo( ogpg[1], r ) ) changed =
true;
603 if ( changeGpgCheckTo( ogpg[2], p ) ) changed =
true;
613 bool changed =
false;
617 changed = changeGpgCheckTo( ogpg,
true, indeterminate, indeterminate );
620 changed = changeGpgCheckTo( ogpg,
true,
true,
true );
623 changed = changeGpgCheckTo( ogpg,
true,
false,
false );
626 changed = changeGpgCheckTo( ogpg,
true,
false, indeterminate );
629 changed = changeGpgCheckTo( ogpg,
true, indeterminate,
false );
632 changed = changeGpgCheckTo( ogpg, indeterminate, indeterminate, indeterminate );
635 changed = changeGpgCheckTo( ogpg,
false, indeterminate, indeterminate );
663 void RepoInfo::setMirrorListUrl(
const Url & url_r )
665 void RepoInfo::setMirrorListUrls( url_set urls )
667 void RepoInfo::setMetalinkUrls( url_set urls )
857 if ( licenseTgz.empty() )
861 cmd.push_back(
"tar" );
862 cmd.push_back(
"-t" );
863 cmd.push_back(
"-z" );
864 cmd.push_back(
"-f" );
865 cmd.push_back( licenseTgz.asString() );
869 static const std::string noAcceptanceFile =
"no-acceptance-needed\n";
872 if ( output == noAcceptanceFile )
878 MIL <<
"License(" << name_r <<
") in " <<
name() <<
" has to be accepted: " << (accept?
"true":
"false" ) << endl;
887 {
return getLicense( std::string(), lang_r ); }
892 if ( avlocales.empty() )
893 return std::string();
896 if ( !getLang && avlocales.find(
Locale::noCode ) == avlocales.end() )
898 WAR <<
"License(" << name_r <<
") in " <<
name() <<
" contains no fallback text!" << endl;
902 getLang = *avlocales.begin();
906 static const std::string licenseFileFallback(
"license.txt" );
907 std::string licenseFile( !getLang ? licenseFileFallback
911 cmd.push_back(
"tar" );
912 cmd.push_back(
"-x" );
913 cmd.push_back(
"-z" );
914 cmd.push_back(
"-O" );
915 cmd.push_back(
"-f" );
917 cmd.push_back( licenseFile );
936 if ( licenseTgz.empty() )
940 cmd.push_back(
"tar" );
941 cmd.push_back(
"-t" );
942 cmd.push_back(
"-z" );
943 cmd.push_back(
"-f" );
944 cmd.push_back( licenseTgz.asString() );
950 static const C_Str license(
"license." );
951 static const C_Str dotTxt(
".txt\n" );
954 if ( output.size() <= license.
size() + dotTxt.
size() )
957 ret.insert(
Locale( std::string( output.c_str()+license.
size(), output.size()- license.
size() - dotTxt.
size() ) ) );
973 str <<
"- url : " <<
url << std::endl;
978 auto strif( [&] (
const std::string & tag_r,
const std::string & value_r ) {
979 if ( ! value_r.empty() )
980 str << tag_r << value_r << std::endl;
986 str <<
"- type : " <<
type() << std::endl;
990 #define OUTS(T,B) ( indeterminate(T) ? (std::string("D(")+(B?"Y":"N")+")") : ((bool)T?"Y":"N") ) 1000 str <<
"- gpgkey : " <<
url << std::endl;
1006 strif(
"- service : ",
service() );
1019 str <<
"# Repository '"<<
alias()<<
"' is maintained by the '"<<
service()<<
"' service." << endl;
1020 str <<
"# Manual changes may be overwritten by a service refresh." << endl;
1021 str <<
"# See also 'man zypper', section 'Services'." << endl;
1023 RepoInfoBase::dumpAsIniOn(
str);
1032 if ( indent.empty() ) indent =
" ";
1037 str <<
"path="<<
path() << endl;
1061 std::string indent(
"gpgkey=");
1064 str << indent <<
url << endl;
1065 if ( indent[0] !=
' ' )
1089 <<
" priority=\"" <<
priority() <<
"\"" 1090 <<
" enabled=\"" <<
enabled() <<
"\"" 1092 <<
" gpgcheck=\"" <<
gpgCheck() <<
"\"" 1102 str <<
" gpgkey=\"" <<
escape(tmpstr) <<
"\"";
1104 str <<
" mirrorlist=\"" <<
escape(tmpstr) <<
"\"";
1106 str <<
" metalink=\"" <<
escape(tmpstr) <<
"\"";
1112 str <<
"<url>" <<
escape((*it).asString()) <<
"</url>" << endl;
1115 str <<
"</repo>" << endl;
1129 #define OUTS( V ) case RepoInfo::V: return str << #V; break 1130 OUTS( GpgCheck::On );
1131 OUTS( GpgCheck::Strict );
1132 OUTS( GpgCheck::AllowUnsigned );
1133 OUTS( GpgCheck::AllowUnsignedRepo );
1134 OUTS( GpgCheck::AllowUnsignedPackage );
1136 OUTS( GpgCheck::Off );
1137 OUTS( GpgCheck::indeterminate );
1140 return str <<
"GpgCheck::UNKNOWN";
1149 if ( canSkipMediaCheck ) {
1151 if ( not mDataPath.empty() ) {
1152 PathInfo mediafile { mDataPath/
"media.1/media" };
1153 if ( mediafile.isExist() ) {
1155 if ( lverifier && lverifier.totalMedia() > 1 ) {
1156 canSkipMediaCheck =
false;
1161 if ( canSkipMediaCheck )
1162 DBG <<
"Can SKIP media.1/media check for status calc of repo " <<
alias() << endl;
1163 return not canSkipMediaCheck;
std::string asString(const Patch::Category &obj)
static const Locale noCode
Empty code.
const RepoVariablesReplacedUrl & mirrorListUrl() const
THE mirrorListUrl to work with (either_cfgMirrorlistUrl or _cfgMetalinkUrl)
Pathname filepath() const
File where this repo was read from.
static const ContentType repoRefreshMirrorlist
const RepoVariablesReplacedUrl & cfgMirrorlistUrl() const
Config file writing needs to tell them appart.
void setBaseUrl(Url url)
Clears current base URL list and adds url.
bool effectiveBaseUrlsEmpty() const
whether effective repository urls are available
Pathname path() const
Repository path.
unsigned priority() const
Repository priority for solver.
bool hasLicense() const
Whether there is a license associated with the repo.
url_set gpgKeyUrls() const
The list of gpgkey URLs defined for this repo.
ZYPP_API detail::EscapedString escape(const std::string &in_r)
Escape xml special charaters (& -> &; from IoBind library).
void setGpgKeyUrl(const Url &gpgkey)
(leagcy API) Set the gpgkey URL defined for this repo
static unsigned defaultPriority()
The default priority (99).
Url rawGpgKeyUrl() const
(leagcy API) The 1st raw gpgkey URL defined for this repo (no variables replaced) ...
Url rawUrl() const
Pars pro toto: The first repository raw url (no variables replaced) this is either rawBaseUrls()...
TriBool rawPkgGpgCheck() const
const std::set< std::string > & contentKeywords() const
Content keywords defined.
boost::logic::tribool TriBool
3-state boolean logic (true, false and indeterminate).
void packagesPath(Pathname new_r)
void setQueryParam(const std::string ¶m, const std::string &value)
Set or add value for the specified query parameter.
static ZConfig & instance()
Singleton ctor.
std::string service() const
Gets name of the service to which this repository belongs or empty string if it has been added manual...
bool usesAutoMetadataPaths() const
void setProbedType(const repo::RepoType &t) const
This allows to adjust the RepoType lazy, from NONE to some probed value, even for const objects...
void setPriority(unsigned newval_r)
Set repository priority for solver.
zypp::Url propagateQueryParams(zypp::Url url_r, const zypp::Url &template_r)
int readlink(const Pathname &symlink_r, Pathname &target_r)
Like 'readlink'.
void rawGpgCheck(TriBool val_r)
RWCOW_pointer< Impl > _pimpl
Pointer to implementation.
Url rawCfgMetalinkUrl() const
The configured raw metalink url.
RepoVariablesReplacedUrl _cfgMirrorlistUrl
std::unordered_set< Locale > LocaleSet
#define for_(IT, BEG, END)
Convenient for-loops using iterator.
const char * c_str() const
String representation.
std::ostream & operator<<(std::ostream &str, const RepoInfo::Impl &obj)
bool pkgGpgCheckIsMandatory() const
Mandatory check (pkgGpgCheck is not off) must ask to confirm using unsigned packages.
int forEachLine(std::istream &str_r, const function< bool(int, std::string)> &consume_r)
Simple lineparser: Call functor consume_r for each line.
url_set rawGpgKeyUrls() const
The list of raw gpgkey URLs defined for this repo (no variables replaced)
String related utilities and Regular expression matching.
std::vector< std::vector< Url > > groupedBaseUrls() const
std::ostream & operator<<(std::ostream &str, const SerialNumber &obj)
What is known about a repository.
static bool warning(const std::string &msg_r, const UserData &userData_r=UserData())
send warning text
void setGpgCheck(TriBool value_r)
Set the value for gpgCheck (or indeterminate to use the default).
TriBool _rawPkgGpgCheck
need to check pkg sign.: Y/N/(ZConf(Y/N/gpgCheck))
std::string receiveLine()
Read one line from the input stream.
Request the standard behavior (as defined in zypp.conf or 'Job')
const RepoVariablesReplacedUrl & cfgMetalinkUrl() const
Config file writing needs to tell them appart.
std::string form(const char *format,...) __attribute__((format(printf
Printf style construction of std::string.
bool enabled() const
If enabled is false, then this repository must be ignored as if does not exists, except when checking...
void internalSetValidRepoSignature(TriBool value_r)
Url gpgKeyUrl() const
(leagcy API) The 1st gpgkey URL defined for this repo
RepoVariablesReplacedUrl baseUrl() const
TriBool internalValidRepoSignature() const
Signature check result needs to be stored/retrieved from _metadataPath.
bool repoGpgCheck() const
Whether the signature of repo metadata should be checked for this repo.
base::ContainerTransform< std::list< Url >, repo::RepoVariablesUrlReplacer > RepoVariablesReplacedUrlList
bool triBoolFromPath(const Pathname &path_r, TriBool &ret_r) const
const_iterator begin() const
Iterator pointing to the first result.
void setValidRepoSignature(TriBool value_r)
Set the value for validRepoSignature (or indeterminate if unsigned).
urls_const_iterator baseUrlsBegin() const
iterator that points at begin of repository urls
bool seekToNode(int depth_r, const std::string &name_r)
bool baseUrlsEmpty() const
whether repository urls are available
void setMirrorlistUrl(const Url &url)
Set the raw mirrorlist url.
const std::string & asString() const
RepoVariablesReplacedUrlList _baseUrls
static Locale bestMatch(const LocaleSet &avLocales_r, Locale requested_r=Locale())
Return the best match for Locale requested_r within the available avLocales_r.
Url url() const
Pars pro toto: The first repository url, this is either baseUrls().front() or if no baseUrl is define...
Url mirrorListUrl() const
Url of a file which contains a list of repository urls.
bool empty() const
Test for an empty path.
url_set effectiveBaseUrls() const
The complete set of effective repository urls.
bool keepPackages() const
Whether packages downloaded from this repository will be kept in local cache.
unsigned split(const C_Str &line_r, TOutputIterator result_r, const C_Str &sepchars_r=" \, const Trim trim_r=NO_TRIM)
Split line_r into words.
std::string asString() const
Returns a default string representation of the Url object.
bool gpgKeyUrlsEmpty() const
Whether gpgkey URLs are defined.
Url rawCfgMirrorlistUrl() const
The configured raw mirrorlist url.
GpgCheck
Some predefined settings.
TriBool pkgGpgCheck() const
Check rpm package signatures (indeterminate - according to gpgcheck)
std::string repoStatusString() const
bool pkgGpgCheck() const
Whether the signature of rpm packages should be checked for this repo.
Pathname packagesPath() const
Execute a program and give access to its io An object of this class encapsulates the execution of an ...
url_set _effectiveBaseUrls
bool set(const std::string &key_r, AnyType val_r)
Set the value for key (nonconst version always returns true).
bool repoGpgCheckIsMandatory() const
Mandatory check (repoGpgCheck is on) must ask to confirm using unsigned repos.
RepoVariablesReplacedUrlList & baseUrls()
void setRepoGpgCheck(TriBool value_r)
Set the value for repoGpgCheck (or indeterminate to use the default).
const std::string & asString() const
String representation.
TriBool triBoolFromPath(const Pathname &path_r) const
std::string alias() const
unique identifier for this source.
bool isExist() const
Return whether valid stat info exists.
std::string escape(const C_Str &str_r, const char sep_r)
Escape desired character c using a backslash.
void addContent(const std::string &keyword_r)
bool gpgCheck() const
Turn signature checking on/off (on)
Convenience char* constructible from std::string and char*, it maps (char*)0 to an empty string...
Url rawMirrorListUrl() const
The raw mirrorListUrl (no variables replaced).
void setPath(const Pathname &path)
set the product path.
TriBool validRepoSignature() const
Whether the repo metadata are signed and successfully validated or indeterminate if unsigned...
Pathname dirname() const
Return all but the last component od this path.
LocaleSet getLicenseLocales() const
Return the locales the license is available for.
void setService(const std::string &name)
sets service which added this repository
RepoVariablesReplacedUrl _cfgMetalinkUrl
void setMetadataPath(const Pathname &path)
Set the path where the local metadata is stored.
bool baseUrlSet() const
Whether there are manualy configured repository urls.
RepoVariablesReplacedUrlList & gpgKeyUrls()
bool startsWith(const C_Str &str_r, const C_Str &prefix_r)
alias for hasPrefix
int close() override
Wait for the progamm to complete.
void getRawGpgChecks(TriBool &g_r, TriBool &r_r, TriBool &p_r) const
Raw values for RepoManager.
void setType(const repo::RepoType &t)
set the repository type
TriBool repoGpgCheck() const
Check repo matadata signatures (indeterminate - according to gpgcheck)
bool gpgCheck() const
Whether default signature checking should be performed.
TriBool _rawGpgCheck
default gpgcheck behavior: Y/N/ZConf
TriBool _validRepoSignature
have signed and valid repo metadata
bool hasContent() const
Check for content keywords.
std::pair< FalseBool, std::set< std::string > > _keywords
Pathname predownloadPath() const
void setKeepPackages(bool keep)
Set if packaqes downloaded from this repository will be kept in local cache.
std::string getLicense(const Locale &lang_r=Locale()) const
Return the best license for the current (or a specified) locale.
bool baseurl2dump() const
std::vector< std::vector< Url > > groupedBaseUrls() const
Returns the currently known effective baseUrls in groups, where each group contains a primary base ur...
bool empty() const
Whether matches were found.
base::ValueTransform< Url, repo::RepoVariablesUrlReplacer > RepoVariablesReplacedUrl
std::string asString(const Url &url_r)
url_set::size_type urls_size_type
std::ostream & dumpOn(std::ostream &str, const Capability &obj)
bool seekToEndNode(int depth_r, const std::string &name_r)
const RepoVariablesReplacedUrlList & baseUrls() const
TriBool cfgPkgGpgCheck() const
std::ostream & dumpOn(std::ostream &str) const override
Write a human-readable representation of this RepoInfo object into the str stream.
TriBool _rawRepoGpgCheck
need to check repo sign.: Y/N/(ZConf(Y/N/gpgCheck))
bool requireStatusWithMediaFile() const
Returns true if this repository requires the media.1/media file to be included in the metadata status...
Find pathnames matching a pattern.
Pathname metadataPath() const
Path where this repo metadata was read from.
std::vector< std::string > Arguments
transform_iterator< repo::RepoVariablesUrlReplacer, url_set::const_iterator > urls_const_iterator
int unlink(const Pathname &path)
Like 'unlink'.
static const RepoType NONE
std::ostream & dumpAsXmlOn(std::ostream &str, const std::string &content="") const override
Write an XML representation of this RepoInfo object.
static const unsigned noPriority
repo::RepoType type() const
Pathname predownloadPath() const
Path where this repo packages are predownloaded.
bool usesAutoMetadataPaths() const
Whether metadataPath uses AUTO% setup.
int add(const Pathname &pattern_r, Flags flags_r=Flags())
Add pathnames matching pattern_r to the current result.
void setPackagesPath(const Pathname &path)
set the path where the local packages are stored
void resetEffectiveUrls() const
'Language[_Country]' codes.
static bool urlSupportsMirrorLink(const zypp::Url &url)
void setMetalinkUrl(const Url &url)
Set the raw metalink url.
static const RepoType RPMMD
void setGpgKeyUrls(url_set urls)
Set a list of gpgkey URLs defined for this repo.
const std::set< std::string > & contentKeywords() const
int symlink(const Pathname &oldpath, const Pathname &newpath)
Like 'symlink'.
void setProbedType(const repo::RepoType &t) const
static const RepoType YAST2
bool hasSuffix(const C_Str &str_r, const C_Str &suffix_r)
Return whether str_r has suffix suffix_r.
void rawRepoGpgCheck(TriBool val_r)
std::chrono::steady_clock::time_point _lastEffectiveUrlsUpdate
url_set rawBaseUrls() const
The complete set of raw repository urls (no variables replaced)
void setTargetDistribution(const std::string &targetDistribution)
Sets the distribution for which is this repository meant.
bool needToAcceptLicense() const
Whether the repo license has to be accepted, e.g.
Base class for Exception.
std::ostream & dumpAsIniOn(std::ostream &str) const override
Write this RepoInfo object into str in a .repo file format.
Impl & operator=(const Impl &)=delete
Url location() const
Returns the location URL for the repository, this is either the first configured baseUrl or a configu...
XmlString nodeText()
If the current node is not empty, advances the reader to the next node, and returns the value...
void addBaseUrl(Url url)
Add a base url.
void setMirrorlistUrl(const Url &url_r)
const RepoVariablesReplacedUrlList & gpgKeyUrls() const
std::string name() const
Repository name.
void pathNameSetTrailingSlash(bool apply_r=true)
Apply or remove a trailing '/' from pathName.
std::string asString() const
Explicit conversion to std::string.
Pathname licenseTgz(const std::string &name_r) const
Path to a license tarball in case it exists in the repo.
void setType(const repo::RepoType &t)
bool internalUnsignedConfirmed() const
We definitely have a symlink pointing to "indeterminate" (for repoGpgCheckIsMandatory)? I.e.
RepoVariablesReplacedUrlList _gpgKeyUrls
Typesafe passing of user data via callbacks.
TriBool rawRepoGpgCheck() const
DefaultIntegral< unsigned, defaultPriority > priority
std::string targetDistribution() const
Distribution for which is this repository meant.
Pathname packagesPath() const
Path where this repo packages are cached.
void setBaseUrls(url_set urls)
Clears current base URL list and adds an url_set.
Wrapper class for ::stat/::lstat.
static const RepoInfo noRepo
Represents no Repository (one with an empty alias).
std::string repoStatusString() const
A string value to track changes requiring a refresh.
urls_const_iterator baseUrlsEnd() const
iterator that points at end of repository urls
void addContent(const std::string &keyword_r)
Add content keywords.
void rawPkgGpgCheck(TriBool val_r)
static const RepoType RPMPLAINDIR
bool autorefresh() const
If true, the repostory must be refreshed before creating resolvables from it.
urls_size_type baseUrlsSize() const
number of repository urls
void setMetalinkUrl(const Url &url_r)
const std::vector< Url > & getUrls() const
static bool schemeIsDownloading(const std::string &scheme_r)
http https ftp sftp tftp
urls_size_type gpgKeyUrlsSize() const
Number of gpgkey URLs defined.
Pathname metadataPath() const
TriBool rawGpgCheck() const
Easy-to use interface to the ZYPP dependency resolver.
static const unsigned defaultPriority
url_set & effectiveBaseUrls() const
Impl * clone() const
clone for RWCOW_pointer
static unsigned noPriority()
The least priority (unsigned(-1)).
bool hasPrefix(const C_Str &str_r, const C_Str &prefix_r)
Return whether str_r has prefix prefix_r.
url_set baseUrls() const
The complete set of repository urls as configured.
void setPkgGpgCheck(TriBool value_r)
Set the value for pkgGpgCheck (or indeterminate to use the default).
repo::RepoType type() const
Type of repository,.
TriBool cfgRepoGpgCheck() const
const char * c_str() const
bool effectiveKeepPackages() const
keepPackages unless the package cache itself enforces keeping the packages.
void metadataPath(Pathname new_r)
Repository type enumeration.
bool hasContent(const std::string &keyword_r) const