This repository has been archived by the owner on Jun 19, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 74
/
Copy pathsubscription.go
93 lines (79 loc) · 2.84 KB
/
subscription.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/*
Copyright 2019 Google LLC
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package pubsub
import (
"context"
"time"
"cloud.google.com/go/pubsub"
)
// SubscriptionConfig re-implements pubsub.SubscriptionConfig to allow us to
// use a wrapped Topic internally.
type SubscriptionConfig struct {
Topic Topic
AckDeadline time.Duration
RetainAckedMessages bool
RetentionDuration time.Duration
Labels map[string]string
}
// pubsubSubscription wraps pubsub.Subscription. Is the subscription that will be used everywhere except unit tests.
type pubsubSubscription struct {
sub *pubsub.Subscription
}
// Verify that it satisfies the pubsub.Subscription interface.
var _ Subscription = &pubsubSubscription{}
// Exists implements pubsub.Subscription.Exists
func (s *pubsubSubscription) Exists(ctx context.Context) (bool, error) {
return s.sub.Exists(ctx)
}
// Config implements pubsub.Subscription.Config
func (s *pubsubSubscription) Config(ctx context.Context) (SubscriptionConfig, error) {
cfg, err := s.sub.Config(ctx)
if err != nil {
return SubscriptionConfig{}, err
}
return SubscriptionConfig{
Topic: &pubsubTopic{topic: cfg.Topic},
AckDeadline: cfg.AckDeadline,
RetainAckedMessages: cfg.RetainAckedMessages,
RetentionDuration: cfg.RetentionDuration,
Labels: cfg.Labels,
}, nil
}
// Update implements pubsub.Subscription.Update
func (s *pubsubSubscription) Update(ctx context.Context, cfg SubscriptionConfig) (SubscriptionConfig, error) {
config := pubsub.SubscriptionConfigToUpdate{
Labels: cfg.Labels,
RetainAckedMessages: cfg.RetainAckedMessages,
RetentionDuration: cfg.RetentionDuration,
AckDeadline: cfg.AckDeadline,
}
updatedConfig, err := s.sub.Update(ctx, config)
if err != nil {
return SubscriptionConfig{}, err
}
return SubscriptionConfig{
Topic: &pubsubTopic{topic: updatedConfig.Topic},
AckDeadline: updatedConfig.AckDeadline,
RetainAckedMessages: updatedConfig.RetainAckedMessages,
RetentionDuration: updatedConfig.RetentionDuration,
Labels: updatedConfig.Labels,
}, err
}
// Delete implements pubsub.Subscription.Delete
func (s *pubsubSubscription) Delete(ctx context.Context) error {
return s.sub.Delete(ctx)
}
// ID implements pubsub.Subscription.ID
func (s *pubsubSubscription) ID() string {
return s.sub.ID()
}