Il seguente esempio di codice illustra come utilizzare i metodi di sicurezza dello spazio di lavoro (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 dello spazio di lavoro 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