| // Copyright 2011 The Go Authors. All rights reserved. | 
 | // Use of this source code is governed by a BSD-style | 
 | // license that can be found in the LICENSE file. | 
 |  | 
 | package user | 
 |  | 
 | import "sync" | 
 |  | 
 | // Current returns the current user. | 
 | // | 
 | // The first call will cache the current user information. | 
 | // Subsequent calls will return the cached value and will not reflect | 
 | // changes to the current user. | 
 | func Current() (*User, error) { | 
 | 	cache.Do(func() { cache.u, cache.err = current() }) | 
 | 	if cache.err != nil { | 
 | 		return nil, cache.err | 
 | 	} | 
 | 	u := *cache.u // copy | 
 | 	return &u, nil | 
 | } | 
 |  | 
 | // cache of the current user | 
 | var cache struct { | 
 | 	sync.Once | 
 | 	u   *User | 
 | 	err error | 
 | } | 
 |  | 
 | // Lookup looks up a user by username. If the user cannot be found, the | 
 | // returned error is of type UnknownUserError. | 
 | func Lookup(username string) (*User, error) { | 
 | 	if u, err := Current(); err == nil && u.Username == username { | 
 | 		return u, err | 
 | 	} | 
 | 	return lookupUser(username) | 
 | } | 
 |  | 
 | // LookupId looks up a user by userid. If the user cannot be found, the | 
 | // returned error is of type UnknownUserIdError. | 
 | func LookupId(uid string) (*User, error) { | 
 | 	if u, err := Current(); err == nil && u.Uid == uid { | 
 | 		return u, err | 
 | 	} | 
 | 	return lookupUserId(uid) | 
 | } | 
 |  | 
 | // LookupGroup looks up a group by name. If the group cannot be found, the | 
 | // returned error is of type UnknownGroupError. | 
 | func LookupGroup(name string) (*Group, error) { | 
 | 	return lookupGroup(name) | 
 | } | 
 |  | 
 | // LookupGroupId looks up a group by groupid. If the group cannot be found, the | 
 | // returned error is of type UnknownGroupIdError. | 
 | func LookupGroupId(gid string) (*Group, error) { | 
 | 	return lookupGroupId(gid) | 
 | } | 
 |  | 
 | // GroupIds returns the list of group IDs that the user is a member of. | 
 | func (u *User) GroupIds() ([]string, error) { | 
 | 	return listGroups(u) | 
 | } |