func runExample(client *as.Client) { // Write initial record. key, _ := as.NewKey(*shared.Namespace, *shared.Set, "opkey") bin1 := as.NewBin("optintbin", 7) bin2 := as.NewBin("optstringbin", "string value") log.Printf("Put: namespace=%s set=%s key=%s bin1=%s value1=%s bin2=%s value2=%s", key.Namespace(), key.SetName(), key.Value(), bin1.Name, bin1.Value, bin2.Name, bin2.Value) client.PutBins(shared.WritePolicy, key, bin1, bin2) // Add integer, write new string and read record. bin3 := as.NewBin(bin1.Name, 4) bin4 := as.NewBin(bin2.Name, "new string") log.Println("Add: ", bin3.Value) log.Println("Write: ", bin4.Value) log.Println("Read:") record, err := client.Operate(shared.WritePolicy, key, as.AddOp(bin3), as.PutOp(bin4), as.GetOp()) shared.PanicOnError(err) if record == nil { log.Fatalf( "Failed to get: namespace=%s set=%s key=%s", key.Namespace(), key.SetName(), key.Value()) } binExpected := as.NewBin(bin3.Name, 11) shared.ValidateBin(key, binExpected, record) shared.ValidateBin(key, bin4, record) }
// Execute put and get on a server configured as multi-bin. This is the server default. func runMultiBinExample(client *as.Client) { key, _ := as.NewKey(*shared.Namespace, *shared.Set, "putgetkey") bin1 := as.NewBin("bin1", "value1") bin2 := as.NewBin("bin2", "value2") log.Printf("Put: namespace=%s set=%s key=%s bin1=%s value1=%s bin2=%s value2=%s", key.Namespace(), key.SetName(), key.Value(), bin1.Name, bin1.Value, bin2.Name, bin2.Value) client.PutBins(shared.WritePolicy, key, bin1, bin2) log.Printf("Get: namespace=%s set=%s key=%s", key.Namespace(), key.SetName(), key.Value()) record, err := client.Get(shared.Policy, key) shared.PanicOnError(err) if record == nil { panic(errors.New(fmt.Sprintf( "Failed to get: namespace=%s set=%s key=%s", key.Namespace(), key.SetName(), key.Value()))) } shared.ValidateBin(key, bin1, record) shared.ValidateBin(key, bin2, record) }
func runReplaceExample(client *as.Client) { key, err := as.NewKey(*shared.Namespace, *shared.Set, "replacekey") shared.PanicOnError(err) bin1 := as.NewBin("bin1", "value1") bin2 := as.NewBin("bin2", "value2") bin3 := as.NewBin("bin3", "value3") log.Printf("Put: namespace=%s set=%s key=%s bin1=%s value1=%s bin2=%s value2=%s", key.Namespace(), key.SetName(), key.Value(), bin1.Name, bin1.Value, bin2.Name, bin2.Value) client.PutBins(shared.WritePolicy, key, bin1, bin2) log.Printf("Replace with: namespace=%s set=%s key=%s bin=%s value=%s", key.Namespace(), key.SetName(), key.Value(), bin3.Name, bin3.Value) wpolicy := as.NewWritePolicy(0, 0) wpolicy.RecordExistsAction = as.REPLACE client.PutBins(wpolicy, key, bin3) log.Printf("Get: namespace=%s set=%s key=%s", key.Namespace(), key.SetName(), key.Value()) record, err := client.Get(shared.Policy, key) if record == nil { log.Fatalf( "Failed to get: namespace=%s set=%s key=%s", key.Namespace(), key.SetName(), key.Value()) } if record.Bins[bin1.Name] == nil { log.Printf(bin1.Name + " was deleted as expected.") } else { log.Fatalln(bin1.Name + " found when it should have been deleted.") } if record.Bins[bin2.Name] == nil { log.Printf(bin2.Name + " was deleted as expected.") } else { log.Fatalln(bin2.Name + " found when it should have been deleted.") } shared.ValidateBin(key, bin3, record) }
// Execute put and get on a server configured as single-bin. func runSingleBinExample(client *as.Client) { key, _ := as.NewKey(*shared.Namespace, *shared.Set, "putgetkey") bin := as.NewBin("", "value") log.Printf("Single Put: namespace=%s set=%s key=%s value=%s", key.Namespace(), key.SetName(), key.Value(), bin.Value) client.PutBins(shared.WritePolicy, key, bin) log.Printf("Single Get: namespace=%s set=%s key=%s", key.Namespace(), key.SetName(), key.Value()) record, err := client.Get(shared.Policy, key) shared.PanicOnError(err) if record == nil { panic(errors.New(fmt.Sprintf( "Failed to get: namespace=%s set=%s key=%s", key.Namespace(), key.SetName(), key.Value()))) } shared.ValidateBin(key, bin, record) }