 9bdcbe0447
			
		
	
	9bdcbe0447
	
	
	
		
			
			Major integrations and fixes: - Added BACKBEAT SDK integration for P2P operation timing - Implemented beat-aware status tracking for distributed operations - Added Docker secrets support for secure license management - Resolved KACHING license validation via HTTPS/TLS - Updated docker-compose configuration for clean stack deployment - Disabled rollback policies to prevent deployment failures - Added license credential storage (CHORUS-DEV-MULTI-001) Technical improvements: - BACKBEAT P2P operation tracking with phase management - Enhanced configuration system with file-based secrets - Improved error handling for license validation - Clean separation of KACHING and CHORUS deployment stacks 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
		
			
				
	
	
		
			42 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package linking
 | |
| 
 | |
| import (
 | |
| 	"io"
 | |
| 
 | |
| 	"github.com/ipld/go-ipld-prime/datamodel"
 | |
| 	"github.com/ipld/go-ipld-prime/storage"
 | |
| )
 | |
| 
 | |
| // SetReadStorage configures how the LinkSystem will look for information to load,
 | |
| // setting it to look at the given storage.ReadableStorage.
 | |
| //
 | |
| // This will overwrite the LinkSystem.StorageReadOpener field.
 | |
| //
 | |
| // This mechanism only supports setting exactly one ReadableStorage.
 | |
| // If you would like to make a more complex configuration
 | |
| // (for example, perhaps using information from a LinkContext to decide which storage area to use?)
 | |
| // then you should set LinkSystem.StorageReadOpener to a custom callback of your own creation instead.
 | |
| func (lsys *LinkSystem) SetReadStorage(store storage.ReadableStorage) {
 | |
| 	lsys.StorageReadOpener = func(lctx LinkContext, lnk datamodel.Link) (io.Reader, error) {
 | |
| 		return storage.GetStream(lctx.Ctx, store, lnk.Binary())
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // SetWriteStorage configures how the LinkSystem will store information,
 | |
| // setting it to write into the given storage.WritableStorage.
 | |
| //
 | |
| // This will overwrite the LinkSystem.StorageWriteOpener field.
 | |
| //
 | |
| // This mechanism only supports setting exactly one WritableStorage.
 | |
| // If you would like to make a more complex configuration
 | |
| // (for example, perhaps using information from a LinkContext to decide which storage area to use?)
 | |
| // then you should set LinkSystem.StorageWriteOpener to a custom callback of your own creation instead.
 | |
| func (lsys *LinkSystem) SetWriteStorage(store storage.WritableStorage) {
 | |
| 	lsys.StorageWriteOpener = func(lctx LinkContext) (io.Writer, BlockWriteCommitter, error) {
 | |
| 		wr, wrcommit, err := storage.PutStream(lctx.Ctx, store)
 | |
| 		return wr, func(lnk datamodel.Link) error {
 | |
| 			return wrcommit(lnk.Binary())
 | |
| 		}, err
 | |
| 	}
 | |
| }
 |