-
Notifications
You must be signed in to change notification settings - Fork 76
Expand file tree
/
Copy pathowlbot.py
More file actions
121 lines (111 loc) · 4.32 KB
/
owlbot.py
File metadata and controls
121 lines (111 loc) · 4.32 KB
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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
# Copyright 2018 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.
"""This script is used to synthesize generated parts of this library."""
import json
import synthtool as s
import synthtool.gcp as gcp
import synthtool.languages.java as java
protobuf_header = "// Generated by the protocol buffer compiler. DO NOT EDIT!"
# License header
license_header = """/*
* 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
*
* https://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.
*/
"""
bad_license_header = """/\\*
\\* Copyright 2018 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.
\\*/
"""
for library in s.get_staging_dirs():
# put any special-case replacements here
service = "firestore"
version = "v1"
s.replace(
f'owl-bot-staging/v1/proto-google-cloud-{service}-{version}-java/src/**/*.java',
protobuf_header,
f'{license_header}{protobuf_header}'
)
service == "firestore-admin"
s.replace(
f'owl-bot-staging/v1/grpc-google-cloud-{service}-{version}-java/src/**/*.java',
bad_license_header,
license_header
)
s.replace(
f'owl-bot-staging/v1/proto-google-cloud-{service}-{version}-java/src/**/*.java',
bad_license_header,
license_header
)
s.move(library)
s.remove_staging_dirs()
java.common_templates(excludes=[
# firestore uses a different project for its integration tests
# due to the default project running datastore
'.kokoro/presubmit/integration.cfg',
'.kokoro/presubmit/graalvm-native-a.cfg',
'.kokoro/presubmit/graalvm-native-b.cfg',
'.kokoro/presubmit/graalvm-native-c.cfg',
'.kokoro/presubmit/samples.cfg',
'.kokoro/nightly/integration.cfg',
'.kokoro/nightly/java11-integration.cfg',
'.kokoro/nightly/samples.cfg',
'.kokoro/build.sh',
'samples/snapshot/pom.xml',
'.kokoro/release/publish_javadoc.sh',
'.kokoro/release/publish_javadoc11.sh',
'.kokoro/release/stage.sh',
'.kokoro/requirements.in',
'.kokoro/requirements.txt',
'.github/CODEOWNERS',
'.github/workflows/samples.yaml',
'renovate.json'
])
# Fix for b/442875200: Inject library_path_overrides for FirestoreAdminClient
# This ensures the doclet links to the correct source directory (google-cloud-firestore-admin)
# instead of the default artifactId (google-cloud-firestore).
metadata_path = ".repo-metadata.json"
try:
with open(metadata_path, "r") as f:
metadata = json.load(f)
# Add the override map if it doesn't exist or update it
if "library_path_overrides" not in metadata:
metadata["library_path_overrides"] = {}
metadata["library_path_overrides"]["FirestoreAdminClient"] = "google-cloud-firestore-admin"
# Write the updated metadata back to the file
with open(metadata_path, "w") as f:
json.dump(metadata, f, indent=2)
f.write("\n")
except Exception as e:
print(f"Failed to update .repo-metadata.json: {e}")