OpenWriter opens a new writer for the given reference, retrying if the writer is locked until the reference is available or returns an error.
(ctx context.Context, cs Ingester, opts ...WriterOpt)
| 147 | // OpenWriter opens a new writer for the given reference, retrying if the writer |
| 148 | // is locked until the reference is available or returns an error. |
| 149 | func OpenWriter(ctx context.Context, cs Ingester, opts ...WriterOpt) (Writer, error) { |
| 150 | var ( |
| 151 | cw Writer |
| 152 | err error |
| 153 | retry = 16 |
| 154 | ) |
| 155 | for { |
| 156 | cw, err = cs.Writer(ctx, opts...) |
| 157 | if err != nil { |
| 158 | if !errdefs.IsUnavailable(err) { |
| 159 | return nil, err |
| 160 | } |
| 161 | |
| 162 | // TODO: Check status to determine if the writer is active, |
| 163 | // continue waiting while active, otherwise return lock |
| 164 | // error or abort. Requires asserting for an ingest manager |
| 165 | |
| 166 | select { |
| 167 | case <-time.After(time.Millisecond * time.Duration(randutil.Intn(retry))): |
| 168 | if retry < 2048 { |
| 169 | retry = retry << 1 |
| 170 | } |
| 171 | continue |
| 172 | case <-ctx.Done(): |
| 173 | // Propagate lock error |
| 174 | return nil, err |
| 175 | } |
| 176 | |
| 177 | } |
| 178 | break |
| 179 | } |
| 180 | |
| 181 | return cw, err |
| 182 | } |
| 183 | |
| 184 | // Copy copies data with the expected digest from the reader into the |
| 185 | // provided content store writer. This copy commits the writer. |
searching dependent graphs…