Skip to content
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

feat (shield): add actions, namespaces and policies apis #69

Merged
merged 3 commits into from
Dec 2, 2021
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
269 changes: 269 additions & 0 deletions odpf/shield/v1/shield.proto
Original file line number Diff line number Diff line change
Expand Up @@ -267,6 +267,135 @@ service ShieldService {
};
}

// Actions
rpc ListActions(ListActionsRequest) returns (ListActionsResponse) {
option (google.api.http) = {
get: "/v1/actions"
};
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_operation) = {
tags: "Action";
summary: "Get all Actions";
};
}

rpc CreateAction(CreateActionRequest) returns (CreateActionResponse) {
option (google.api.http) = {
post: "/v1/actions",
body: "body"
};
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_operation) = {
tags: "Action";
summary: "Create Action";
};
}

rpc GetAction(GetActionRequest) returns (GetActionResponse) {
option (google.api.http) = {
get: "/v1/actions/{id}",
};
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_operation) = {
tags: "Action";
summary: "Get Action by ID";
};
}

rpc UpdateAction(UpdateActionRequest) returns (UpdateActionResponse) {
option (google.api.http) = {
put: "/v1/actions/{id}",
body: "body"
};
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_operation) = {
tags: "Action";
summary: "Update Action by ID";
};
}

// Namespaces
rpc ListNamespaces(ListNamespacesRequest) returns (ListNamespacesResponse) {
option (google.api.http) = {
get: "/v1/namespaces"
};
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_operation) = {
tags: "Namespace";
summary: "Get all Namespaces";
};
}

rpc CreateNamespace(CreateNamespaceRequest) returns (CreateNamespaceResponse) {
option (google.api.http) = {
post: "/v1/namespaces",
body: "body"
};
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_operation) = {
tags: "Namespace";
summary: "Create Namespace";
};
}

rpc GetNamespace(GetNamespaceRequest) returns (GetNamespaceResponse) {
option (google.api.http) = {
get: "/v1/namespaces/{id}",
};
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_operation) = {
tags: "Namespace";
summary: "Get Namespace by ID";
};
}

rpc UpdateNamespace(UpdateNamespaceRequest) returns (UpdateNamespaceResponse) {
option (google.api.http) = {
put: "/v1/namespaces/{id}",
body: "body"
};
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_operation) = {
tags: "Namespace";
summary: "Update Namespace by ID";
};
}

// Policies
rpc ListPolicies(ListPoliciesRequest) returns (ListPoliciesResponse) {
option (google.api.http) = {
get: "/v1/policies"
};
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_operation) = {
tags: "Policy";
summary: "Get all Policy";
};
}

rpc CreatePolicy(CreatePolicyRequest) returns (CreatePolicyResponse) {
option (google.api.http) = {
post: "/v1/policies",
body: "body"
};
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_operation) = {
tags: "Policy";
summary: "Create Policy";
};
}

rpc GetPolicy(GetPolicyRequest) returns (GetPolicyResponse) {
option (google.api.http) = {
get: "/v1/policies/{id}",
};
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_operation) = {
tags: "Policy";
summary: "Get Policy by ID";
};
}

rpc UpdatePolicy(UpdatePolicyRequest) returns (UpdatePolicyResponse) {
option (google.api.http) = {
put: "/v1/policies/{id}",
body: "body"
};
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_operation) = {
tags: "Policy";
summary: "Update Policy by ID";
};
}

}

message UserRequestBody {
Expand Down Expand Up @@ -536,3 +665,143 @@ message UpdateProjectRequest {
string id = 1;
ProjectRequestBody body = 2;
}

message Action {
string id = 1;
string name = 2 [(validate.rules).string.pattern = "^[A-Za-z0-9_-]+$"];
string namespace = 3;
krtkvrm marked this conversation as resolved.
Show resolved Hide resolved
google.protobuf.Timestamp created_at = 4;
google.protobuf.Timestamp updated_at = 5;
}

message Namespace {
string id = 1;
string name = 2 [(validate.rules).string.pattern = "^[A-Za-z0-9_-]+$"];
google.protobuf.Timestamp created_at = 6;
google.protobuf.Timestamp updated_at = 7;
}

message Policy {
string id = 1;
Role role = 2;
krtkvrm marked this conversation as resolved.
Show resolved Hide resolved
Action action = 3;
Namespace namespace = 4;
google.protobuf.Timestamp created_at = 5;
google.protobuf.Timestamp updated_at = 6;
}

message ActionRequestBody {
string id = 1;
string name = 2 [(validate.rules).string.pattern = "^[A-Za-z0-9_-]+$"];
string namespace_id = 3;
}

message NamespaceRequestBody {
string id = 1;
string name = 2 [(validate.rules).string.pattern = "^[A-Za-z0-9_-]+$"];
}

message PolicyRequestBody {
string role_id = 1;
string action_id = 2;
string namespace_id = 3;
}

message ListActionsRequest {

}

message ListActionsResponse {
repeated Action actions = 1;
}

message CreateActionRequest {
ActionRequestBody body = 1;
}

message CreateActionResponse {
Action action = 1;
}

message GetActionRequest {
string id = 1;
}

message GetActionResponse {
Action action = 1;
}

message UpdateActionRequest {
string id = 1;
ActionRequestBody body = 2;
}

message UpdateActionResponse {
Action action = 1;
}

message ListNamespacesRequest {

}

message ListNamespacesResponse {
repeated Namespace namespaces = 1;
}

message CreateNamespaceRequest {
NamespaceRequestBody body = 1;
}

message CreateNamespaceResponse {
Namespace namespace = 1;
}

message GetNamespaceRequest {
string id = 1;
}

message GetNamespaceResponse {
Namespace namespace = 1;
}

message UpdateNamespaceRequest {
string id = 1;
NamespaceRequestBody body = 2;
}

message UpdateNamespaceResponse {
Namespace namespace = 1;
}

message ListPoliciesRequest {

}

message ListPoliciesResponse {
repeated Policy policies = 1;
}

message CreatePolicyRequest {
PolicyRequestBody body = 1;
}

message CreatePolicyResponse {
repeated Policy policies = 1;
}

message GetPolicyRequest {
string id = 1;
}

message GetPolicyResponse {
Policy policy = 1;
}

message UpdatePolicyRequest {
string id = 1;
PolicyRequestBody body = 2;
}

message UpdatePolicyResponse {
repeated Policy policies = 1;
}