Files
perl-String-Random/perl-String-Random.spec
2025-08-12 18:17:16 +02:00

91 lines
2.9 KiB
RPMSpec

#
# spec file for package perl-String-Random
#
# Copyright (c) 2024 SUSE LLC
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.
# Please submit bugfixes or comments via https://bugs.opensuse.org/
#
%define cpan_name String-Random
Name: perl-String-Random
Version: 0.320.0
Release: 0
# 0.32 -> normalize -> 0.320.0
%define cpan_version 0.32
License: Artistic-1.0 OR GPL-1.0-or-later
Summary: Perl module to generate random strings based on a pattern
URL: https://metacpan.org/release/%{cpan_name}
Source0: https://cpan.metacpan.org/authors/id/S/SH/SHLOMIF/%{cpan_name}-%{cpan_version}.tar.gz
Source1: cpanspec.yml
Source100: README.md
BuildArch: noarch
BuildRequires: perl
BuildRequires: perl-macros
BuildRequires: perl(Module::Build) >= 0.28
BuildRequires: perl(Test::More) >= 0.88
BuildRequires: perl(parent)
Requires: perl(parent)
Provides: perl(String::Random) = %{version}
%undefine __perllib_provides
%{perl_requires}
%description
This module makes it trivial to generate random strings.
As an example, let's say you are writing a script that needs to generate a
random password for a user. The relevant code might look something like
this:
use String::Random;
my $pass = String::Random->new;
print "Your password is ", $pass->randpattern("CCcc!ccn"), "\n";
This would output something like this:
Your password is UDwp$tj5
*NOTE!!!*: currently, 'String::Random' defaults to Perl's built-in
predictable random number generator so the passwords generated by it are
insecure. See the 'rand_gen' option to 'String::Random' constructor to
specify a more secure random number generator. There is no equivalent to
this in the procedural interface, you must use the object-oriented
interface to get this functionality.
If you are more comfortable dealing with regular expressions, the following
code would have a similar result:
use String::Random;
my $pass = String::Random->new;
print "Your password is ",
$pass->randregex('[A-Z]{2}[a-z]{2}.[a-z]{2}\d'), "\n";
%prep
%autosetup -n %{cpan_name}-%{cpan_version}
%build
perl Build.PL --installdirs=vendor
./Build build --flags=%{?_smp_mflags}
%check
./Build test
%install
./Build install --destdir=%{buildroot} --create_packlist=0
%perl_gen_filelist
%files -f %{name}.files
%doc Changes README README.md TODO
%license LICENSE
%changelog