本文整理匯總了Golang中github.com/couchbase/sync_gateway/channels.AtSequence函數的典型用法代碼示例。如果您正苦於以下問題:Golang AtSequence函數的具體用法?Golang AtSequence怎麽用?Golang AtSequence使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了AtSequence函數的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestRebuildRoleChannels
func TestRebuildRoleChannels(t *testing.T) {
computer := mockComputer{channels: ch.AtSequence(ch.SetOf("derived1", "derived2"), 1)}
auth := NewAuthenticator(gTestBucket, &computer)
role, _ := auth.NewRole("testRole", ch.SetOf("explicit1"))
err := auth.InvalidateChannels(role)
assert.Equals(t, err, nil)
role2, err := auth.GetRole("testRole")
assert.Equals(t, err, nil)
assert.DeepEquals(t, role2.Channels(), ch.AtSequence(ch.SetOf("explicit1", "derived1", "derived2", "!"), 1))
}
示例2: TestRebuildUserChannels
func TestRebuildUserChannels(t *testing.T) {
computer := mockComputer{channels: ch.AtSequence(ch.SetOf("derived1", "derived2"), 1)}
auth := NewAuthenticator(gTestBucket, &computer)
user, _ := auth.NewUser("testUser", "password", ch.SetOf("explicit1"))
user.setChannels(nil)
err := auth.Save(user)
assert.Equals(t, err, nil)
user2, err := auth.GetUser("testUser")
assert.Equals(t, err, nil)
assert.DeepEquals(t, user2.Channels(), ch.AtSequence(ch.SetOf("explicit1", "derived1", "derived2", "!"), 1))
}
示例3: TestRebuildUserRoles
func TestRebuildUserRoles(t *testing.T) {
computer := mockComputer{roles: ch.AtSequence(base.SetOf("role1", "role2"), 3)}
auth := NewAuthenticator(gTestBucket, &computer)
user, _ := auth.NewUser("testUser", "letmein", nil)
user.SetExplicitRoles(ch.TimedSet{"role3": ch.NewVbSimpleSequence(1), "role1": ch.NewVbSimpleSequence(1)})
err := auth.InvalidateRoles(user)
assert.Equals(t, err, nil)
user2, err := auth.GetUser("testUser")
assert.Equals(t, err, nil)
expected := ch.AtSequence(base.SetOf("role1", "role3"), 1)
expected.AddChannel("role2", 3)
assert.DeepEquals(t, user2.RoleNames(), expected)
}
示例4: updateAccess
// Updates a document's channel/role UserAccessMap with new access settings from an AccessMap.
// Returns an array of the user/role names whose access has changed as a result.
func (accessMap *UserAccessMap) updateAccess(doc *document, newAccess channels.AccessMap) (changedUsers []string) {
// Update users already appearing in doc.Access:
for name, access := range *accessMap {
if access.UpdateAtSequence(newAccess[name], doc.Sequence) {
if len(access) == 0 {
delete(*accessMap, name)
}
changedUsers = append(changedUsers, name)
}
}
// Add new users who are in newAccess but not accessMap:
for name, access := range newAccess {
if _, existed := (*accessMap)[name]; !existed {
if *accessMap == nil {
*accessMap = UserAccessMap{}
}
(*accessMap)[name] = channels.AtSequence(access, doc.Sequence)
changedUsers = append(changedUsers, name)
}
}
if changedUsers != nil {
what := "channel"
if accessMap == &doc.RoleAccess {
what = "role"
}
base.LogTo("Access", "Doc %q grants %s access: %v", doc.ID, what, *accessMap)
}
return changedUsers
}
示例5: defaultGuestUser
func (auth *Authenticator) defaultGuestUser() User {
user := &userImpl{
roleImpl: roleImpl{
ExplicitChannels_: ch.AtSequence(ch.SetOf(), 1),
},
userImplBody: userImplBody{
Disabled_: true,
},
auth: auth,
}
user.Channels_ = user.ExplicitChannels_.Copy()
return user
}
示例6: UnmarshalJSON
func (user *userImpl) UnmarshalJSON(data []byte) error {
if err := json.Unmarshal(data, &user.userImplBody); err != nil {
return err
} else if err := json.Unmarshal(data, &user.roleImpl); err != nil {
return err
}
// Migrate "admin_roles" field:
if user.OldExplicitRoles_ != nil {
user.ExplicitRoles_ = ch.AtSequence(base.SetFromArray(user.OldExplicitRoles_), 1)
user.OldExplicitRoles_ = nil
}
return nil
}
示例7: TestAccessFunction
func TestAccessFunction(t *testing.T) {
/*
var logKeys = map[string]bool {
"CRUD": true,
"Access": true,
}
base.UpdateLogKeys(logKeys, true)
*/
db := setupTestDB(t)
defer tearDownTestDB(t, db)
authenticator := auth.NewAuthenticator(db.Bucket, db)
var err error
db.ChannelMapper = channels.NewChannelMapper(`function(doc){access(doc.users,doc.userChannels);}`)
user, _ := authenticator.NewUser("naomi", "letmein", channels.SetOf("Netflix"))
user.SetExplicitRoles(channels.TimedSet{"animefan": channels.NewVbSimpleSequence(1), "tumblr": channels.NewVbSimpleSequence(1)})
assertNoError(t, authenticator.Save(user), "Save")
body := Body{"users": []string{"naomi"}, "userChannels": []string{"Hulu"}}
_, err = db.Put("doc1", body)
assertNoError(t, err, "")
body = Body{"users": []string{"role:animefan"}, "userChannels": []string{"CrunchyRoll"}}
_, err = db.Put("doc2", body)
assertNoError(t, err, "")
// Create the role _after_ creating the documents, to make sure the previously-indexed access
// privileges are applied.
role, _ := authenticator.NewRole("animefan", nil)
authenticator.Save(role)
user, err = authenticator.GetUser("naomi")
assertNoError(t, err, "GetUser")
expected := channels.AtSequence(channels.SetOf("Hulu", "Netflix", "!"), 1)
assert.DeepEquals(t, user.Channels(), expected)
expected.AddChannel("CrunchyRoll", 2)
assert.DeepEquals(t, user.InheritedChannels(), expected)
}
示例8: WriteDirectWithChannelGrant
func WriteDirectWithChannelGrant(db *Database, channelArray []string, sequence uint64, username string, channelGrantArray []string) {
docId := fmt.Sprintf("doc-%v", sequence)
rev := "1-a"
chanMap := make(map[string]*channels.ChannelRemoval, 10)
for _, channel := range channelArray {
chanMap[channel] = nil
}
accessMap := make(map[string]channels.TimedSet)
channelTimedSet := channels.AtSequence(base.SetFromArray(channelGrantArray), sequence)
accessMap[username] = channelTimedSet
syncData := &syncData{
CurrentRev: rev,
Sequence: sequence,
Channels: chanMap,
Access: accessMap,
}
db.Bucket.Add(docId, 0, Body{"_sync": syncData, "key": docId})
}
示例9: TestRoleInheritance
func TestRoleInheritance(t *testing.T) {
// Create some roles:
auth := NewAuthenticator(gTestBucket, nil)
role, _ := auth.NewRole("square", ch.SetOf("dull", "duller", "dullest"))
assert.Equals(t, auth.Save(role), nil)
role, _ = auth.NewRole("frood", ch.SetOf("hoopy", "hoopier", "hoopiest"))
assert.Equals(t, auth.Save(role), nil)
user, _ := auth.NewUser("arthur", "password", ch.SetOf("britain"))
user.(*userImpl).setRolesSince(ch.TimedSet{"square": ch.NewVbSimpleSequence(0x3), "nonexistent": ch.NewVbSimpleSequence(0x42), "frood": ch.NewVbSimpleSequence(0x4)})
assert.DeepEquals(t, user.RoleNames(), ch.TimedSet{"square": ch.NewVbSimpleSequence(0x3), "nonexistent": ch.NewVbSimpleSequence(0x42), "frood": ch.NewVbSimpleSequence(0x4)})
auth.Save(user)
user2, err := auth.GetUser("arthur")
assert.Equals(t, err, nil)
log.Printf("Channels = %s", user2.Channels())
assert.DeepEquals(t, user2.Channels(), ch.AtSequence(ch.SetOf("!", "britain"), 1))
assert.DeepEquals(t, user2.InheritedChannels(),
ch.TimedSet{"!": ch.NewVbSimpleSequence(0x1), "britain": ch.NewVbSimpleSequence(0x1), "dull": ch.NewVbSimpleSequence(0x3), "duller": ch.NewVbSimpleSequence(0x3), "dullest": ch.NewVbSimpleSequence(0x3), "hoopy": ch.NewVbSimpleSequence(0x4), "hoopier": ch.NewVbSimpleSequence(0x4), "hoopiest": ch.NewVbSimpleSequence(0x4)})
assert.True(t, user2.CanSeeChannel("britain"))
assert.True(t, user2.CanSeeChannel("duller"))
assert.True(t, user2.CanSeeChannel("hoopy"))
assert.Equals(t, user2.AuthorizeAllChannels(ch.SetOf("britain", "dull", "hoopiest")), nil)
}
示例10: VectorMultiChangesFeed
// Returns the (ordered) union of all of the changes made to multiple channels.
func (db *Database) VectorMultiChangesFeed(chans base.Set, options ChangesOptions) (<-chan *ChangeEntry, error) {
to := ""
var userVbNo uint16
if db.user != nil && db.user.Name() != "" {
to = fmt.Sprintf(" (to %s)", db.user.Name())
userVbNo = uint16(db.Bucket.VBHash(db.user.DocID()))
}
base.LogTo("Changes+", "Vector MultiChangesFeed(%s, %+v) ... %s", chans, options, to)
output := make(chan *ChangeEntry, 50)
go func() {
var cumulativeClock *base.SyncSequenceClock
var lastHashedValue string
hashedEntryCount := 0
defer func() {
base.LogTo("Changes+", "MultiChangesFeed done %s", to)
close(output)
}()
var changeWaiter *changeWaiter
var userChangeCount uint64
var addedChannels base.Set // Tracks channels added to the user during changes processing.
if options.Wait {
// Note (Adam): I don't think there's a reason to set this to false here. We're outside the
// main iteration loop (so the if check above should only happen once), and I don't believe
// options.Wait is referenced elsewhere once MultiChangesFeed is called. Leaving it as-is
// makes it possible for channels to identify whether a getChanges call has options.Wait set to true,
// which is useful to identify active change listeners. However, it's possible there's a subtlety of
// longpoll or continuous processing I'm missing here - leaving this note instead of just deleting for now.
//options.Wait = false
changeWaiter = db.startChangeWaiter(chans)
userChangeCount = changeWaiter.CurrentUserCount()
}
cumulativeClock = base.NewSyncSequenceClock()
cumulativeClock.SetTo(getChangesClock(options.Since))
// This loop is used to re-run the fetch after every database change, in Wait mode
outer:
for {
// Get the last polled stable sequence. We don't return anything later than stable sequence in each iteration
stableClock, err := db.changeCache.GetStableClock(true)
if err != nil {
base.Warn("MultiChangesFeed got error reading stable sequence: %v", err)
return
}
// Restrict to available channels, expand wild-card, and find since when these channels
// have been available to the user:
var channelsSince channels.TimedSet
if db.user != nil {
channelsSince = db.user.FilterToAvailableChannels(chans)
} else {
channelsSince = channels.AtSequence(chans, 0)
}
// Updates the changeWaiter to the current set of available channels.
if changeWaiter != nil {
changeWaiter.UpdateChannels(channelsSince)
}
base.LogTo("Changes+", "MultiChangesFeed: channels expand to %#v ... %s", channelsSince, to)
// Build the channel feeds.
feeds, err := db.initializeChannelFeeds(channelsSince, options, addedChannels, userVbNo)
if err != nil {
return
}
// This loop reads the available entries from all the feeds in parallel, merges them,
// and writes them to the output channel:
current := make([]*ChangeEntry, len(feeds))
var sentSomething bool
nextEntry := getNextSequenceFromFeeds(current, feeds)
for {
minEntry := nextEntry
if minEntry == nil {
break // Exit the loop when there are no more entries
}
// Calculate next entry here, to help identify whether minEntry is the last entry we're sending,
// to guarantee hashing
nextEntry = getNextSequenceFromFeeds(current, feeds)
// Don't send any entries later than the stable sequence
if stableClock.GetSequence(minEntry.Seq.vbNo) < minEntry.Seq.Seq {
continue
}
// Add the doc body or the conflicting rev IDs, if those options are set:
if options.IncludeDocs || options.Conflicts {
db.addDocToChangeEntry(minEntry, options)
}
// Clock handling
if minEntry.Seq.TriggeredBy == 0 {
// Update the cumulative clock, and stick it on the entry.
//.........這裏部分代碼省略.........
示例11: TestUserAccess
func TestUserAccess(t *testing.T) {
// User with no access:
auth := NewAuthenticator(gTestBucket, nil)
user, _ := auth.NewUser("foo", "password", nil)
assert.DeepEquals(t, user.ExpandWildCardChannel(ch.SetOf("*")), ch.SetOf("!"))
assert.False(t, user.CanSeeChannel("x"))
assert.True(t, canSeeAllChannels(user, ch.SetOf()))
assert.False(t, canSeeAllChannels(user, ch.SetOf("x")))
assert.False(t, canSeeAllChannels(user, ch.SetOf("x", "y")))
assert.False(t, canSeeAllChannels(user, ch.SetOf("*")))
assert.False(t, user.AuthorizeAllChannels(ch.SetOf("*")) == nil)
assert.False(t, user.AuthorizeAnyChannel(ch.SetOf("x", "y")) == nil)
assert.False(t, user.AuthorizeAnyChannel(ch.SetOf()) == nil)
// User with access to one channel:
user.setChannels(ch.AtSequence(ch.SetOf("x"), 1))
assert.DeepEquals(t, user.ExpandWildCardChannel(ch.SetOf("*")), ch.SetOf("x"))
assert.True(t, canSeeAllChannels(user, ch.SetOf()))
assert.True(t, canSeeAllChannels(user, ch.SetOf("x")))
assert.False(t, canSeeAllChannels(user, ch.SetOf("x", "y")))
assert.False(t, user.AuthorizeAllChannels(ch.SetOf("x", "y")) == nil)
assert.False(t, user.AuthorizeAllChannels(ch.SetOf("*")) == nil)
assert.True(t, user.AuthorizeAnyChannel(ch.SetOf("x", "y")) == nil)
assert.False(t, user.AuthorizeAnyChannel(ch.SetOf("y")) == nil)
assert.False(t, user.AuthorizeAnyChannel(ch.SetOf()) == nil)
// User with access to one channel and one derived channel:
user.setChannels(ch.AtSequence(ch.SetOf("x", "z"), 1))
assert.DeepEquals(t, user.ExpandWildCardChannel(ch.SetOf("*")), ch.SetOf("x", "z"))
assert.DeepEquals(t, user.ExpandWildCardChannel(ch.SetOf("x")), ch.SetOf("x"))
assert.True(t, canSeeAllChannels(user, ch.SetOf()))
assert.True(t, canSeeAllChannels(user, ch.SetOf("x")))
assert.False(t, canSeeAllChannels(user, ch.SetOf("x", "y")))
assert.False(t, user.AuthorizeAllChannels(ch.SetOf("x", "y")) == nil)
assert.False(t, user.AuthorizeAllChannels(ch.SetOf("*")) == nil)
// User with access to two channels:
user.setChannels(ch.AtSequence(ch.SetOf("x", "z"), 1))
assert.DeepEquals(t, user.ExpandWildCardChannel(ch.SetOf("*")), ch.SetOf("x", "z"))
assert.DeepEquals(t, user.ExpandWildCardChannel(ch.SetOf("x")), ch.SetOf("x"))
assert.True(t, canSeeAllChannels(user, ch.SetOf()))
assert.True(t, canSeeAllChannels(user, ch.SetOf("x")))
assert.False(t, canSeeAllChannels(user, ch.SetOf("x", "y")))
assert.False(t, user.AuthorizeAllChannels(ch.SetOf("x", "y")) == nil)
assert.False(t, user.AuthorizeAllChannels(ch.SetOf("*")) == nil)
user.setChannels(ch.AtSequence(ch.SetOf("x", "y"), 1))
assert.DeepEquals(t, user.ExpandWildCardChannel(ch.SetOf("*")), ch.SetOf("x", "y"))
assert.True(t, canSeeAllChannels(user, ch.SetOf()))
assert.True(t, canSeeAllChannels(user, ch.SetOf("x")))
assert.True(t, canSeeAllChannels(user, ch.SetOf("x", "y")))
assert.False(t, canSeeAllChannels(user, ch.SetOf("x", "y", "z")))
assert.True(t, user.AuthorizeAllChannels(ch.SetOf("x", "y")) == nil)
assert.False(t, user.AuthorizeAllChannels(ch.SetOf("*")) == nil)
// User with wildcard access:
user.setChannels(ch.AtSequence(ch.SetOf("*", "q"), 1))
assert.DeepEquals(t, user.ExpandWildCardChannel(ch.SetOf("*")), ch.SetOf("*", "q"))
assert.True(t, user.CanSeeChannel("*"))
assert.True(t, canSeeAllChannels(user, ch.SetOf()))
assert.True(t, canSeeAllChannels(user, ch.SetOf("x")))
assert.True(t, canSeeAllChannels(user, ch.SetOf("x", "y")))
assert.True(t, user.AuthorizeAllChannels(ch.SetOf("x", "y")) == nil)
assert.True(t, user.AuthorizeAllChannels(ch.SetOf("*")) == nil)
assert.True(t, user.AuthorizeAnyChannel(ch.SetOf("x")) == nil)
assert.True(t, user.AuthorizeAnyChannel(ch.SetOf("*")) == nil)
assert.True(t, user.AuthorizeAnyChannel(ch.SetOf()) == nil)
}
示例12: initRole
func (role *roleImpl) initRole(name string, channels base.Set) error {
channels = ch.ExpandingStar(channels)
role.Name_ = name
role.ExplicitChannels_ = ch.AtSequence(channels, 1)
return role.validate()
}
示例13: SimpleMultiChangesFeed
// Returns the (ordered) union of all of the changes made to multiple channels.
func (db *Database) SimpleMultiChangesFeed(chans base.Set, options ChangesOptions) (<-chan *ChangeEntry, error) {
to := ""
if db.user != nil && db.user.Name() != "" {
to = fmt.Sprintf(" (to %s)", db.user.Name())
}
base.LogTo("Changes", "MultiChangesFeed(%s, %+v) ... %s", chans, options, to)
output := make(chan *ChangeEntry, 50)
go func() {
defer func() {
base.LogTo("Changes", "MultiChangesFeed done %s", to)
close(output)
}()
var changeWaiter *changeWaiter
var userChangeCount uint64
var lowSequence uint64
var lateSequenceFeeds map[string]*lateSequenceFeed
var addedChannels base.Set // Tracks channels added to the user during changes processing.
// lowSequence is used to send composite keys to clients, so that they can obtain any currently
// skipped sequences in a future iteration or request.
oldestSkipped := db.changeCache.getOldestSkippedSequence()
if oldestSkipped > 0 {
lowSequence = oldestSkipped - 1
} else {
lowSequence = 0
}
if options.Wait {
options.Wait = false
changeWaiter = db.startChangeWaiter(chans)
userChangeCount = changeWaiter.CurrentUserCount()
}
// If a request has a low sequence that matches the current lowSequence,
// ignore the low sequence. This avoids infinite looping of the records between
// low::high. It also means any additional skipped sequences between low::high won't
// be sent until low arrives or is abandoned.
if options.Since.LowSeq != 0 && options.Since.LowSeq == lowSequence {
options.Since.LowSeq = 0
}
// For a continuous feed, initialise the lateSequenceFeeds that track late-arriving sequences
// to the channel caches.
if options.Continuous {
lateSequenceFeeds = make(map[string]*lateSequenceFeed)
}
// This loop is used to re-run the fetch after every database change, in Wait mode
outer:
for {
// Restrict to available channels, expand wild-card, and find since when these channels
// have been available to the user:
var channelsSince channels.TimedSet
if db.user != nil {
channelsSince = db.user.FilterToAvailableChannels(chans)
} else {
channelsSince = channels.AtSequence(chans, 0)
}
// Updates the changeWaiter to the current set of available channels
if changeWaiter != nil {
changeWaiter.UpdateChannels(channelsSince)
}
base.LogTo("Changes+", "MultiChangesFeed: channels expand to %#v ... %s", channelsSince, to)
// lowSequence is used to send composite keys to clients, so that they can obtain any currently
// skipped sequences in a future iteration or request.
oldestSkipped = db.changeCache.getOldestSkippedSequence()
if oldestSkipped > 0 {
lowSequence = oldestSkipped - 1
} else {
lowSequence = 0
}
// Populate the parallel arrays of channels and names:
feeds := make([]<-chan *ChangeEntry, 0, len(channelsSince))
names := make([]string, 0, len(channelsSince))
// Get read lock for late-arriving sequences, to avoid sending the same late arrival in
// two different changes iterations. e.g. without the RLock, a late-arriving sequence
// could be written to channel X during one iteration, and channel Y during another. Users
// with access to both channels would see two versions on the feed.
for name, vbSeqAddedAt := range channelsSince {
chanOpts := options
seqAddedAt := vbSeqAddedAt.Sequence
// Check whether requires backfill based on addedChannels in this _changes feed
isNewChannel := false
if addedChannels != nil {
_, isNewChannel = addedChannels[name]
}
// Check whether requires backfill based on current sequence, seqAddedAt
// Triggered by handling:
// 1. options.Since.TriggeredBy == seqAddedAt : We're in the middle of backfill for this channel, based
//.........這裏部分代碼省略.........