BSON::OID(3pm) - phpMan

Command: man perldoc info search(apropos)  


BSON::OID(3pm)                 User Contributed Perl Documentation                 BSON::OID(3pm)

NAME
       BSON::OID - BSON type wrapper for Object IDs

VERSION
       version v1.12.2

SYNOPSIS
           use BSON::Types ':all';

           my $oid  = bson_oid();
           my $oid  = bson_oid->from_epoch(1467543496, 0); # for queries only

           my $bytes = $oid->oid;
           my $hex   = $oid->hex;

DESCRIPTION
       This module provides a wrapper around a BSON Object ID
       <https://docs.mongodb.com/manual/reference/method/ObjectId/>.

ATTRIBUTES
   oid
       A 12-byte (packed) Object ID (OID) string.  If not provided, a new OID will be generated.

METHODS
   new
           my $oid = BSON::OID->new;

           my $oid = BSON::OID->new( oid => $twelve_bytes );

       This is the preferred way to generate an OID.  Without arguments, a unique OID will be
       generated.  With a 12-byte string, an object can be created around an existing OID byte-
       string.

   from_epoch
           # generate a new OID

           my $oid = BSON::OID->from_epoch( $epoch, 0); # other bytes zeroed
           my $oid = BSON::OID->from_epoch( $epoch, $eight_more_bytes );

           # reset an existing OID

           $oid->from_epoch( $new_epoch, 0 );
           $oid->from_epoch( $new_epoch, $eight_more_bytes );

       Warning! You should not rely on this method for a source of unique IDs.  Use this method
       for query boundaries, only.

       An OID is a twelve-byte string.  Typically, the first four bytes represent integer seconds
       since the Unix epoch in big-endian format.  The remaining bytes ensure uniqueness.

       With this method, the first argument to this method is an epoch time (in integer seconds).
       The second argument is the remaining eight-bytes to append to the string.

       When called as a class method, it returns a new BSON::OID object.  When called as an
       object method, it mutates the existing internal OID value.

       As a special case, if the second argument is defined and zero ("0"), then the remaining
       bytes will be zeroed.

           my $oid = BSON::OID->from_epoch(1467545180, 0);

       This is particularly useful when looking for documents by their insertion date: you can
       simply look for OIDs which are greater or lower than the one generated with this method.

       For backwards compatibility with Mango, if called without a second argument, the method
       generates the remainder of the fields "like usual".  This is equivalent to calling
       "BSON::OID->new" and replacing the first four bytes with the packed epoch value.

           # UNSAFE: don't do this unless you have to

           my $oid = BSON::OID->from_epoch(1467545180);

       If you insist on creating a unique OID with "from_epoch", set the remaining eight bytes in
       a way that guarantees thread-safe uniqueness, such as from a reliable source of randomness
       (see Crypt::URandom).

         use Crypt::Random 'urandom';
         my $oid = BSON::OID->from_epoch(1467545180, urandom(8));

   hex
       Returns the "oid" attributes as 24-byte hexadecimal value

   get_time
       Returns a number corresponding to the portion of the "oid" value that represents seconds
       since the epoch.

   TO_JSON
       Returns a string for this OID, with the OID given as 24 hex digits.

       If the "BSON_EXTJSON" option is true, it will instead be compatible with MongoDB's
       extended JSON <https://github.com/mongodb/specifications/blob/master/source/extended-
       json.rst> format, which represents it as a document as follows:

           {"$oid" : "012345678901234567890123"}

OVERLOAD
       The string operator is overloaded so any string operations will actually use the
       24-character hex value of the OID.  Fallback overloading is enabled.

       Both numeric comparison ("<=>") and string comparison ("cmp") are overloaded to do string
       comparison of the 24-character hex value of the OID.  If used with a non-BSON::OID object,
       be sure to provide a 24-character hex string or the results are undefined.

THREADS
       This module is thread safe.

AUTHORS
       o   David Golden <david AT mongodb.com>

       o   Stefan G. <minimalist AT lavabit.com>

COPYRIGHT AND LICENSE
       This software is Copyright (c) 2020 by Stefan G. and MongoDB, Inc.

       This is free software, licensed under:

         The Apache License, Version 2.0, January 2004

perl v5.30.3                                2020-08-14                             BSON::OID(3pm)

Generated by $Id: phpMan.php,v 4.55 2007/09/05 04:42:51 chedong Exp $ Author: Che Dong
On Apache
Under GNU General Public License
2025-01-15 01:10 @18.227.46.54 CrawledBy Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)
Valid XHTML 1.0!Valid CSS!