You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							43 lines
						
					
					
						
							1.1 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							43 lines
						
					
					
						
							1.1 KiB
						
					
					
				
								package arangodb
							 | 
						|
								
							 | 
						|
								import (
							 | 
						|
									"context"
							 | 
						|
									"github.com/arangodb/go-driver"
							 | 
						|
									"time"
							 | 
						|
								
							 | 
						|
									"github.com/seaweedfs/seaweedfs/weed/filer"
							 | 
						|
								
							 | 
						|
									"github.com/seaweedfs/seaweedfs/weed/glog"
							 | 
						|
								)
							 | 
						|
								
							 | 
						|
								var _ filer.BucketAware = (*ArangodbStore)(nil)
							 | 
						|
								
							 | 
						|
								func (store *ArangodbStore) OnBucketCreation(bucket string) {
							 | 
						|
									timeout, cancel := context.WithTimeout(context.Background(), 10*time.Second)
							 | 
						|
									defer cancel()
							 | 
						|
									// create the collection && add to cache
							 | 
						|
									_, err := store.ensureBucket(timeout, bucket)
							 | 
						|
									if err != nil {
							 | 
						|
										glog.Errorf("bucket create %s: %v", bucket, err)
							 | 
						|
									}
							 | 
						|
								}
							 | 
						|
								func (store *ArangodbStore) OnBucketDeletion(bucket string) {
							 | 
						|
									timeout, cancel := context.WithTimeout(context.Background(), 10*time.Second)
							 | 
						|
									defer cancel()
							 | 
						|
									collection, err := store.ensureBucket(timeout, bucket)
							 | 
						|
									if err != nil {
							 | 
						|
										glog.Errorf("bucket delete %s: %v", bucket, err)
							 | 
						|
										return
							 | 
						|
									}
							 | 
						|
									err = collection.Remove(timeout)
							 | 
						|
									if err != nil && !driver.IsNotFound(err) {
							 | 
						|
										glog.Errorf("bucket delete %s: %v", bucket, err)
							 | 
						|
										return
							 | 
						|
									}
							 | 
						|
									store.mu.Lock()
							 | 
						|
									delete(store.buckets, bucket)
							 | 
						|
									store.mu.Unlock()
							 | 
						|
								}
							 | 
						|
								func (store *ArangodbStore) CanDropWholeBucket() bool {
							 | 
						|
									return true
							 | 
						|
								}
							 |