-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add initial Plugin specification #132
Merged
Merged
Changes from 50 commits
Commits
Show all changes
51 commits
Select commit
Hold shift + click to select a range
e2a11ff
wip
mfridman aa08ddf
wip; pass format lint
mfridman 2577109
disable push
mfridman 2a1a374
Enable push
emcfarlane 861779d
first pass at tidying up registry config
mfridman badc37d
wip
mfridman fa7e531
wip
mfridman c5e3a78
wip
mfridman 0eac937
wip
mfridman a82217d
wip
mfridman dff06aa
wip
mfridman adb18e6
wip
emcfarlane 69b571b
switch to commits and labels
emcfarlane 0208156
wip
mfridman a3472e1
wip
mfridman af0c906
wip
mfridman df121ef
Update commit service and Digest P1
emcfarlane 6887aab
add collection entity instead of enum
mfridman c0a6fdc
wip
mfridman 7741a6b
fix lint
mfridman 365a2e4
commit
mfridman b34ff09
commit
mfridman 681ee14
fix collection id
emcfarlane bab5cf2
add plugin image uploads
emcfarlane a7468f6
update plugin create request
mfridman 0badaec
update upload_service.proto
mfridman b1f3222
s/module/plugin and comments
mfridman 3e44a69
update comment
mfridman fd48e8f
remove todo: digest
mfridman 428ed38
remove todo: compression
mfridman 04cb0ab
remove todo: source_url
mfridman 69c0d42
cleanup field numbers
mfridman ab84720
Merge branch 'main' into mf/plugins
bufdev 38293c9
remove legacy docker-based plugin definitions; misc cleanup
mfridman b687e13
remove compression type
mfridman 9af8a88
copy plugin info and update comments
mfridman d9ba013
flatten and remove nested filter message
mfridman a801d90
update comment
mfridman 6813f20
add scoped label refs to upload
mfridman 4282fe1
updates following review
mfridman 398d8e0
restore protovalidate for now
mfridman 304e859
add partial collection_service.proto
mfridman c47e631
add source_control_url to upload
mfridman 2e7c067
add collection service definitions; misc cleanup
mfridman 624adc0
fix comment
mfridman b3ac2f4
use The for consistency
mfridman f6f7205
Add a limit to upload
mfridman 3dee9d4
add GetPluginCollectionAssociations
mfridman 1782bc5
rename from v1beta1 to v1
mfridman 45eb887
add compression.proto and use in both upload and download
mfridman dea5e2a
rename from v1 to v1beta1
mfridman File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,9 @@ | ||
# Generated by buf. DO NOT EDIT. | ||
version: v2 | ||
deps: | ||
- name: buf.build/bufbuild/bufplugin | ||
commit: 42bdb4b676254830a221d52d10bf17be | ||
digest: b5:c9fb96550e52b1b899f667d2371d2aee37b4b5b0d8e21d83dd620207d466f3a95b96fc072fe9a49785da293f1fe379f0b4ac8ce054b6a1cedcafba8f2145d086 | ||
- name: buf.build/bufbuild/protovalidate | ||
commit: b983156c5e994cc9892e0ce3e64e17e0 | ||
digest: b5:a02a4a5a0a9306cf1391d17e8811bbd6a0dbd0e0e29ddfc34b9d103311164974472d43627c3d63e6a8abaffd6c7a301c4f7965bbab2dc56f7f7812429a84b812 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,65 @@ | ||
// Copyright 2023-2024 Buf Technologies, Inc. | ||
// | ||
// 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. | ||
|
||
syntax = "proto3"; | ||
|
||
package buf.registry.plugin.v1; | ||
|
||
import "buf/registry/priv/extension/v1beta1/extension.proto"; | ||
import "buf/validate/validate.proto"; | ||
import "google/protobuf/timestamp.proto"; | ||
|
||
option go_package = "buf.build/gen/go/bufbuild/registry/protocolbuffers/go/buf/registry/plugin/v1"; | ||
|
||
// A collection for a Plugin. | ||
// | ||
// These collections help organize plugins based on their functionality or ecosystem. | ||
message Collection { | ||
option (buf.registry.priv.extension.v1beta1.message).response_only = true; | ||
|
||
// The id of the Collection. | ||
string id = 1 [ | ||
(buf.validate.field).required = true, | ||
(buf.validate.field).string.tuuid = true | ||
]; | ||
// The time the Collection was created on the BSR. | ||
google.protobuf.Timestamp create_time = 2 [(buf.validate.field).required = true]; | ||
// The last time the Collection was updated on the BSR. | ||
google.protobuf.Timestamp update_time = 3 [(buf.validate.field).required = true]; | ||
// The name of the Collection. | ||
// | ||
// Unique within a BSR instance. | ||
string name = 4 [ | ||
(buf.validate.field).required = true, | ||
(buf.validate.field).string.max_len = 250 | ||
]; | ||
// The configurable description of the Collection. | ||
string description = 5 [(buf.validate.field).string.max_len = 350]; | ||
} | ||
|
||
// CollectionRef is a reference to a Collection, either an id or a name. | ||
message CollectionRef { | ||
option (buf.registry.priv.extension.v1beta1.message).request_only = true; | ||
|
||
oneof value { | ||
option (buf.validate.oneof).required = true; | ||
// The id of the Collection. | ||
string id = 1 [(buf.validate.field).string.tuuid = true]; | ||
// The name of the Collection. | ||
string name = 2 [(buf.validate.field).string = { | ||
min_len: 2 | ||
max_len: 100 | ||
}]; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,104 @@ | ||
// Copyright 2023-2024 Buf Technologies, Inc. | ||
// | ||
// 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. | ||
|
||
syntax = "proto3"; | ||
|
||
package buf.registry.plugin.v1; | ||
|
||
import "buf/registry/plugin/v1/collection.proto"; | ||
import "buf/registry/plugin/v1/plugin.proto"; | ||
import "buf/validate/validate.proto"; | ||
|
||
option go_package = "buf.build/gen/go/bufbuild/registry/protocolbuffers/go/buf/registry/plugin/v1"; | ||
|
||
// Operate on Collections. | ||
service CollectionService { | ||
// Get Collections. | ||
rpc GetCollections(GetCollectionsRequest) returns (GetCollectionsResponse) { | ||
option idempotency_level = NO_SIDE_EFFECTS; | ||
} | ||
// List Collections for a given Plugin. | ||
rpc ListCollections(ListCollectionsRequest) returns (ListCollectionsResponse) { | ||
option idempotency_level = NO_SIDE_EFFECTS; | ||
} | ||
// Get the Collections for the given Plugins. | ||
rpc GetPluginCollectionAssociations(GetPluginCollectionAssociationsRequest) returns (GetPluginCollectionAssociationsResponse) { | ||
option idempotency_level = NO_SIDE_EFFECTS; | ||
} | ||
} | ||
|
||
message GetCollectionsRequest { | ||
// The Collections to request. | ||
repeated CollectionRef collection_refs = 1 [ | ||
(buf.validate.field).repeated.min_items = 1, | ||
(buf.validate.field).repeated.max_items = 250 | ||
]; | ||
} | ||
|
||
message GetCollectionsResponse { | ||
// The retrieved Collections in the same order as requested. | ||
repeated Collection collections = 1 [(buf.validate.field).repeated.min_items = 1]; | ||
} | ||
|
||
message ListCollectionsRequest { | ||
// The list order. | ||
enum Order { | ||
ORDER_UNSPECIFIED = 0; | ||
// Order by create_time newest to oldest. | ||
ORDER_CREATE_TIME_DESC = 1; | ||
// Order by create_time oldest to newest. | ||
ORDER_CREATE_TIME_ASC = 2; | ||
} | ||
// The maximum number of items to return. | ||
// | ||
// The default value is 10. | ||
uint32 page_size = 1 [(buf.validate.field).uint32.lte = 250]; | ||
// The page to start from. | ||
// | ||
// If empty, the first page is returned. | ||
string page_token = 2 [(buf.validate.field).string.max_len = 4096]; | ||
// The order to return the Plugins. | ||
// | ||
// If not specified, defaults to ORDER_CREATE_TIME_DESC. | ||
Order order = 3 [(buf.validate.field).enum.defined_only = true]; | ||
} | ||
|
||
message ListCollectionsResponse { | ||
// The next page token. | ||
// | ||
// If empty, there are no more pages. | ||
string next_page_token = 1 [(buf.validate.field).string.max_len = 4096]; | ||
// The listed Collections. | ||
repeated Collection collections = 2; | ||
} | ||
|
||
message GetPluginCollectionAssociationsRequest { | ||
// The Plugins to request Collections for. | ||
repeated PluginRef plugin_refs = 1 [ | ||
(buf.validate.field).repeated.min_items = 1, | ||
(buf.validate.field).repeated.max_items = 250 | ||
]; | ||
} | ||
|
||
message GetPluginCollectionAssociationsResponse { | ||
// The Associations for the requested Plugins. | ||
message Association { | ||
// The id of the Plugin. | ||
string plugin_id = 1; | ||
// The collection ids associated with the Plugin. | ||
repeated string collection_ids = 2; | ||
} | ||
// The Associations for the requested Plugins in the same order as requested. | ||
repeated Association associations = 1; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
// Copyright 2023-2024 Buf Technologies, Inc. | ||
// | ||
// 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. | ||
|
||
syntax = "proto3"; | ||
|
||
package buf.registry.plugin.v1; | ||
|
||
import "buf/plugin/info/v1/plugin_info.proto"; | ||
import "buf/registry/plugin/v1/digest.proto"; | ||
import "buf/registry/priv/extension/v1beta1/extension.proto"; | ||
import "buf/validate/validate.proto"; | ||
import "google/protobuf/timestamp.proto"; | ||
|
||
option go_package = "buf.build/gen/go/bufbuild/registry/protocolbuffers/go/buf/registry/plugin/v1"; | ||
|
||
// A commit on a specific Plugin. | ||
// | ||
// Commits are immutable. | ||
// | ||
// Many Commits may be associated with one Digest. | ||
// | ||
// Not that the Digest returned on a Commit depends on the requested DigestType in the RPC that | ||
// returned the Commit. | ||
message Commit { | ||
option (buf.registry.priv.extension.v1beta1.message).response_only = true; | ||
|
||
// The id of the Commit. | ||
string id = 1 [ | ||
(buf.validate.field).required = true, | ||
(buf.validate.field).string.tuuid = true | ||
]; | ||
// The time the Commit was pushed to the BSR. | ||
// | ||
// Commits are immutable, so there is no corresponding update_time. | ||
google.protobuf.Timestamp create_time = 2 [(buf.validate.field).required = true]; | ||
// The id of the Organization that owns the Plugin that the Commit is associated with. | ||
string owner_id = 3 [ | ||
(buf.validate.field).required = true, | ||
(buf.validate.field).string.tuuid = true | ||
]; | ||
// The id of the Plugin that the Commit is associated with. | ||
string plugin_id = 4 [ | ||
(buf.validate.field).required = true, | ||
(buf.validate.field).string.tuuid = true | ||
]; | ||
// The Digest of the Commit's contents. | ||
Digest digest = 5 [(buf.validate.field).required = true]; | ||
// The id of the User that created this Commit on the BSR. | ||
// | ||
// May be empty if the User is no longer available. | ||
string created_by_user_id = 6 [ | ||
(buf.validate.field).string.tuuid = true, | ||
(buf.validate.field).ignore = IGNORE_IF_UNPOPULATED | ||
]; | ||
// The URL of the source control commit that is associated with the Commit. | ||
// | ||
// BSR users can navigate to this link to find source control information that is relevant to this Commit | ||
// (e.g. commit description, PR discussion, authors, approvers, etc.). | ||
string source_control_url = 7 [ | ||
(buf.validate.field).string.uri = true, | ||
(buf.validate.field).string.max_len = 255, | ||
(buf.validate.field).ignore = IGNORE_IF_UNPOPULATED | ||
]; | ||
// The plugin information as stored directly within the plugin. This is part of the Bufplugin API, | ||
// and can be returned from a plugin's GetPluginInfo implementation. | ||
buf.plugin.info.v1.PluginInfo plugin_info = 8; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,114 @@ | ||
// Copyright 2023-2024 Buf Technologies, Inc. | ||
// | ||
// 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. | ||
|
||
syntax = "proto3"; | ||
|
||
package buf.registry.plugin.v1; | ||
|
||
import "buf/registry/plugin/v1/commit.proto"; | ||
import "buf/registry/plugin/v1/digest.proto"; | ||
import "buf/registry/plugin/v1/resource.proto"; | ||
import "buf/validate/validate.proto"; | ||
|
||
option go_package = "buf.build/gen/go/bufbuild/registry/protocolbuffers/go/buf/registry/plugin/v1"; | ||
|
||
// Operate on Commits. | ||
service CommitService { | ||
// Get Commits. | ||
rpc GetCommits(GetCommitsRequest) returns (GetCommitsResponse) { | ||
option idempotency_level = NO_SIDE_EFFECTS; | ||
} | ||
// List Commits for a given Plugin, Label, or Commit. | ||
rpc ListCommits(ListCommitsRequest) returns (ListCommitsResponse) { | ||
option idempotency_level = NO_SIDE_EFFECTS; | ||
} | ||
} | ||
|
||
message GetCommitsRequest { | ||
// References to request a Commit for. | ||
// | ||
// See the documentation on ResourceRef for resource resolution details. | ||
// | ||
// Resolution is as follows: | ||
// - If a Plugin is referenced, the Commit of the default Label is returned. | ||
// - If a Label is referenced, the Commit of this Label is returned. | ||
// - If a Commit is referenced, this Commit is returned. | ||
repeated ResourceRef resource_refs = 1 [ | ||
(buf.validate.field).repeated.min_items = 1, | ||
(buf.validate.field).repeated.max_items = 250 | ||
]; | ||
// The DigestType to use for Digests returned on Commits. | ||
// | ||
// If this DigestType is not available, an error is returned. | ||
// Note that certain DigestTypes may be deprecated over time. | ||
// | ||
// If not set, the latest DigestType is used, currently p1. | ||
DigestType digest_type = 2 [(buf.validate.field).enum.defined_only = true]; | ||
} | ||
|
||
message GetCommitsResponse { | ||
// The found Commits in the same order as requested. | ||
repeated Commit commits = 1 [(buf.validate.field).repeated.min_items = 1]; | ||
} | ||
|
||
message ListCommitsRequest { | ||
// The list order. | ||
enum Order { | ||
ORDER_UNSPECIFIED = 0; | ||
// Order by create_time newest to oldest. | ||
ORDER_CREATE_TIME_DESC = 1; | ||
// Order by create_time oldest to newest. | ||
ORDER_CREATE_TIME_ASC = 2; | ||
} | ||
// The maximum number of items to return. | ||
// | ||
// The default value is 10. | ||
uint32 page_size = 1 [(buf.validate.field).uint32.lte = 250]; | ||
// The page to start from. | ||
// | ||
// If empty, the first page is returned. | ||
string page_token = 2 [(buf.validate.field).string.max_len = 4096]; | ||
// The reference to list Commits for. | ||
// | ||
// See the documentation on Ref for resource resolution details. | ||
// | ||
// Once the resource is resolved, the following Commits are listed (subject to any additional filters in the request): | ||
// - If a Plugin is referenced, all Commits for the Plugin are returned. | ||
// - If a Label is referenced, the Commit the Label points to is returned. | ||
// Use ListLabelHistory to get the history of Commits for a Label. | ||
// - If a Commit is referenced, this Commit is returned. | ||
ResourceRef resource_ref = 3 [(buf.validate.field).required = true]; | ||
// The order to return the Commits. | ||
// | ||
// If not specified, defaults to ORDER_CREATE_TIME_DESC. | ||
Order order = 4 [(buf.validate.field).enum.defined_only = true]; | ||
// The DigestType to use for Digests returned on Commits. | ||
// | ||
// If this DigestType is not available, an error is returned. | ||
// Note that certain DigestTypes may be deprecated over time. | ||
// | ||
// If not set, the latest DigestType is used, currently p1. | ||
DigestType digest_type = 5 [(buf.validate.field).enum.defined_only = true]; | ||
// Only return Commits with an id that contains this string using a case-insensitive comparison. | ||
string id_query = 6 [(buf.validate.field).string.max_len = 36]; | ||
} | ||
|
||
message ListCommitsResponse { | ||
// The next page token. | ||
// | ||
// If empty, there are no more pages. | ||
string next_page_token = 1 [(buf.validate.field).string.max_len = 4096]; | ||
// The listed Commits. | ||
repeated Commit commits = 2; | ||
} |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Extreme nit: I would sort these alphabetically, to match the lock file