channeldb: skip sub-buckets during invoice time series migration

In this commit, we fix an existing bu gin the invoice time series
migration code. Before this commit, the migration would fail as we would
try to migrate an empty invoice. We now detect this case and skip all
empty invoices.

We also add a bit more logging on both the info and trace logging level.
This commit is contained in:
Olaoluwa Osuntokun 2018-07-05 22:07:40 -05:00
parent 4813da9a64
commit db4a09d3b5
No known key found for this signature in database
GPG Key ID: 964EA263DD637C21

@ -136,10 +136,17 @@ func migrateInvoiceTimeSeries(tx *bolt.Tx) error {
return err return err
} }
log.Infof("Migrating invoice database to new time series format")
// Now that we have all the buckets we need, we'll run through each // Now that we have all the buckets we need, we'll run through each
// invoice in the database, and update it to reflect the new format // invoice in the database, and update it to reflect the new format
// expected post migration. // expected post migration.
return invoices.ForEach(func(invoiceNum, invoiceBytes []byte) error { err = invoices.ForEach(func(invoiceNum, invoiceBytes []byte) error {
// If this is a sub bucket, then we'll skip it.
if invoiceBytes == nil {
return nil
}
// First, we'll make a copy of the encoded invoice bytes. // First, we'll make a copy of the encoded invoice bytes.
invoiceBytesCopy := make([]byte, len(invoiceBytes)) invoiceBytesCopy := make([]byte, len(invoiceBytes))
copy(invoiceBytesCopy, invoiceBytes) copy(invoiceBytesCopy, invoiceBytes)
@ -153,7 +160,7 @@ func migrateInvoiceTimeSeries(tx *bolt.Tx) error {
invoiceReader := bytes.NewReader(invoiceBytesCopy) invoiceReader := bytes.NewReader(invoiceBytesCopy)
invoice, err := deserializeInvoice(invoiceReader) invoice, err := deserializeInvoice(invoiceReader)
if err != nil { if err != nil {
return err return fmt.Errorf("unable to decode invoice: %v", err)
} }
// Now that we have the fully decoded invoice, we can update // Now that we have the fully decoded invoice, we can update
@ -173,6 +180,10 @@ func migrateInvoiceTimeSeries(tx *bolt.Tx) error {
return err return err
} }
log.Tracef("Adding invoice (preimage=%v, add_index=%v) to add "+
"time series", invoice.Terms.PaymentPreimage[:],
nextAddSeqNo)
// Next, we'll check if the invoice has been settled or not. If // Next, we'll check if the invoice has been settled or not. If
// so, then we'll also add it to the settle index. // so, then we'll also add it to the settle index.
var nextSettleSeqNo uint64 var nextSettleSeqNo uint64
@ -190,6 +201,11 @@ func migrateInvoiceTimeSeries(tx *bolt.Tx) error {
} }
invoice.AmtPaid = invoice.Terms.Value invoice.AmtPaid = invoice.Terms.Value
log.Tracef("Adding invoice (preimage=%v, "+
"settle_index=%v) to add time series",
invoice.Terms.PaymentPreimage[:],
nextSettleSeqNo)
} }
// Finally, we'll update the invoice itself with the new // Finally, we'll update the invoice itself with the new
@ -207,4 +223,11 @@ func migrateInvoiceTimeSeries(tx *bolt.Tx) error {
return invoices.Put(invoiceNum, b.Bytes()) return invoices.Put(invoiceNum, b.Bytes())
}) })
if err != nil {
return err
}
log.Infof("Migration to invoice time series index complete!")
return nil
} }