Il seguente esempio di codice illustra come utilizzare i metodi di sicurezza del workspace (inclusi i metodi degli oggetti Folder, Folders, Permission e Permissions) per richiamare le autorizzazioni di sicurezza applicate alle cartelle Public e Personal. Questo esempio fornisce un'idea generale di come sia possibile utilizzare l'API ClearQuest per creare una politica di sicurezza della cartella workspace e richiamare le informazioni sulle impostazioni correnti.
use strict;
require "CQPerlExt.pm";
################################
# Subroutines
sub get_access_description($)
{
my ($folder) = @_;
my $perm = $folder->GetPermission();
my $kind = $perm->GetKindName();
my $group = $perm->GetGroup($CQPerlExt::CQ_NAME_EXTEND_WHEN_NEEDED);
return "$kind for $group";
}
sub show_subfolders($$);
sub show_subfolders($$)
{
my ($folder, $indent) = @_;
my $name = $folder->GetName();
my $access = get_access_description($folder);
my $folders = $folder->GetSubfolders();
my $count = $folders->Count();
print $indent . "$name: $access\n";
for (my $i = 0; $i < $count; $i++) {
my $folder = $folders->Item($i);
show_subfolders($folder, $indent . "| ");
}
}
################################
# Main
my $session;
my $workspace;
my $PublicFolder;
my $PersonalFolder;
my $PublicFolderName;
my $PersonalFolderName;
if (scalar(@ARGV) != 4) {
die "ERROR: insufficient arguments; need username, password, database, dbset\n";
}
my ($username, $password, $database, $dbset) = @ARGV;
$session = CQSession::Build();
$session->UserLogon($username, $password, $database, $dbset);
$workspace = $session->GetWorkSpace();
$PublicFolder = $workspace->GetPublicFolder();
$PublicFolderName = $workspace->GetPublicFolderName();
show_subfolders($PublicFolder, "");
$PersonalFolder = $workspace->GetPersonalFolder();
$PersonalFolderName = $workspace->GetPersonalFolderName();
show_subfolders($PersonalFolder, "");
$session->Unbuild();
$session = undef;
# end Main