ZetCode

PHP chgrp Function

last modified April 3, 2025

The PHP chgrp function changes the group ownership of a file. It's useful for managing file permissions in Unix-like systems. This function requires appropriate permissions to work.

Basic Definition

The chgrp function changes the group of the specified file. It takes two parameters: the filename and the group name or number.

Syntax: chgrp(string $filename, string|int $group): bool. The function returns true on success and false on failure. It only works on Unix systems.

Basic chgrp Example

This shows the simplest usage of chgrp to change a file's group.

basic_chgrp.php
<?php

declare(strict_types=1);

$filename = "testfile.txt";
$group = "www-data";

if (chgrp($filename, $group)) {
    echo "Group changed successfully to $group";
} else {
    echo "Failed to change group";
}

This attempts to change the group of "testfile.txt" to "www-data". The script must have sufficient permissions to perform this operation.

Using Group ID Instead of Name

You can specify the group using its numeric ID instead of the name.

chgrp_gid.php
<?php

declare(strict_types=1);

$filename = "data.log";
$gid = 33; // Typically www-data's GID

if (chgrp($filename, $gid)) {
    echo "Group changed successfully to GID $gid";
} else {
    echo "Failed to change group";
}

This changes the group using the numeric group ID. This can be more reliable as group names might vary between systems while IDs remain consistent.

Error Handling Example

Proper error handling is important when working with file permissions.

chgrp_error.php
<?php

declare(strict_types=1);

$filename = "protected_file.conf";
$group = "admin";

if (!file_exists($filename)) {
    die("File does not exist");
}

if (!is_writable($filename)) {
    die("File is not writable");
}

if (chgrp($filename, $group)) {
    echo "Group changed successfully";
} else {
    echo "Failed to change group: " . error_get_last()['message'];
}

This example includes checks for file existence and writability before attempting to change the group. It also shows how to get the last error message.

Changing Group Recursively

This example demonstrates changing group ownership for a directory and its contents recursively.

chgrp_recursive.php
<?php

declare(strict_types=1);

function changeGroupRecursive(string $path, $group): void {
    if (is_dir($path)) {
        $items = scandir($path);
        
        foreach ($items as $item) {
            if ($item !== "." && $item !== "..") {
                changeGroupRecursive($path . DIRECTORY_SEPARATOR . $item, $group);
            }
        }
    }
    
    if (!chgrp($path, $group)) {
        throw new RuntimeException("Failed to change group for $path");
    }
}

try {
    changeGroupRecursive("/var/www/uploads", "www-data");
    echo "All files and directories updated successfully";
} catch (RuntimeException $e) {
    echo "Error: " . $e->getMessage();
}

This recursive function changes group ownership for all files and subdirectories. Note that this requires significant permissions and should be used carefully.

Checking Current Group Before Change

It's often good practice to check the current group before attempting to change it.

chgrp_check.php
<?php

declare(strict_types=1);

$filename = "config.ini";
$desired_group = "backup";

$fileinfo = posix_getpwuid(fileowner($filename));
$groupinfo = posix_getgrgid(filegroup($filename));

echo "Current owner: {$fileinfo['name']}\n";
echo "Current group: {$groupinfo['name']}\n";

if ($groupinfo['name'] !== $desired_group) {
    if (chgrp($filename, $desired_group)) {
        echo "Group changed to $desired_group";
    } else {
        echo "Failed to change group";
    }
} else {
    echo "File already belongs to $desired_group";
}

This script first displays the current ownership information, then only attempts to change the group if necessary. The posix_getgrgid function provides group name information.

Best Practices

Source

PHP chgrp Documentation

This tutorial covered the PHP chgrp function with practical examples showing its usage in different scenarios.

Author

My name is Jan Bodnar, and I am a passionate programmer with extensive programming experience. I have been writing programming articles since 2007. To date, I have authored over 1,400 articles and 8 e-books. I possess more than ten years of experience in teaching programming.

List all PHP Filesystem Functions.