matterbridge/vendor/github.com/pborman/uuid/node.go

51 lines
1.5 KiB
Go
Raw Permalink Normal View History

2016-04-10 23:39:38 +02:00
// Copyright 2011 Google Inc. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package uuid
import (
2020-08-10 00:29:54 +02:00
guuid "github.com/google/uuid"
2016-04-10 23:39:38 +02:00
)
// NodeInterface returns the name of the interface from which the NodeID was
// derived. The interface "user" is returned if the NodeID was set by
// SetNodeID.
func NodeInterface() string {
2020-08-10 00:29:54 +02:00
return guuid.NodeInterface()
2016-04-10 23:39:38 +02:00
}
// SetNodeInterface selects the hardware address to be used for Version 1 UUIDs.
// If name is "" then the first usable interface found will be used or a random
// Node ID will be generated. If a named interface cannot be found then false
// is returned.
//
// SetNodeInterface never fails when name is "".
func SetNodeInterface(name string) bool {
2020-08-10 00:29:54 +02:00
return guuid.SetNodeInterface(name)
2016-04-10 23:39:38 +02:00
}
// NodeID returns a slice of a copy of the current Node ID, setting the Node ID
// if not already set.
func NodeID() []byte {
2020-08-10 00:29:54 +02:00
return guuid.NodeID()
2016-04-10 23:39:38 +02:00
}
// SetNodeID sets the Node ID to be used for Version 1 UUIDs. The first 6 bytes
// of id are used. If id is less than 6 bytes then false is returned and the
// Node ID is not set.
func SetNodeID(id []byte) bool {
2020-08-10 00:29:54 +02:00
return guuid.SetNodeID(id)
2016-04-10 23:39:38 +02:00
}
// NodeID returns the 6 byte node id encoded in uuid. It returns nil if uuid is
// not valid. The NodeID is only well defined for version 1 and 2 UUIDs.
func (uuid UUID) NodeID() []byte {
if len(uuid) != 16 {
return nil
}
node := make([]byte, 6)
copy(node, uuid[10:])
return node
}