# phpman > perldoc > User::Identity::Collection::Locations

## NAME
    [User::Identity::Collection::Locations](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection%3A%3ALocations/markdown) - a collection of locations

## INHERITANCE
     [User::Identity::Collection::Locations](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection%3A%3ALocations/markdown)
       is a [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown)
       is a [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)

## SYNOPSIS
## DESCRIPTION
    The "[User::Identity::Collection::Location](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection%3A%3ALocation/markdown)" object maintains a set [User::Identity::Location](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ALocation/markdown)
    objects, each describing a physical location.

    Extends "DESCRIPTION" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown).

## OVERLOADED
    Extends "OVERLOADED" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown).

    overload: @{}
        Inherited, see "OVERLOADED" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown)

    overload: stringification
        Inherited, see "OVERLOADED" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown)

## METHODS
    Extends "METHODS" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown).

### Constructors
    Extends "Constructors" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown).

    [User::Identity::Collection::Locations](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection%3A%3ALocations/markdown)->new( [$name], %options )
         -Option     --Defined in                --Default
          description  [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)        undef
          item_type    [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown)  [User::Identity::Location](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ALocation/markdown)
          name         [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)        'locations'
          parent       [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)        undef
          roles        [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown)  undef

        description => STRING
        item_type => CLASS
        name => STRING
        parent => OBJECT
        roles => ROLE|ARRAY

### Attributes
    Extends "Attributes" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown).

    $obj->description()
        Inherited, see "Attributes" in [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)

    $obj->itemType()
        Inherited, see "Attributes" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown)

    $obj->name( [$newname] )
        Inherited, see "Attributes" in [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)

    $obj->roles()
        Inherited, see "Attributes" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown)

### Collections
    Extends "Collections" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown).

    $obj->add($collection, $role)
        Inherited, see "Collections" in [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)

    $obj->addCollection( $object | <[$type], %options> )
        Inherited, see "Collections" in [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)

    $obj->collection($name)
        Inherited, see "Collections" in [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)

    $obj->parent( [$parent] )
        Inherited, see "Collections" in [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)

    $obj->removeCollection($object|$name)
        Inherited, see "Collections" in [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)

    $obj->type()
    [User::Identity::Collection::Locations](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection%3A%3ALocations/markdown)->type()
        Inherited, see "Collections" in [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)

    $obj->user()
        Inherited, see "Collections" in [User::Identity::Item](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3AItem/markdown)

### Maintaining roles
    Extends "Maintaining roles" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown).

    $obj->addRole($role| <[$name],%options> | ARRAY)
        Inherited, see "Maintaining roles" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown)

    $obj->removeRole($role|$name)
        Inherited, see "Maintaining roles" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown)

    $obj->renameRole( <$role|$oldname>, $newname )
        Inherited, see "Maintaining roles" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown)

    $obj->sorted()
        Inherited, see "Maintaining roles" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown)

### Searching
    Extends "Searching" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown).

    $obj->find($name|CODE|undef)
        Inherited, see "Searching" in [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown)

## DIAGNOSTICS
    Error: $object is not a collection.
        The first argument is an object, but not of a class which extends
        [User::Identity::Collection](https://www.chedong.com/phpMan.php/perldoc/User%3A%3AIdentity%3A%3ACollection/markdown).

    Error: Cannot create a $type to add this to my collection.
        Some options are specified to create a $type object, which is native to this collection.
        However, for some reason this failed.

    Error: Cannot load collection module for $type ($class).
        Either the specified $type does not exist, or that module named $class returns compilation
        errors. If the type as specified in the warning is not the name of a package, you specified
        a nickname which was not defined. Maybe you forgot the 'require' the package which defines
        the nickname.

    Error: Cannot rename $name into $newname: already exists
    Error: Cannot rename $name into $newname: doesn't exist
    Error: Creation of a collection via $class failed.
        The $class did compile, but it was not possible to create an object of that class using the
        options you specified.

    Error: Don't know what type of collection you want to add.
        If you add a collection, it must either by a collection object or a list of options which
        can be used to create a collection object. In the latter case, the type of collection must
        be specified.

    Warning: No collection $name
        The collection with $name does not exist and can not be created.

    Error: Wrong type of role for $collection: requires a $expect but got a $type
        Each $collection groups sets of roles of one specific type ($expect). You cannot add objects
        of a different $type.

## SEE ALSO
    This module is part of User-Identity distribution version 1.01, built on February 11, 2022.
    Website: <http://perl.overmeer.net/CPAN/>

## LICENSE
    Copyrights 2003-2022 by [Mark Overmeer <<markov@cpan.org>>]. For other contributors see ChangeLog.

    This program is free software; you can redistribute it and/or modify it under the same terms as
    Perl itself. See <http://dev.perl.org/licenses/>

