| // 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 allows user account lookups by name or id. |
| package user |
| |
| import ( |
| "strconv" |
| ) |
| |
| var ( |
| userImplemented = true // set to false by lookup_stubs.go's init |
| groupImplemented = true // set to false by lookup_stubs.go's init |
| ) |
| |
| // User represents a user account. |
| // |
| // On POSIX systems Uid and Gid contain a decimal number |
| // representing uid and gid. On windows Uid and Gid |
| // contain security identifier (SID) in a string format. |
| // On Plan 9, Uid, Gid, Username, and Name will be the |
| // contents of /dev/user. |
| type User struct { |
| Uid string // user ID |
| Gid string // primary group ID |
| Username string |
| Name string |
| HomeDir string |
| } |
| |
| // Group represents a grouping of users. |
| // |
| // On POSIX systems Gid contains a decimal number |
| // representing the group ID. |
| type Group struct { |
| Gid string // group ID |
| Name string // group name |
| } |
| |
| // UnknownUserIdError is returned by LookupId when |
| // a user cannot be found. |
| type UnknownUserIdError int |
| |
| func (e UnknownUserIdError) Error() string { |
| return "user: unknown userid " + strconv.Itoa(int(e)) |
| } |
| |
| // UnknownUserError is returned by Lookup when |
| // a user cannot be found. |
| type UnknownUserError string |
| |
| func (e UnknownUserError) Error() string { |
| return "user: unknown user " + string(e) |
| } |
| |
| // UnknownGroupIdError is returned by LookupGroupId when |
| // a group cannot be found. |
| type UnknownGroupIdError string |
| |
| func (e UnknownGroupIdError) Error() string { |
| return "group: unknown groupid " + string(e) |
| } |
| |
| // UnknownGroupError is returned by LookupGroup when |
| // a group cannot be found. |
| type UnknownGroupError string |
| |
| func (e UnknownGroupError) Error() string { |
| return "group: unknown group " + string(e) |
| } |