diff --git a/api/workflow.pb.go b/api/workflow.pb.go index c45701c..dac9c13 100644 --- a/api/workflow.pb.go +++ b/api/workflow.pb.go @@ -511,60 +511,62 @@ func init() { func init() { proto.RegisterFile("workflow.proto", fileDescriptor_892c7f566756b0be) } var fileDescriptor_892c7f566756b0be = []byte{ - // 835 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x96, 0xdf, 0x4e, 0x33, 0x45, - 0x14, 0xc0, 0x33, 0xf4, 0x2b, 0xd2, 0xf3, 0xa5, 0x1f, 0x78, 0x28, 0xa5, 0x56, 0x88, 0x38, 0x62, - 0x02, 0x42, 0xba, 0xa5, 0xfe, 0x09, 0xc1, 0x90, 0x48, 0x08, 0xe0, 0x45, 0x63, 0x4c, 0x15, 0x89, - 0x78, 0x21, 0x43, 0x3b, 0xd4, 0x8d, 0x65, 0x67, 0xdd, 0x99, 0x96, 0x98, 0xa6, 0x17, 0xea, 0x9d, - 0xb7, 0x7a, 0xe7, 0x8d, 0xf1, 0x29, 0xbc, 0xf6, 0x15, 0x78, 0x02, 0x13, 0x7d, 0x03, 0x1f, 0xc0, - 0xec, 0xec, 0xce, 0xb2, 0xbb, 0x5d, 0xa0, 0x15, 0xef, 0x3a, 0x73, 0xce, 0x9c, 0xf3, 0x3b, 0x7f, - 0xbb, 0xf0, 0xe2, 0x46, 0x78, 0x5f, 0x5f, 0xf5, 0xc4, 0x4d, 0xcd, 0xf5, 0x84, 0x12, 0x98, 0x63, - 0xae, 0x5d, 0x5d, 0xe9, 0x0a, 0xd1, 0xed, 0x71, 0x8b, 0xb9, 0xb6, 0xc5, 0x1c, 0x47, 0x28, 0xa6, - 0x6c, 0xe1, 0xc8, 0x40, 0xa5, 0xba, 0x6c, 0x9e, 0x7c, 0xa9, 0xf8, 0xb5, 0xdb, 0x63, 0x8a, 0x07, - 0x02, 0x7a, 0x01, 0x4b, 0x87, 0x1e, 0x67, 0x8a, 0x9f, 0x85, 0x0a, 0x2d, 0xfe, 0x4d, 0x9f, 0x4b, - 0x85, 0x2b, 0x50, 0x70, 0xd8, 0x35, 0x97, 0x2e, 0x6b, 0xf3, 0x0a, 0x59, 0x23, 0x1b, 0x85, 0xd6, - 0xdd, 0x05, 0x6e, 0xc2, 0x9c, 0xb1, 0x58, 0x99, 0x59, 0x23, 0x1b, 0xcf, 0x1b, 0xc5, 0x1a, 0x73, - 0xed, 0x5a, 0x64, 0x25, 0x12, 0xd3, 0x63, 0xc0, 0x13, 0xae, 0xa6, 0x33, 0x8f, 0xf0, 0xcc, 0x3f, - 0x68, 0xd3, 0x85, 0x96, 0xfe, 0x4d, 0x3f, 0x84, 0xd2, 0x19, 0x53, 0xed, 0xaf, 0x9e, 0x6e, 0xe9, - 0x47, 0x02, 0xe5, 0x18, 0x52, 0x53, 0x74, 0xe5, 0x7f, 0x36, 0x86, 0x15, 0x78, 0xc9, 0x15, 0x9d, - 0x8f, 0xfc, 0xeb, 0x9c, 0xbe, 0x36, 0x47, 0x5c, 0x87, 0x62, 0x5b, 0x38, 0x8a, 0xd9, 0x0e, 0xf7, - 0xb4, 0xfc, 0x99, 0x96, 0x27, 0x2f, 0xe9, 0xaf, 0x04, 0x4a, 0x4d, 0x5b, 0x46, 0x34, 0x13, 0xa2, - 0xd4, 0x61, 0xd1, 0x64, 0xf8, 0xd3, 0xb0, 0xa2, 0xa7, 0x76, 0x27, 0x24, 0xcb, 0x12, 0xe1, 0x2e, - 0x2c, 0xa7, 0xaf, 0x3f, 0xe3, 0x9e, 0xb4, 0x85, 0x13, 0x82, 0xdf, 0x27, 0xa6, 0xe7, 0xb0, 0x94, - 0x22, 0x94, 0xae, 0x70, 0x24, 0xc7, 0x12, 0xe4, 0xdb, 0xa2, 0xef, 0x28, 0x8d, 0x97, 0x6f, 0x05, - 0x07, 0xdc, 0x82, 0x82, 0xb1, 0x24, 0x2b, 0x33, 0x6b, 0xb9, 0xf1, 0xe6, 0xb8, 0x93, 0xd3, 0x75, - 0x98, 0x6b, 0x8a, 0xee, 0x91, 0xa3, 0xbc, 0x6f, 0xfd, 0x54, 0xfa, 0xb9, 0xe1, 0xa1, 0xc1, 0x42, - 0xcb, 0x1c, 0xe9, 0x9f, 0x04, 0xe6, 0xcc, 0x6b, 0x3f, 0x31, 0x6d, 0xdd, 0xb2, 0x9d, 0x03, 0xa3, - 0x78, 0x77, 0x81, 0x0b, 0x90, 0xeb, 0x47, 0x89, 0xf0, 0x7f, 0x46, 0x55, 0xcb, 0xc5, 0xaa, 0x56, - 0x86, 0x59, 0xa9, 0x98, 0xea, 0xcb, 0xb0, 0x28, 0xe1, 0x09, 0xdf, 0x03, 0x70, 0x99, 0xc7, 0xae, - 0xb9, 0xe2, 0x9e, 0xac, 0xe4, 0x35, 0x7c, 0x39, 0x01, 0xff, 0xb1, 0x11, 0xb7, 0x62, 0x9a, 0x78, - 0x00, 0x0b, 0xe9, 0xec, 0x55, 0x66, 0xf5, 0x5c, 0x2c, 0x25, 0x5e, 0x1b, 0x61, 0x6b, 0x4c, 0x9d, - 0xee, 0xc3, 0xcb, 0x63, 0x3e, 0x22, 0x76, 0x12, 0x63, 0x2f, 0x41, 0x7e, 0xc0, 0x7a, 0x7d, 0xd3, - 0x86, 0xc1, 0xa1, 0xf1, 0x4f, 0x11, 0xe6, 0xcd, 0xfb, 0x4f, 0xb8, 0x37, 0xb0, 0xdb, 0x1c, 0x3d, - 0x78, 0x91, 0x1c, 0x6e, 0xac, 0x6a, 0x9a, 0xcc, 0x89, 0xaf, 0x26, 0x8b, 0x44, 0xdf, 0xfd, 0xfe, - 0xf6, 0xaf, 0x9f, 0x66, 0x2c, 0xfa, 0x86, 0xbf, 0x52, 0xa4, 0x35, 0xd8, 0xb9, 0xe4, 0x8a, 0xed, - 0x58, 0xc3, 0xa8, 0x07, 0x47, 0x56, 0x54, 0xc6, 0xbd, 0x68, 0xdc, 0xd1, 0x86, 0xe7, 0xb1, 0xd9, - 0xc2, 0x65, 0x6d, 0x74, 0x7c, 0x01, 0xa4, 0xbd, 0x35, 0xb4, 0xb7, 0x6d, 0x7c, 0x6b, 0x02, 0x6f, - 0xc1, 0xed, 0x08, 0x25, 0x14, 0x13, 0x7d, 0x89, 0xaf, 0x68, 0x9b, 0x59, 0xd3, 0x54, 0xad, 0x66, - 0x89, 0x82, 0x36, 0xa6, 0x5b, 0xda, 0xf7, 0x9b, 0x38, 0x49, 0xa4, 0xd8, 0x87, 0x62, 0x62, 0x0d, - 0x85, 0x4e, 0xb3, 0x56, 0x53, 0x3a, 0xc6, 0x5d, 0xed, 0xa7, 0x81, 0xf5, 0xc9, 0x63, 0xb4, 0x6e, - 0x7c, 0xbb, 0x75, 0x82, 0xbf, 0x11, 0x98, 0x4f, 0xed, 0x2c, 0x7c, 0x35, 0x9d, 0xdb, 0xd8, 0x26, - 0x0b, 0x7d, 0x9b, 0xd9, 0xa2, 0x4c, 0xfb, 0xfe, 0x02, 0x3f, 0x9f, 0xc2, 0xb7, 0x2b, 0x3a, 0xd2, - 0x1a, 0x86, 0xeb, 0x6c, 0x64, 0x45, 0x7b, 0x4b, 0x5a, 0xc3, 0xc4, 0x0e, 0x1b, 0x59, 0x3d, 0xd1, - 0x95, 0x75, 0x82, 0xbf, 0x10, 0x28, 0x27, 0x7b, 0xcb, 0x74, 0x37, 0xd2, 0x8c, 0xc6, 0x8b, 0x86, - 0x21, 0x44, 0xce, 0x1e, 0x15, 0x7a, 0xac, 0xd1, 0x3f, 0xa0, 0xdb, 0x8f, 0xa3, 0x47, 0xff, 0x6e, - 0x72, 0x6f, 0x6c, 0xc0, 0xf0, 0x6f, 0x02, 0xab, 0xa7, 0x6e, 0x27, 0x03, 0x20, 0x5c, 0x74, 0xb8, - 0xa9, 0x01, 0x1e, 0xd4, 0x79, 0x84, 0xf5, 0x3b, 0xa2, 0x61, 0x87, 0xd5, 0xee, 0x34, 0xb0, 0xd6, - 0x30, 0x0d, 0x5b, 0xeb, 0xdb, 0x9d, 0x91, 0x35, 0x08, 0x7c, 0x66, 0xc9, 0x43, 0xd1, 0x28, 0x23, - 0xce, 0x3f, 0x08, 0xac, 0x66, 0x27, 0xda, 0xc4, 0xf9, 0x84, 0x62, 0x5c, 0xe9, 0xf8, 0x2e, 0x68, - 0xf3, 0xff, 0x8c, 0x2f, 0x23, 0x88, 0x5b, 0x02, 0x8b, 0xb1, 0xce, 0x8e, 0xee, 0x5f, 0x4b, 0xf7, - 0xfc, 0x84, 0xdc, 0x3f, 0x04, 0x85, 0x19, 0x61, 0x63, 0x3a, 0x70, 0x9f, 0xf3, 0xfc, 0x04, 0x8f, - 0xa6, 0x7f, 0x15, 0xab, 0x9e, 0x29, 0x16, 0xfe, 0x4e, 0x60, 0x25, 0xbe, 0x83, 0x52, 0x85, 0x91, - 0xb8, 0x31, 0xb6, 0xa6, 0xd2, 0x2a, 0x26, 0xce, 0xcd, 0x09, 0x34, 0xc3, 0xfd, 0x76, 0xa8, 0x43, - 0xdf, 0xc7, 0xf7, 0x9f, 0x10, 0x04, 0xfe, 0x4c, 0x92, 0x5f, 0x01, 0xc6, 0x9b, 0xc4, 0xd7, 0xef, - 0x25, 0x89, 0x60, 0xe9, 0x43, 0x2a, 0x21, 0xe5, 0x3b, 0x9a, 0xb2, 0x86, 0x53, 0x8d, 0xf9, 0xe5, - 0xac, 0xfe, 0x8c, 0x7d, 0xfb, 0xdf, 0x00, 0x00, 0x00, 0xff, 0xff, 0xaa, 0x6f, 0xd7, 0x25, 0x14, - 0x0b, 0x00, 0x00, + // 869 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x96, 0x4f, 0x6f, 0x1b, 0x45, + 0x14, 0xc0, 0x35, 0x71, 0x1d, 0xe2, 0x57, 0xb9, 0x29, 0xaf, 0x8e, 0x6d, 0x4c, 0x2a, 0xc2, 0x34, + 0x48, 0x49, 0x5b, 0x79, 0x5d, 0x53, 0x50, 0x15, 0x54, 0x89, 0xa8, 0x6a, 0xcb, 0xc1, 0x42, 0xc8, + 0x50, 0x2a, 0xca, 0x81, 0x4e, 0xec, 0x89, 0xb3, 0xc2, 0xd9, 0x59, 0x76, 0xc6, 0x8e, 0x90, 0xe5, + 0x03, 0x70, 0xe3, 0x0a, 0x12, 0x07, 0x2e, 0x11, 0x9f, 0x82, 0x33, 0x5f, 0x21, 0x9f, 0x00, 0x09, + 0xbe, 0x07, 0xda, 0xd9, 0x99, 0xcd, 0xee, 0x7a, 0x93, 0xd8, 0x09, 0x37, 0xcf, 0xbc, 0x37, 0xef, + 0xfd, 0xde, 0x5f, 0x2f, 0xdc, 0x38, 0x12, 0xc1, 0xb7, 0xfb, 0x43, 0x71, 0xd4, 0xf4, 0x03, 0xa1, + 0x04, 0x16, 0x98, 0xef, 0x36, 0xd6, 0x07, 0x42, 0x0c, 0x86, 0xdc, 0x61, 0xbe, 0xeb, 0x30, 0xcf, + 0x13, 0x8a, 0x29, 0x57, 0x78, 0x32, 0x52, 0x69, 0xd4, 0xec, 0x93, 0x6f, 0x14, 0x3f, 0xf4, 0x87, + 0x4c, 0xf1, 0x48, 0x40, 0x5f, 0xc3, 0xda, 0x93, 0x80, 0x33, 0xc5, 0x5f, 0x1a, 0x85, 0x2e, 0xff, + 0x6e, 0xc4, 0xa5, 0xc2, 0x75, 0x28, 0x79, 0xec, 0x90, 0x4b, 0x9f, 0xf5, 0x78, 0x9d, 0x6c, 0x90, + 0xad, 0x52, 0xf7, 0xf4, 0x02, 0xb7, 0x61, 0xc5, 0x5a, 0xac, 0x2f, 0x6d, 0x90, 0xad, 0xeb, 0xed, + 0x72, 0x93, 0xf9, 0x6e, 0x33, 0xb6, 0x12, 0x8b, 0xe9, 0x33, 0xc0, 0xe7, 0x5c, 0x2d, 0x66, 0x1e, + 0xe1, 0x5a, 0x78, 0xd0, 0xa6, 0x4b, 0x5d, 0xfd, 0x9b, 0x7e, 0x02, 0x95, 0x97, 0x4c, 0xf5, 0x0e, + 0xae, 0x6e, 0xe9, 0x67, 0x02, 0xd5, 0x04, 0x52, 0x47, 0x0c, 0xe4, 0xa5, 0x8d, 0x61, 0x1d, 0xde, + 0xf0, 0x45, 0xff, 0xd3, 0xf0, 0xba, 0xa0, 0xaf, 0xed, 0x11, 0x37, 0xa1, 0xdc, 0x13, 0x9e, 0x62, + 0xae, 0xc7, 0x03, 0x2d, 0xbf, 0xa6, 0xe5, 0xe9, 0x4b, 0x7a, 0x4c, 0xa0, 0xd2, 0x71, 0x65, 0x4c, + 0x33, 0x27, 0x4a, 0x0b, 0x6e, 0xd9, 0x0c, 0x7f, 0x61, 0x2a, 0xfa, 0xc2, 0xed, 0x1b, 0xb2, 0x3c, + 0x11, 0x3e, 0x82, 0x5a, 0xf6, 0xfa, 0x4b, 0x1e, 0x48, 0x57, 0x78, 0x06, 0xfc, 0x2c, 0x31, 0x7d, + 0x05, 0x6b, 0x19, 0x42, 0xe9, 0x0b, 0x4f, 0x72, 0xac, 0x40, 0xb1, 0x27, 0x46, 0x9e, 0xd2, 0x78, + 0xc5, 0x6e, 0x74, 0xc0, 0x7b, 0x50, 0xb2, 0x96, 0x64, 0x7d, 0x69, 0xa3, 0x30, 0xdb, 0x1c, 0xa7, + 0x72, 0xba, 0x09, 0x2b, 0x1d, 0x31, 0x78, 0xea, 0xa9, 0xe0, 0xfb, 0x30, 0x95, 0x61, 0x6e, 0xb8, + 0x31, 0x58, 0xea, 0xda, 0x23, 0xfd, 0x9b, 0xc0, 0x8a, 0x7d, 0x1d, 0x26, 0xa6, 0xa7, 0x5b, 0xb6, + 0xbf, 0x6b, 0x15, 0x4f, 0x2f, 0xf0, 0x26, 0x14, 0x46, 0x71, 0x22, 0xc2, 0x9f, 0x71, 0xd5, 0x0a, + 0x89, 0xaa, 0x55, 0x61, 0x59, 0x2a, 0xa6, 0x46, 0xd2, 0x14, 0xc5, 0x9c, 0xf0, 0x43, 0x00, 0x9f, + 0x05, 0xec, 0x90, 0x2b, 0x1e, 0xc8, 0x7a, 0x51, 0xc3, 0x57, 0x53, 0xf0, 0x9f, 0x59, 0x71, 0x37, + 0xa1, 0x89, 0xbb, 0x70, 0x33, 0x9b, 0xbd, 0xfa, 0xb2, 0x9e, 0x8b, 0xb5, 0xd4, 0x6b, 0x2b, 0xec, + 0xce, 0xa8, 0xd3, 0xc7, 0xf0, 0xe6, 0x8c, 0x8f, 0x98, 0x9d, 0x24, 0xd8, 0x2b, 0x50, 0x1c, 0xb3, + 0xe1, 0xc8, 0xb6, 0x61, 0x74, 0x68, 0xff, 0xb6, 0x0a, 0xab, 0xf6, 0xfd, 0xe7, 0x3c, 0x18, 0xbb, + 0x3d, 0x8e, 0x01, 0xdc, 0x48, 0x0f, 0x37, 0x36, 0x34, 0x4d, 0xee, 0xc4, 0x37, 0xd2, 0x45, 0xa2, + 0x1f, 0xfc, 0x78, 0xf2, 0xcf, 0x2f, 0x4b, 0x0e, 0xbd, 0x13, 0xae, 0x14, 0xe9, 0x8c, 0x1f, 0xec, + 0x71, 0xc5, 0x1e, 0x38, 0x93, 0xb8, 0x07, 0xa7, 0x4e, 0x5c, 0xc6, 0x9d, 0x78, 0xdc, 0xd1, 0x85, + 0xeb, 0x89, 0xd9, 0xc2, 0x9a, 0x36, 0x3a, 0xbb, 0x00, 0xb2, 0xde, 0xda, 0xda, 0xdb, 0x7d, 0xbc, + 0x3b, 0x87, 0xb7, 0xe8, 0x76, 0x8a, 0x12, 0xca, 0xa9, 0xbe, 0xc4, 0xb7, 0xb4, 0xcd, 0xbc, 0x69, + 0x6a, 0x34, 0xf2, 0x44, 0x51, 0x1b, 0xd3, 0x7b, 0xda, 0xf7, 0x7b, 0x38, 0x4f, 0xa4, 0x38, 0x82, + 0x72, 0x6a, 0x0d, 0x19, 0xa7, 0x79, 0xab, 0x29, 0x1b, 0xe3, 0x23, 0xed, 0xa7, 0x8d, 0xad, 0xf9, + 0x63, 0x74, 0x8e, 0x42, 0xbb, 0x2d, 0x82, 0x7f, 0x10, 0x58, 0xcd, 0xec, 0x2c, 0x7c, 0x3b, 0x9b, + 0xdb, 0xc4, 0x26, 0x33, 0xbe, 0xed, 0x6c, 0x51, 0xa6, 0x7d, 0x7f, 0x8d, 0x5f, 0x2d, 0xe0, 0xdb, + 0x17, 0x7d, 0xe9, 0x4c, 0xcc, 0x3a, 0x9b, 0x3a, 0xf1, 0xde, 0x92, 0xce, 0x24, 0xb5, 0xc3, 0xa6, + 0xce, 0x50, 0x0c, 0x64, 0x8b, 0xe0, 0xef, 0x04, 0xaa, 0xe9, 0xde, 0xb2, 0xdd, 0x8d, 0x34, 0xa7, + 0xf1, 0xe2, 0x61, 0x30, 0xc8, 0xf9, 0xa3, 0x42, 0x9f, 0x69, 0xf4, 0x8f, 0xe9, 0xfd, 0x8b, 0xd1, + 0xe3, 0x7f, 0x37, 0xb9, 0x33, 0x33, 0x60, 0xf8, 0x2f, 0x81, 0xdb, 0x2f, 0xfc, 0x7e, 0x0e, 0x80, + 0x59, 0x74, 0xb8, 0xad, 0x01, 0xce, 0xd5, 0xb9, 0x80, 0xf5, 0x07, 0xa2, 0x61, 0x27, 0x8d, 0xc1, + 0x22, 0xb0, 0xce, 0x24, 0x0b, 0xdb, 0x1c, 0xb9, 0xfd, 0xa9, 0x33, 0x8e, 0x7c, 0xe6, 0xc9, 0x8d, + 0x68, 0x9a, 0x13, 0xe7, 0x5f, 0x04, 0x6e, 0xe7, 0x27, 0xda, 0xc6, 0x79, 0x85, 0x62, 0xec, 0xeb, + 0xf8, 0x5e, 0xd3, 0xce, 0xff, 0x19, 0x5f, 0x4e, 0x10, 0x27, 0x04, 0x6e, 0x25, 0x3a, 0x3b, 0xbe, + 0x7f, 0x27, 0xdb, 0xf3, 0x73, 0x72, 0xff, 0x14, 0x15, 0x66, 0x8a, 0xed, 0xc5, 0xc0, 0x43, 0xce, + 0x57, 0xcf, 0xf1, 0xe9, 0xe2, 0xaf, 0x12, 0xd5, 0xb3, 0xc5, 0xc2, 0x3f, 0x09, 0xac, 0x27, 0x77, + 0x50, 0xa6, 0x30, 0x12, 0xb7, 0x66, 0xd6, 0x54, 0x56, 0xc5, 0xc6, 0xb9, 0x3d, 0x87, 0xa6, 0xd9, + 0x6f, 0x4f, 0x74, 0xe8, 0x8f, 0xf1, 0xa3, 0x2b, 0x04, 0x81, 0xbf, 0x92, 0xf4, 0x57, 0x80, 0xf5, + 0x26, 0xf1, 0xdd, 0x33, 0x49, 0x62, 0x58, 0x7a, 0x9e, 0x8a, 0xa1, 0x7c, 0xa8, 0x29, 0x9b, 0xb8, + 0xd0, 0x98, 0xe3, 0x31, 0x81, 0xda, 0x6e, 0xd0, 0x3b, 0x70, 0xc7, 0xb3, 0x3b, 0xe7, 0x8e, 0xf6, + 0x7a, 0x86, 0xd4, 0xa2, 0x6d, 0x9e, 0xaf, 0x64, 0xe0, 0x76, 0x34, 0xdc, 0xc3, 0xbb, 0x97, 0xe8, + 0x9e, 0xbd, 0x65, 0xfd, 0xa5, 0xfd, 0xfe, 0x7f, 0x01, 0x00, 0x00, 0xff, 0xff, 0x85, 0x98, 0x83, + 0x4b, 0xb7, 0x0b, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -591,6 +593,7 @@ type WorkflowServiceClient interface { GetWorkflowTemplate(ctx context.Context, in *GetWorkflowTemplateRequest, opts ...grpc.CallOption) (*WorkflowTemplate, error) ListWorkflowTemplateVersions(ctx context.Context, in *ListWorkflowTemplateVersionsRequest, opts ...grpc.CallOption) (*ListWorkflowTemplateVersionsResponse, error) ListWorkflowTemplates(ctx context.Context, in *ListWorkflowTemplatesRequest, opts ...grpc.CallOption) (*ListWorkflowTemplatesResponse, error) + ArchiveWorkflowTemplate(ctx context.Context, in *ArchiveWorkflowTemplateRequest, opts ...grpc.CallOption) (*ArchiveWorkflowTemplateResponse, error) } type workflowServiceClient struct { @@ -746,6 +749,15 @@ func (c *workflowServiceClient) ListWorkflowTemplates(ctx context.Context, in *L return out, nil } +func (c *workflowServiceClient) ArchiveWorkflowTemplate(ctx context.Context, in *ArchiveWorkflowTemplateRequest, opts ...grpc.CallOption) (*ArchiveWorkflowTemplateResponse, error) { + out := new(ArchiveWorkflowTemplateResponse) + err := c.cc.Invoke(ctx, "/api.WorkflowService/ArchiveWorkflowTemplate", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + // WorkflowServiceServer is the server API for WorkflowService service. type WorkflowServiceServer interface { // Creates a Workflow @@ -760,6 +772,7 @@ type WorkflowServiceServer interface { GetWorkflowTemplate(context.Context, *GetWorkflowTemplateRequest) (*WorkflowTemplate, error) ListWorkflowTemplateVersions(context.Context, *ListWorkflowTemplateVersionsRequest) (*ListWorkflowTemplateVersionsResponse, error) ListWorkflowTemplates(context.Context, *ListWorkflowTemplatesRequest) (*ListWorkflowTemplatesResponse, error) + ArchiveWorkflowTemplate(context.Context, *ArchiveWorkflowTemplateRequest) (*ArchiveWorkflowTemplateResponse, error) } // UnimplementedWorkflowServiceServer can be embedded to have forward compatible implementations. @@ -799,6 +812,9 @@ func (*UnimplementedWorkflowServiceServer) ListWorkflowTemplateVersions(ctx cont func (*UnimplementedWorkflowServiceServer) ListWorkflowTemplates(ctx context.Context, req *ListWorkflowTemplatesRequest) (*ListWorkflowTemplatesResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method ListWorkflowTemplates not implemented") } +func (*UnimplementedWorkflowServiceServer) ArchiveWorkflowTemplate(ctx context.Context, req *ArchiveWorkflowTemplateRequest) (*ArchiveWorkflowTemplateResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method ArchiveWorkflowTemplate not implemented") +} func RegisterWorkflowServiceServer(s *grpc.Server, srv WorkflowServiceServer) { s.RegisterService(&_WorkflowService_serviceDesc, srv) @@ -1008,6 +1024,24 @@ func _WorkflowService_ListWorkflowTemplates_Handler(srv interface{}, ctx context return interceptor(ctx, in, info, handler) } +func _WorkflowService_ArchiveWorkflowTemplate_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(ArchiveWorkflowTemplateRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(WorkflowServiceServer).ArchiveWorkflowTemplate(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/api.WorkflowService/ArchiveWorkflowTemplate", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(WorkflowServiceServer).ArchiveWorkflowTemplate(ctx, req.(*ArchiveWorkflowTemplateRequest)) + } + return interceptor(ctx, in, info, handler) +} + var _WorkflowService_serviceDesc = grpc.ServiceDesc{ ServiceName: "api.WorkflowService", HandlerType: (*WorkflowServiceServer)(nil), @@ -1048,6 +1082,10 @@ var _WorkflowService_serviceDesc = grpc.ServiceDesc{ MethodName: "ListWorkflowTemplates", Handler: _WorkflowService_ListWorkflowTemplates_Handler, }, + { + MethodName: "ArchiveWorkflowTemplate", + Handler: _WorkflowService_ArchiveWorkflowTemplate_Handler, + }, }, Streams: []grpc.StreamDesc{ { diff --git a/api/workflow.pb.gw.go b/api/workflow.pb.gw.go index 7fbddaa..638ecb0 100644 --- a/api/workflow.pb.gw.go +++ b/api/workflow.pb.gw.go @@ -955,6 +955,82 @@ func local_request_WorkflowService_ListWorkflowTemplates_0(ctx context.Context, } +func request_WorkflowService_ArchiveWorkflowTemplate_0(ctx context.Context, marshaler runtime.Marshaler, client WorkflowServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq ArchiveWorkflowTemplateRequest + var metadata runtime.ServerMetadata + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["uid"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "uid") + } + + protoReq.Uid, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "uid", err) + } + + msg, err := client.ArchiveWorkflowTemplate(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_WorkflowService_ArchiveWorkflowTemplate_0(ctx context.Context, marshaler runtime.Marshaler, server WorkflowServiceServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq ArchiveWorkflowTemplateRequest + var metadata runtime.ServerMetadata + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["namespace"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "namespace") + } + + protoReq.Namespace, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "namespace", err) + } + + val, ok = pathParams["uid"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "uid") + } + + protoReq.Uid, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "uid", err) + } + + msg, err := server.ArchiveWorkflowTemplate(ctx, &protoReq) + return msg, metadata, err + +} + // RegisterWorkflowServiceHandlerServer registers the http handlers for service WorkflowService to "mux". // UnaryRPC :call WorkflowServiceServer directly. // StreamingRPC :currently unsupported pending https://github.com/grpc/grpc-go/issues/906. @@ -1174,6 +1250,26 @@ func RegisterWorkflowServiceHandlerServer(ctx context.Context, mux *runtime.Serv }) + mux.Handle("DELETE", pattern_WorkflowService_ArchiveWorkflowTemplate_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_WorkflowService_ArchiveWorkflowTemplate_0(rctx, inboundMarshaler, server, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_WorkflowService_ArchiveWorkflowTemplate_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + return nil } @@ -1455,6 +1551,26 @@ func RegisterWorkflowServiceHandlerClient(ctx context.Context, mux *runtime.Serv }) + mux.Handle("DELETE", pattern_WorkflowService_ArchiveWorkflowTemplate_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_WorkflowService_ArchiveWorkflowTemplate_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_WorkflowService_ArchiveWorkflowTemplate_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + return nil } @@ -1482,6 +1598,8 @@ var ( pattern_WorkflowService_ListWorkflowTemplateVersions_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 1, 0, 4, 1, 5, 2, 2, 3, 1, 0, 4, 1, 5, 4, 2, 5}, []string{"apis", "v1beta1", "namespace", "workflow_templates", "uid", "versions"}, "", runtime.AssumeColonVerbOpt(true))) pattern_WorkflowService_ListWorkflowTemplates_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 1, 0, 4, 1, 5, 2, 2, 3}, []string{"apis", "v1beta1", "namespace", "workflow_templates"}, "", runtime.AssumeColonVerbOpt(true))) + + pattern_WorkflowService_ArchiveWorkflowTemplate_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 1, 0, 4, 1, 5, 2, 2, 3, 1, 0, 4, 1, 5, 4}, []string{"apis", "v1beta1", "namespace", "workflow_templates", "uid"}, "", runtime.AssumeColonVerbOpt(true))) ) var ( @@ -1508,4 +1626,6 @@ var ( forward_WorkflowService_ListWorkflowTemplateVersions_0 = runtime.ForwardResponseMessage forward_WorkflowService_ListWorkflowTemplates_0 = runtime.ForwardResponseMessage + + forward_WorkflowService_ArchiveWorkflowTemplate_0 = runtime.ForwardResponseMessage ) diff --git a/api/workflow.proto b/api/workflow.proto index 3f23a9a..53e6466 100644 --- a/api/workflow.proto +++ b/api/workflow.proto @@ -79,6 +79,12 @@ service WorkflowService { get: "/apis/v1beta1/{namespace}/workflow_templates" }; } + + rpc ArchiveWorkflowTemplate (ArchiveWorkflowTemplateRequest) returns (ArchiveWorkflowTemplateResponse) { + option (google.api.http) = { + delete: "/apis/v1beta1/{namespace}/workflow_templates/{uid}" + }; + } } message CreateWorkflowRequest { diff --git a/api/workflow.swagger.json b/api/workflow.swagger.json index 7da7799..d5005f5 100644 --- a/api/workflow.swagger.json +++ b/api/workflow.swagger.json @@ -100,6 +100,34 @@ "tags": [ "WorkflowService" ] + }, + "delete": { + "operationId": "ArchiveWorkflowTemplate", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/apiArchiveWorkflowTemplateResponse" + } + } + }, + "parameters": [ + { + "name": "namespace", + "in": "path", + "required": true, + "type": "string" + }, + { + "name": "uid", + "in": "path", + "required": true, + "type": "string" + } + ], + "tags": [ + "WorkflowService" + ] } }, "/apis/v1beta1/{namespace}/workflow_templates/{uid}/versions": { @@ -423,6 +451,14 @@ } }, "definitions": { + "apiArchiveWorkflowTemplateResponse": { + "type": "object", + "properties": { + "workflowTemplate": { + "$ref": "#/definitions/apiWorkflowTemplate" + } + } + }, "apiListWorkflowTemplateVersionsResponse": { "type": "object", "properties": { @@ -535,6 +571,10 @@ "isLatest": { "type": "boolean", "format": "boolean" + }, + "isArchived": { + "type": "boolean", + "format": "boolean" } } }, diff --git a/api/workflow_template.pb.go b/api/workflow_template.pb.go index 029889e..fe5dc75 100644 --- a/api/workflow_template.pb.go +++ b/api/workflow_template.pb.go @@ -349,6 +349,92 @@ func (m *ListWorkflowTemplatesResponse) GetWorkflowTemplates() []*WorkflowTempla return nil } +type ArchiveWorkflowTemplateRequest struct { + Namespace string `protobuf:"bytes,1,opt,name=namespace,proto3" json:"namespace,omitempty"` + Uid string `protobuf:"bytes,2,opt,name=uid,proto3" json:"uid,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *ArchiveWorkflowTemplateRequest) Reset() { *m = ArchiveWorkflowTemplateRequest{} } +func (m *ArchiveWorkflowTemplateRequest) String() string { return proto.CompactTextString(m) } +func (*ArchiveWorkflowTemplateRequest) ProtoMessage() {} +func (*ArchiveWorkflowTemplateRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_b9a07547748a96e8, []int{7} +} + +func (m *ArchiveWorkflowTemplateRequest) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_ArchiveWorkflowTemplateRequest.Unmarshal(m, b) +} +func (m *ArchiveWorkflowTemplateRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_ArchiveWorkflowTemplateRequest.Marshal(b, m, deterministic) +} +func (m *ArchiveWorkflowTemplateRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_ArchiveWorkflowTemplateRequest.Merge(m, src) +} +func (m *ArchiveWorkflowTemplateRequest) XXX_Size() int { + return xxx_messageInfo_ArchiveWorkflowTemplateRequest.Size(m) +} +func (m *ArchiveWorkflowTemplateRequest) XXX_DiscardUnknown() { + xxx_messageInfo_ArchiveWorkflowTemplateRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_ArchiveWorkflowTemplateRequest proto.InternalMessageInfo + +func (m *ArchiveWorkflowTemplateRequest) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +func (m *ArchiveWorkflowTemplateRequest) GetUid() string { + if m != nil { + return m.Uid + } + return "" +} + +type ArchiveWorkflowTemplateResponse struct { + WorkflowTemplate *WorkflowTemplate `protobuf:"bytes,1,opt,name=workflowTemplate,proto3" json:"workflowTemplate,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *ArchiveWorkflowTemplateResponse) Reset() { *m = ArchiveWorkflowTemplateResponse{} } +func (m *ArchiveWorkflowTemplateResponse) String() string { return proto.CompactTextString(m) } +func (*ArchiveWorkflowTemplateResponse) ProtoMessage() {} +func (*ArchiveWorkflowTemplateResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_b9a07547748a96e8, []int{8} +} + +func (m *ArchiveWorkflowTemplateResponse) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_ArchiveWorkflowTemplateResponse.Unmarshal(m, b) +} +func (m *ArchiveWorkflowTemplateResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_ArchiveWorkflowTemplateResponse.Marshal(b, m, deterministic) +} +func (m *ArchiveWorkflowTemplateResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_ArchiveWorkflowTemplateResponse.Merge(m, src) +} +func (m *ArchiveWorkflowTemplateResponse) XXX_Size() int { + return xxx_messageInfo_ArchiveWorkflowTemplateResponse.Size(m) +} +func (m *ArchiveWorkflowTemplateResponse) XXX_DiscardUnknown() { + xxx_messageInfo_ArchiveWorkflowTemplateResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_ArchiveWorkflowTemplateResponse proto.InternalMessageInfo + +func (m *ArchiveWorkflowTemplateResponse) GetWorkflowTemplate() *WorkflowTemplate { + if m != nil { + return m.WorkflowTemplate + } + return nil +} + type WorkflowTemplate struct { CreatedAt string `protobuf:"bytes,1,opt,name=createdAt,proto3" json:"createdAt,omitempty"` Uid string `protobuf:"bytes,2,opt,name=uid,proto3" json:"uid,omitempty"` @@ -356,6 +442,7 @@ type WorkflowTemplate struct { Version int32 `protobuf:"varint,4,opt,name=version,proto3" json:"version,omitempty"` Manifest string `protobuf:"bytes,5,opt,name=manifest,proto3" json:"manifest,omitempty"` IsLatest bool `protobuf:"varint,6,opt,name=isLatest,proto3" json:"isLatest,omitempty"` + IsArchived bool `protobuf:"varint,7,opt,name=isArchived,proto3" json:"isArchived,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` @@ -365,7 +452,7 @@ func (m *WorkflowTemplate) Reset() { *m = WorkflowTemplate{} } func (m *WorkflowTemplate) String() string { return proto.CompactTextString(m) } func (*WorkflowTemplate) ProtoMessage() {} func (*WorkflowTemplate) Descriptor() ([]byte, []int) { - return fileDescriptor_b9a07547748a96e8, []int{7} + return fileDescriptor_b9a07547748a96e8, []int{9} } func (m *WorkflowTemplate) XXX_Unmarshal(b []byte) error { @@ -428,6 +515,13 @@ func (m *WorkflowTemplate) GetIsLatest() bool { return false } +func (m *WorkflowTemplate) GetIsArchived() bool { + if m != nil { + return m.IsArchived + } + return false +} + func init() { proto.RegisterType((*CreateWorkflowTemplateRequest)(nil), "api.CreateWorkflowTemplateRequest") proto.RegisterType((*UpdateWorkflowTemplateVersionRequest)(nil), "api.UpdateWorkflowTemplateVersionRequest") @@ -436,32 +530,36 @@ func init() { proto.RegisterType((*ListWorkflowTemplateVersionsResponse)(nil), "api.ListWorkflowTemplateVersionsResponse") proto.RegisterType((*ListWorkflowTemplatesRequest)(nil), "api.ListWorkflowTemplatesRequest") proto.RegisterType((*ListWorkflowTemplatesResponse)(nil), "api.ListWorkflowTemplatesResponse") + proto.RegisterType((*ArchiveWorkflowTemplateRequest)(nil), "api.ArchiveWorkflowTemplateRequest") + proto.RegisterType((*ArchiveWorkflowTemplateResponse)(nil), "api.ArchiveWorkflowTemplateResponse") proto.RegisterType((*WorkflowTemplate)(nil), "api.WorkflowTemplate") } func init() { proto.RegisterFile("workflow_template.proto", fileDescriptor_b9a07547748a96e8) } var fileDescriptor_b9a07547748a96e8 = []byte{ - // 330 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x53, 0xbf, 0x4f, 0x02, 0x31, - 0x14, 0x4e, 0x39, 0x0e, 0xb9, 0xe7, 0x82, 0x8d, 0xc6, 0x86, 0x40, 0x72, 0xa9, 0x0c, 0x37, 0x31, - 0xe8, 0xea, 0x42, 0x18, 0x5c, 0x98, 0x1a, 0xd1, 0xd1, 0x54, 0x78, 0x24, 0x8d, 0x70, 0xad, 0xd7, - 0x22, 0x89, 0x93, 0x4e, 0xfe, 0x2b, 0xfe, 0x99, 0xe6, 0xca, 0x0f, 0x15, 0xee, 0x8c, 0x21, 0xd1, - 0xad, 0x5f, 0xfb, 0xbd, 0xd7, 0xef, 0x7b, 0x3f, 0xe0, 0x74, 0xa1, 0xb3, 0x87, 0xc9, 0x54, 0x2f, - 0xee, 0x1c, 0xce, 0xcc, 0x54, 0x3a, 0xec, 0x9a, 0x4c, 0x3b, 0x4d, 0x03, 0x69, 0x14, 0x7f, 0x21, - 0xd0, 0xee, 0x67, 0x28, 0x1d, 0xde, 0xae, 0x68, 0xd7, 0x2b, 0x96, 0xc0, 0xc7, 0x39, 0x5a, 0x47, - 0x5b, 0x10, 0xa5, 0x72, 0x86, 0xd6, 0xc8, 0x11, 0x32, 0x12, 0x93, 0x24, 0x12, 0x9f, 0x17, 0xb4, - 0x07, 0x8d, 0xc5, 0x56, 0x20, 0xab, 0xc4, 0x24, 0x39, 0x3c, 0x3f, 0xe9, 0x4a, 0xa3, 0xba, 0x3b, - 0x59, 0x77, 0xe8, 0xfc, 0x8d, 0x40, 0x67, 0x68, 0xc6, 0x05, 0x12, 0x6e, 0x30, 0xb3, 0x4a, 0xa7, - 0xff, 0xa6, 0x64, 0x02, 0xcd, 0x2b, 0x74, 0xfb, 0x15, 0xa2, 0x01, 0xc1, 0x5c, 0x8d, 0xfd, 0x8f, - 0x91, 0xc8, 0x8f, 0x94, 0xc1, 0xc1, 0xd3, 0xd2, 0x00, 0x0b, 0x62, 0x92, 0x84, 0x62, 0x0d, 0xf9, - 0x10, 0xce, 0x06, 0xca, 0xba, 0x12, 0xbb, 0x76, 0xcf, 0x0f, 0xf9, 0x2b, 0x81, 0xce, 0xcf, 0x79, - 0xad, 0xd1, 0xa9, 0x45, 0x7a, 0x0c, 0xe1, 0x48, 0xcf, 0x53, 0xe7, 0x93, 0x86, 0x62, 0x09, 0x68, - 0x1f, 0x8e, 0xb6, 0x2b, 0x62, 0x59, 0x25, 0x0e, 0xca, 0x2b, 0xb8, 0xcb, 0xe7, 0x97, 0xd0, 0x2a, - 0x92, 0xf0, 0x3b, 0x4f, 0xfc, 0x19, 0xda, 0x25, 0xd1, 0x7f, 0xaf, 0xfc, 0x9d, 0x40, 0x63, 0x9b, - 0x97, 0xcb, 0x1d, 0xf9, 0xed, 0x18, 0xf7, 0xdc, 0x5a, 0xee, 0xe6, 0xa2, 0xa0, 0xe7, 0x14, 0xaa, - 0xb9, 0x1b, 0xdf, 0xf0, 0x48, 0xf8, 0xf3, 0xd7, 0x39, 0xa8, 0x7e, 0x9b, 0x03, 0xda, 0x84, 0xfa, - 0x4c, 0xa6, 0x6a, 0x82, 0xd6, 0xb1, 0xd0, 0x47, 0x6c, 0x70, 0xfe, 0xa6, 0xec, 0x20, 0x57, 0xe6, - 0x58, 0x2d, 0x26, 0x49, 0x5d, 0x6c, 0xf0, 0x7d, 0xcd, 0x2f, 0xf0, 0xc5, 0x47, 0x00, 0x00, 0x00, - 0xff, 0xff, 0xa0, 0x4d, 0xfe, 0x9d, 0xdb, 0x03, 0x00, 0x00, + // 368 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x54, 0x41, 0x4f, 0xc2, 0x30, + 0x14, 0x4e, 0x19, 0x03, 0xf6, 0xbc, 0x60, 0xa3, 0xb1, 0x21, 0x80, 0xcb, 0xe4, 0xb0, 0x13, 0x07, + 0xbd, 0x7a, 0x21, 0x1c, 0xbc, 0x70, 0x30, 0x8b, 0xe8, 0xd1, 0xd4, 0xad, 0xc4, 0x46, 0x58, 0xeb, + 0x5a, 0x20, 0xf1, 0xa4, 0x27, 0xff, 0x9a, 0x3f, 0xcb, 0xac, 0x0c, 0x44, 0xd8, 0x8c, 0x12, 0xf5, + 0xd6, 0xf7, 0xfa, 0xbd, 0xd7, 0xef, 0xfb, 0xf2, 0x6d, 0x70, 0x34, 0x17, 0xc9, 0xc3, 0x68, 0x2c, + 0xe6, 0xb7, 0x9a, 0x4d, 0xe4, 0x98, 0x6a, 0xd6, 0x95, 0x89, 0xd0, 0x02, 0x5b, 0x54, 0x72, 0xef, + 0x19, 0x41, 0xab, 0x9f, 0x30, 0xaa, 0xd9, 0x4d, 0x06, 0xbb, 0xca, 0x50, 0x01, 0x7b, 0x9c, 0x32, + 0xa5, 0x71, 0x13, 0x9c, 0x98, 0x4e, 0x98, 0x92, 0x34, 0x64, 0x04, 0xb9, 0xc8, 0x77, 0x82, 0x8f, + 0x06, 0xee, 0x41, 0x7d, 0xbe, 0x31, 0x48, 0x4a, 0x2e, 0xf2, 0xf7, 0x4e, 0x0f, 0xbb, 0x54, 0xf2, + 0xee, 0xd6, 0xd6, 0x2d, 0xb8, 0xf7, 0x8a, 0xa0, 0x33, 0x94, 0x51, 0x0e, 0x85, 0x6b, 0x96, 0x28, + 0x2e, 0xe2, 0x7f, 0x63, 0x32, 0x82, 0xc6, 0x05, 0xd3, 0xbb, 0x19, 0x51, 0x07, 0x6b, 0xca, 0x23, + 0xf3, 0xa2, 0x13, 0xa4, 0x47, 0x4c, 0xa0, 0x3a, 0x5b, 0x08, 0x20, 0x96, 0x8b, 0x7c, 0x3b, 0x58, + 0x96, 0xde, 0x10, 0x4e, 0x06, 0x5c, 0xe9, 0x02, 0xb9, 0x6a, 0xc7, 0x07, 0xbd, 0x17, 0x04, 0x9d, + 0xaf, 0xf7, 0x2a, 0x29, 0x62, 0xc5, 0xf0, 0x01, 0xd8, 0xa1, 0x98, 0xc6, 0xda, 0x2c, 0xb5, 0x83, + 0x45, 0x81, 0xfb, 0xb0, 0xbf, 0xe9, 0x88, 0x22, 0x25, 0xd7, 0x2a, 0x76, 0x70, 0x1b, 0xef, 0x9d, + 0x43, 0x33, 0x8f, 0xc2, 0xf7, 0x34, 0x79, 0x4f, 0xd0, 0x2a, 0x98, 0xfe, 0x7b, 0xe6, 0x97, 0xd0, + 0xee, 0x25, 0xe1, 0x3d, 0x9f, 0xb1, 0x5f, 0x0a, 0x80, 0x17, 0xc1, 0x71, 0xe1, 0xc6, 0x4c, 0x4f, + 0x5e, 0x68, 0xd1, 0xcf, 0x42, 0xfb, 0x86, 0xa0, 0xbe, 0x09, 0x4b, 0xa9, 0x86, 0xe6, 0xab, 0x8e, + 0x7a, 0x7a, 0x49, 0x75, 0xd5, 0xc8, 0xc9, 0x2a, 0x86, 0x72, 0xaa, 0xc4, 0x04, 0xd5, 0x09, 0xcc, + 0x79, 0x3d, 0xbf, 0xe5, 0x4f, 0xf9, 0xc5, 0x0d, 0xa8, 0x4d, 0x68, 0xcc, 0x47, 0x4c, 0x69, 0x62, + 0x9b, 0x89, 0x55, 0x9d, 0xde, 0x71, 0x35, 0x48, 0x1d, 0xd5, 0xa4, 0xe2, 0x22, 0xbf, 0x16, 0xac, + 0x6a, 0xdc, 0x06, 0xe0, 0x2a, 0xb3, 0x24, 0x22, 0x55, 0x73, 0xbb, 0xd6, 0xb9, 0xab, 0x98, 0x1f, + 0xd3, 0xd9, 0x7b, 0x00, 0x00, 0x00, 0xff, 0xff, 0x0e, 0xb1, 0x9a, 0x5e, 0xb3, 0x04, 0x00, 0x00, } diff --git a/api/workflow_template.proto b/api/workflow_template.proto index b60fa5f..d0094e3 100644 --- a/api/workflow_template.proto +++ b/api/workflow_template.proto @@ -37,6 +37,15 @@ message ListWorkflowTemplatesResponse { repeated WorkflowTemplate workflowTemplates = 2; } +message ArchiveWorkflowTemplateRequest { + string namespace = 1; + string uid = 2; +} + +message ArchiveWorkflowTemplateResponse { + WorkflowTemplate workflowTemplate = 1; +} + message WorkflowTemplate { string createdAt = 1; string uid = 2; @@ -44,4 +53,5 @@ message WorkflowTemplate { int32 version = 4; string manifest = 5; bool isLatest = 6; + bool isArchived = 7; } \ No newline at end of file diff --git a/db/20200204103708_AddIsArchivedToWorkflowTemplates.sql b/db/20200204103708_AddIsArchivedToWorkflowTemplates.sql new file mode 100644 index 0000000..91dc253 --- /dev/null +++ b/db/20200204103708_AddIsArchivedToWorkflowTemplates.sql @@ -0,0 +1,5 @@ +-- +goose Up +ALTER TABLE workflow_templates ADD COLUMN is_archived boolean DEFAULT false; + +-- +goose Down +ALTER TABLE workflow_templates DROP COLUMN is_archived; diff --git a/manager/workflow_manager.go b/manager/workflow_manager.go index cd4207d..77a2b88 100644 --- a/manager/workflow_manager.go +++ b/manager/workflow_manager.go @@ -346,3 +346,28 @@ func (r *ResourceManager) ListWorkflowTemplates(namespace string) (workflowTempl return } + +func (r *ResourceManager) ArchiveWorkflowTemplate(namespace, uid string) (archived bool, err error) { + allowed, err := r.kubeClient.IsAuthorized(namespace, "delete", "argoproj.io", "workflow", "") + if err != nil { + return false, util.NewUserError(codes.Unknown, "Unknown error.") + } + if !allowed { + return false, util.NewUserError(codes.PermissionDenied, "Permission denied.") + } + + workflowTemplate, err := r.workflowRepository.GetWorkflowTemplate(namespace, uid, 0) + if err != nil { + return false, util.NewUserError(codes.Unknown, "Unknown error.") + } + if err == nil && workflowTemplate == nil { + return false, util.NewUserError(codes.NotFound, "Workflow template not found.") + } + + archived, err = r.workflowRepository.ArchiveWorkflowTemplate(namespace, uid) + if !archived || err != nil { + return false, util.NewUserError(codes.Unknown, "Unknown error.") + } + + return +} diff --git a/model/workflow_template.go b/model/workflow_template.go index 79b7665..8b9cffd 100644 --- a/model/workflow_template.go +++ b/model/workflow_template.go @@ -6,13 +6,14 @@ import ( ) type WorkflowTemplate struct { - ID uint64 - CreatedAt time.Time `db:"created_at"` - UID string - Name string - Manifest string - Version int32 - IsLatest bool `db:"is_latest"` + ID uint64 + CreatedAt time.Time `db:"created_at"` + UID string + Name string + Manifest string + Version int32 + IsLatest bool `db:"is_latest"` + IsArchived bool `db:"is_archived"` } func (wt *WorkflowTemplate) GetManifestBytes() []byte { diff --git a/repository/workflow_repository.go b/repository/workflow_repository.go index 9451653..236842e 100644 --- a/repository/workflow_repository.go +++ b/repository/workflow_repository.go @@ -131,7 +131,7 @@ func (r *WorkflowRepository) UpdateWorkflowTemplateVersion(workflowTemplate *mod } func (r *WorkflowRepository) workflowTemplatesSelectBuilder(namespace string) sq.SelectBuilder { - sb := r.sb.Select("wt.id", "wt.created_at", "wt.uid", "wt.name", "wtv.version", "wtv.is_latest"). + sb := r.sb.Select("wt.id", "wt.created_at", "wt.uid", "wt.name", "wt.is_archived", "wtv.version", "wtv.is_latest"). From("workflow_template_versions wtv"). Join("workflow_templates wt ON wt.id = wtv.workflow_template_id"). Where(sq.Eq{ @@ -184,6 +184,9 @@ func (r *WorkflowRepository) ListWorkflowTemplates(namespace string) (workflowTe query, args, err := r.workflowTemplatesSelectBuilder(namespace). Options("DISTINCT ON (wt.id) wt.id,"). + Where(sq.Eq{ + "wt.is_archived": false, + }). OrderBy("wt.id desc").ToSql() if err != nil { return @@ -193,3 +196,23 @@ func (r *WorkflowRepository) ListWorkflowTemplates(namespace string) (workflowTe return } + +func (r *WorkflowRepository) ArchiveWorkflowTemplate(namespace, uid string) (bool, error) { + query, args, err := r.sb.Update("workflow_templates"). + Set("is_archived", true). + Where(sq.Eq{ + "uid": uid, + "namespace": namespace, + }). + ToSql() + + if err != nil { + return false, err + } + + if _, err := r.db.Exec(query, args...); err != nil { + return false, err + } + + return true, nil +} diff --git a/server/workflow_server.go b/server/workflow_server.go index 7863424..34d2746 100644 --- a/server/workflow_server.go +++ b/server/workflow_server.go @@ -29,12 +29,13 @@ func apiWorkflow(wf *model.Workflow) (workflow *api.Workflow) { if wf.WorkflowTemplate != nil { workflow.WorkflowTemplate = &api.WorkflowTemplate{ - Uid: wf.WorkflowTemplate.UID, - CreatedAt: wf.WorkflowTemplate.CreatedAt.UTC().Format(time.RFC3339), - Name: wf.WorkflowTemplate.Name, - Version: wf.WorkflowTemplate.Version, - Manifest: wf.WorkflowTemplate.Manifest, - IsLatest: wf.WorkflowTemplate.IsLatest, + Uid: wf.WorkflowTemplate.UID, + CreatedAt: wf.WorkflowTemplate.CreatedAt.UTC().Format(time.RFC3339), + Name: wf.WorkflowTemplate.Name, + Version: wf.WorkflowTemplate.Version, + Manifest: wf.WorkflowTemplate.Manifest, + IsLatest: wf.WorkflowTemplate.IsLatest, + IsArchived: wf.WorkflowTemplate.IsArchived, } } @@ -43,12 +44,13 @@ func apiWorkflow(wf *model.Workflow) (workflow *api.Workflow) { func apiWorkflowTemplate(wft *model.WorkflowTemplate) *api.WorkflowTemplate { return &api.WorkflowTemplate{ - Uid: wft.UID, - CreatedAt: wft.CreatedAt.UTC().Format(time.RFC3339), - Name: wft.Name, - Version: wft.Version, - Manifest: wft.Manifest, - IsLatest: wft.IsLatest, + Uid: wft.UID, + CreatedAt: wft.CreatedAt.UTC().Format(time.RFC3339), + Name: wft.Name, + Version: wft.Version, + Manifest: wft.Manifest, + IsLatest: wft.IsLatest, + IsArchived: wft.IsArchived, } } @@ -243,3 +245,16 @@ func (s *WorkflowServer) ListWorkflowTemplates(ctx context.Context, req *api.Lis WorkflowTemplates: apiWorkflowTemplates, }, nil } + +func (s *WorkflowServer) ArchiveWorkflowTemplate(ctx context.Context, req *api.ArchiveWorkflowTemplateRequest) (*api.ArchiveWorkflowTemplateResponse, error) { + archived, err := s.resourceManager.ArchiveWorkflowTemplate(req.Namespace, req.Uid) + if errors.As(err, &userError) { + return nil, userError.GRPCError() + } + + return &api.ArchiveWorkflowTemplateResponse{ + WorkflowTemplate: &api.WorkflowTemplate{ + IsArchived: archived, + }, + }, nil +}