-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathcatalog.spec
837 lines (645 loc) · 29 KB
/
catalog.spec
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
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
/*
Service for managing, registering, and building KBase Modules using the KBase SDK.
*/
module Catalog {
/* @range [0,1] */
typedef int boolean;
/* Get the version of the deployed catalog service endpoint. */
funcdef version() returns (string version);
/*
Describes how to find a single module/repository.
module_name - name of module defined in kbase.yaml file;
git_url - the url used to register the module
*/
typedef structure {
string module_name;
string git_url;
} SelectOneModuleParams;
/* returns true (1) if the module exists, false (2) otherwise */
funcdef is_registered(SelectOneModuleParams params) returns (boolean);
typedef structure {
string git_url;
string git_commit_hash;
} RegisterRepoParams;
/* allow/require developer to supply git branch/git commit tag?
if this is a new module, creates the initial registration with the authenticated user as
the sole owner, then launches a build to update the dev version of the module. You can check
the state of this build with the 'get_module_state' method passing in the git_url. If the module
already exists, then you must be an owner to reregister. That will immediately overwrite your
dev version of the module (old dev versions are not stored, but you can always reregister an old
version from the repo) and start a build.
*/
funcdef register_repo(RegisterRepoParams params) returns (string registration_id) authentication required;
/* immediately updates the beta tag to what is currently in dev, whatever is currently in beta
is discarded. Will fail if a release request is active and has not been approved/denied */
funcdef push_dev_to_beta(SelectOneModuleParams params) returns () authentication required;
/* requests a push from beta to release version; must be approved be a kbase Admin */
funcdef request_release(SelectOneModuleParams params) returns () authentication required;
typedef structure {
string module_name;
string git_url;
string git_commit_hash;
string git_commit_message;
int timestamp;
list <string> owners;
} RequestedReleaseInfo;
funcdef list_requested_releases() returns (list<RequestedReleaseInfo> requested_releases);
/*
decision - approved | denied
review_message -
*/
typedef structure {
string module_name;
string git_url;
string decision;
string review_message;
} ReleaseReview;
funcdef review_release_request(ReleaseReview review) returns () authentication required;
/*
Describes how to filter repositories.
include_released - optional flag indicated modules that are released are included (default:true)
include_unreleased - optional flag indicated modules that are not released are included (default:false)
with_disabled - optional flag indicating disabled repos should be included (default:false).
include_modules_with_no_name_set - default to 0, if set return modules that were never
registered successfully (first registration failed, never
got a module name, but there is a git_url)
*/
typedef structure {
list <string> owners;
boolean include_released;
boolean include_unreleased;
boolean include_disabled;
boolean include_modules_with_no_name_set;
} ListModuleParams;
typedef structure {
string git_commit_hash;
} VersionCommitInfo;
/*
git_url is always returned. Every other field
may or may not exist depending on what has been registered or if
certain registrations have failed
*/
typedef structure {
string module_name;
string git_url;
string language;
boolean dynamic_service;
list <string> owners;
VersionCommitInfo dev;
VersionCommitInfo beta;
VersionCommitInfo release;
list <VersionCommitInfo> released_version_list;
} BasicModuleInfo;
/* */
funcdef list_basic_module_info(ListModuleParams params) returns (list<BasicModuleInfo> info_list);
/* FAVORITES!! */
typedef structure {
string module_name;
string id;
} FavoriteItem;
funcdef add_favorite(FavoriteItem params) returns () authentication required;
funcdef remove_favorite(FavoriteItem params) returns () authentication required;
funcdef list_favorites(string username) returns(list<FavoriteItem> favorites);
typedef structure {
string username;
string timestamp;
} FavoriteUser;
funcdef list_app_favorites(FavoriteItem item) returns(list<FavoriteUser> users);
/* if favorite item is given, will return stars just for that item. If a module
name is given, will return stars for all methods in that module. If none of
those are given, then will return stars for every method that there is info on
parameters to add:
list<FavoriteItem> items;
*/
typedef structure {
list<string> modules;
} ListFavoriteCounts;
typedef structure {
string module_name;
string app_id;
int count;
} FavoriteCount;
funcdef list_favorite_counts(ListFavoriteCounts params) returns (list<FavoriteCount> counts);
typedef structure {
int start_line;
int end_line;
} FunctionPlace;
typedef structure {
string type;
string comment;
} Parameter;
typedef structure {
string name;
string comment;
FunctionPlace place;
list<Parameter> input;
list<Parameter> output;
} Function;
typedef structure {
string file_name;
string content;
boolean is_main;
} SpecFile;
typedef structure {
string module_name;
string sdk_version;
string sdk_git_commit;
string impl_file_path;
mapping<string, FunctionPlace> function_places;
mapping<string, Function> functions;
list<SpecFile> spec_files;
} CompilationReport;
/*
data_folder - optional field representing unique module name (like <module_name> transformed to
lower cases) used for reference data purposes (see description for data_version field). This
value will be treated as part of file system path relative to the base that comes from the
config (currently base is supposed to be "/kb/data" defined in "ref-data-base" parameter).
data_version - optional field, reflects version of data defined in kbase.yml (see "data-version"
key). In case this field is set data folder with path "/kb/data/<data_folder>/<data_version>"
should be initialized by running docker image with "init" target from catalog. And later when
async methods are run it should be mounted on AWE worker machine into "/data" folder inside
docker container by execution engine.
*/
typedef structure {
int timestamp;
string registration_id;
string version;
string git_commit_hash;
string git_commit_message;
boolean dynamic_service;
list<string> narrative_method_ids;
list<string> local_function_ids;
string docker_img_name;
string data_folder;
string data_version;
CompilationReport compilation_report;
} ModuleVersionInfo;
typedef structure {
string module_name;
string git_url;
string description;
string language;
list <string> owners;
ModuleVersionInfo release;
ModuleVersionInfo beta;
ModuleVersionInfo dev;
} ModuleInfo;
funcdef get_module_info(SelectOneModuleParams selection) returns (ModuleInfo info);
/*
only required: module_name or git_url, the rest are optional selectors
If no selectors given, returns current release version
version is one of: release | beta | dev
old release versions can only be retrieved individually by timestamp or git_commit_hash
Note: this method isn't particularly smart or effecient yet, because it pulls the info for a particular
module first, then searches in code for matches to the relevant query. Instead, this should be
performed on the database side through queries. Will optimize when this becomes an issue.
In the future, this will be extended so that you can retrieve version info by only
timestamp, git commit, etc, but the necessary indicies have not been setup yet. In general, we will
need to add better search capabilities
*/
typedef structure {
string module_name;
string git_url;
int timestamp;
string git_commit_hash;
string version;
} SelectModuleVersionParams;
/* DEPRECATED!!! use get_module_version */
funcdef get_version_info(SelectModuleVersionParams params) returns (ModuleVersionInfo version);
funcdef list_released_module_versions(SelectOneModuleParams params) returns (list<ModuleVersionInfo> versions);
/*
module_name - the name of the module
module_description - (optionally returned) html description in KBase YAML of this module
git_url - the git url of the source for this module
released - 1 if this version has been released, 0 otherwise
release_tags - list of strings of: 'dev', 'beta', or 'release', or empty list
this is a list because the same commit version may be the version in multiple release states
release_timestamp - time in ms since epoch when this module was approved and moved to release, null otherwise
note that a module was released before v1.0.0, the release timestamp may not have been
recorded and will default to the registration timestamp
timestamp - time in ms since epoch when the registration for this version was started
registration_id - id of the last registration for this version, used for fetching registration logs and state
version - validated semantic version number as indicated in the KBase YAML of this version
semantic versions are unique among released versions of this module
git_commit_hash - the full git commit hash of the source for this module
git_commit_message - the message attached to this git commit
dynamic_service - 1 if this version is available as a web service, 0 otherwise
narrative_app_ids - list of Narrative App ids registered with this module version
local_function_ids - list of Local Function ids registered with this module version
docker_img_name - name of the docker image for this module created on registration
data_folder - name of the data folder used
compilation_report - (optionally returned) summary of the KIDL specification compilation
*/
typedef structure {
string module_name;
string module_description;
string git_url;
boolean released;
list<string> release_tags;
int timestamp;
string registration_id;
string version;
string git_commit_hash;
string git_commit_message;
boolean dynamic_service;
list<string> narrative_app_ids;
list<string> local_function_ids;
string docker_img_name;
string data_folder;
string data_version;
CompilationReport compilation_report;
} ModuleVersion;
/*
Get a specific module version.
Requires either a module_name or git_url. If both are provided, they both must match.
If no other options are specified, then the latest 'release' version is returned. If
the module has not been released, then the latest 'beta' or 'dev' version is returned.
You can check in the returned object if the version has been released (see is_released)
and what release tags are pointing to this version (see release_tags).
Optionally, a 'version' parameter can be provided that can be either:
1) release tag: 'dev' | 'beta' | 'release'
2) specific semantic version of a released version (you cannot pull dev/beta or other
unreleased versions by semantic version)
- e.g. 2.0.1
3) semantic version requirement specification, see: https://pypi.python.org/pypi/semantic_version/
which will return the latest released version that matches the criteria. You cannot pull
dev/beta or other unreleased versions this way.
- e.g.:
- '>1.0.0'
- '>=2.1.1,<3.3.0'
- '!=0.2.4-alpha,<0.3.0'
4) specific full git commit hash
include_module_description - set to 1 to include the module description in the YAML file of this version;
default is 0
include_compilation_report - set to 1 to include the module compilation report, default is 0
*/
typedef structure {
string module_name;
string git_url;
string version;
boolean include_module_description;
boolean include_compilation_report;
} SelectModuleVersion;
funcdef get_module_version(SelectModuleVersion selection) returns (ModuleVersion version);
/* Local Function Listing Support */
typedef structure {
list<string> file_types;
list<string> kb_types;
} IOTags;
typedef structure {
list <string> categories;
IOTags input;
IOTags output;
} LocalFunctionTags;
/* todo: switch release_tag to release_tags */
typedef structure {
string module_name;
string function_id;
string git_commit_hash;
string version;
list<string> release_tag;
string name;
string short_description;
LocalFunctionTags tags;
} LocalFunctionInfo;
typedef structure {
LocalFunctionInfo info;
string long_description;
} LocalFunctionDetails;
/*
Allows various ways to filter.
Release tag = dev/beta/release, default is release
module_names = only include modules in the list; if empty or not
provided then include everything
*/
typedef structure {
string release_tag;
list<string> module_names;
} ListLocalFunctionParams;
funcdef list_local_functions(ListLocalFunctionParams params) returns (list<LocalFunctionInfo> info_list);
/*
release_tag = dev | beta | release, if it doesn't exist and git_commit_hash isn't set, we default to release
and will not return anything if the function is not released
*/
typedef structure {
string module_name;
string function_id;
string release_tag;
string git_commit_hash;
} SelectOneLocalFunction;
typedef structure {
list<SelectOneLocalFunction> functions;
} GetLocalFunctionDetails;
funcdef get_local_function_details(GetLocalFunctionDetails params) returns (list<LocalFunctionDetails> detail_list);
/* End local function listing support */
/* DYNAMIC SERVICES SUPPORT Methods */
typedef structure {
string module_name;
string version;
string git_commit_hash;
string docker_img_name;
} BasicModuleVersionInfo;
/*
module_name - required for module lookup
lookup - a lookup string, if empty will get the latest released module
1) version tag = dev | beta | release
2) semantic version match identifiier
not supported yet: 3) exact commit hash
not supported yet: 4) exact timestamp
only_service_versions - 1/0, default is 1
*/
typedef structure {
string module_name;
string lookup;
boolean only_service_versions;
} ModuleVersionLookupParams;
funcdef module_version_lookup(ModuleVersionLookupParams selection) returns (BasicModuleVersionInfo);
/*
tag = dev | beta | release
if tag is not set, all release versions are returned
*/
typedef structure {
string tag;
} ListServiceModuleParams;
funcdef list_service_modules(ListServiceModuleParams filter) returns (list<BasicModuleVersionInfo> service_modules);
/* End Dynamic Services Support Methods */
typedef structure {
string module_name;
string git_url;
string registration_state;
string error_message;
} SetRegistrationStateParams;
funcdef set_registration_state(SetRegistrationStateParams params) returns () authentication required;
/*
active: True | False,
release_approval: approved | denied | under_review | not_requested, (all releases require approval)
review_message: str, (optional)
registration: complete | error | (build state status),
error_message: str (optional)
*/
typedef structure {
boolean active;
boolean released;
string release_approval;
string review_message;
string registration;
string error_message;
} ModuleState;
/* */
funcdef get_module_state(SelectOneModuleParams params) returns (ModuleState state);
/* must specify skip & limit, or first_n, or last_n. If none given, this gets last 5000 lines */
typedef structure {
string registration_id;
int skip;
int limit;
int first_n;
int last_n;
} GetBuildLogParams;
typedef structure {
string content;
boolean error;
} BuildLogLine;
typedef structure {
string registration_id;
string timestamp;
string module_name_lc;
string git_url;
string error;
string registration;
list <BuildLogLine> log;
} BuildLog;
funcdef get_build_log(string registration_id) returns (string);
/*
given the registration_id returned from the register method, you can check the build log with this method
*/
funcdef get_parsed_build_log(GetBuildLogParams params) returns (BuildLog build_log);
typedef structure {
string timestamp;
string registration_id;
string registration;
string error_message;
string module_name_lc;
string git_url;
} BuildInfo;
/*
Always sorted by time, oldest builds are last.
only one of these can be set to true:
only_running - if true, only show running builds
only_error - if true, only show builds that ended in an error
only_complete - if true, only show builds that are complete
skip - skip these first n records, default 0
limit - limit result to the most recent n records, default 1000
modules - only include builds from these modules based on names/git_urls
*/
typedef structure {
boolean only_runnning;
boolean only_error;
boolean only_complete;
int skip;
int limit;
list <SelectOneModuleParams> modules;
} ListBuildParams;
funcdef list_builds(ListBuildParams params) returns (list<BuildInfo> builds);
/* all fields are required to make sure you update the right one */
typedef structure {
string module_name;
string current_git_url;
string new_git_url;
} UpdateGitUrlParams;
/* admin method to delete a module, will only work if the module has not been released */
funcdef delete_module(SelectOneModuleParams params) returns () authentication required;
/* admin method to move the git url for a module, should only be used if the exact same code has migrated to
a new URL. It should not be used as a way to change ownership, get updates from a new source, or get a new
module name for an existing git url because old versions are retained and git commits saved will no longer
be correct. */
funcdef migrate_module_to_new_git_url(UpdateGitUrlParams params) returns () authentication required;
/* admin methods to turn on/off modules */
funcdef set_to_active(SelectOneModuleParams params) returns () authentication required;
funcdef set_to_inactive(SelectOneModuleParams params) returns () authentication required;
/* temporary developer approval, should be moved to more mature user profile service */
funcdef is_approved_developer(list<string>usernames) returns (list<boolean> is_approved);
funcdef list_approved_developers() returns (list<string> usernames) authentication required;
funcdef approve_developer(string username) returns () authentication required;
funcdef revoke_developer(string username) returns () authentication required;
/*
user_id - GlobusOnline login of invoker,
app_module_name - optional module name of registered repo (could be absent of null for
old fashioned services) where app_id comes from,
app_id - optional method-spec id without module_name prefix (could be absent or null
in case original execution was started through API call without app ID defined),
func_module_name - optional module name of registered repo (could be absent of null for
old fashioned services) where func_name comes from,
func_name - name of function in KIDL-spec without module_name prefix,
git_commit_hash - optional service version (in case of dynamically registered repo),
creation_time, exec_start_time and finish_time - defined in seconds since Epoch (POSIX),
is_error - indicates whether execution was finished with error or not.
*/
typedef structure {
string user_id;
string app_module_name;
string app_id;
string func_module_name;
string func_name;
string git_commit_hash;
float creation_time;
float exec_start_time;
float finish_time;
boolean is_error;
string job_id;
} LogExecStatsParams;
/*
Request from Execution Engine for adding statistics about each method run. It could be done
using catalog admin credentials only.
*/
funcdef log_exec_stats(LogExecStatsParams params) returns () authentication required;
/*
full_app_ids - list of fully qualified app IDs (including module_name prefix followed by
slash in case of dynamically registered repo).
per_week - optional flag switching results to weekly data rather than one row per app for
all time (default value is false)
*/
typedef structure {
list<string> full_app_ids;
boolean per_week;
} GetExecAggrStatsParams;
/*
full_app_id - optional fully qualified method-spec id including module_name prefix followed
by slash in case of dynamically registered repo (it could be absent or null in case
original execution was started through API call without app ID defined),
time_range - one of supported time ranges (currently it could be either '*' for all time
or ISO-encoded week like "2016-W01")
total_queue_time - summarized time difference between exec_start_time and creation_time moments
defined in seconds since Epoch (POSIX),
total_exec_time - summarized time difference between finish_time and exec_start_time moments
defined in seconds since Epoch (POSIX).
*/
typedef structure {
string full_app_id;
string time_range;
int number_of_calls;
int number_of_errors;
float total_queue_time;
float total_exec_time;
} ExecAggrStats;
funcdef get_exec_aggr_stats(GetExecAggrStatsParams params) returns (list<ExecAggrStats>);
/*
Get aggregated usage metrics; available only to Admins.
*/
typedef structure {
int begin;
int end;
} ExecAggrTableParams;
funcdef get_exec_aggr_table(ExecAggrTableParams params) returns (UnspecifiedObject table) authentication required;
/*
Get raw usage metrics; available only to Admins.
*/
typedef structure {
int begin;
int end;
} GetExecRawStatsParams;
funcdef get_exec_raw_stats(GetExecRawStatsParams params) returns (list<UnspecifiedObject> records) authentication required;
/* Temporary set of methods to dynamically set client groups for specific methods. These methods
will likely go away after the execution engine has been refactored/extended. Only admins can
run these methods.
*/
/* app_id = full app id; if module name is used it will be case insensitive
this will overwrite all existing client groups (it won't just push what's on the list)
If client_groups is empty or set to null, then the client_group mapping will be removed.
*/
typedef structure {
string app_id;
list<string> client_groups;
} AppClientGroup;
/* if app_ids is empty or null, all client groups are returned */
typedef structure {
} GetClientGroupParams;
/* @deprecated list_client_group_configs */
funcdef get_client_groups(GetClientGroupParams params) returns (list<AppClientGroup> groups);
typedef structure {
string module_name;
string function_name;
list<string> client_groups;
} ClientGroupConfig;
funcdef set_client_group_config(ClientGroupConfig config) returns () authentication required;
funcdef remove_client_group_config(ClientGroupConfig config) returns () authentication required;
typedef structure {
string module_name;
string function_name;
} ClientGroupFilter;
funcdef list_client_group_configs(ClientGroupFilter filter) returns (list<ClientGroupConfig> groups);
typedef structure {
string host_dir;
string container_dir;
boolean read_only;
} VolumeMount;
/* for a module, function, and client group, set mount configurations */
typedef structure {
string module_name;
string function_name;
string client_group;
list <VolumeMount> volume_mounts;
} VolumeMountConfig;
/* must specify all properties of the VolumeMountConfig */
funcdef set_volume_mount(VolumeMountConfig config) returns () authentication required;
/* must specify module_name, function_name, client_group and this method will delete any configured mounts */
funcdef remove_volume_mount(VolumeMountConfig config) returns () authentication required;
/*
Parameters for listing VolumeMountConfigs. If nothing is set, everything is
returned. Otherwise, will return everything that matches all fields set. For
instance, if only module_name is set, will return everything for that module. If
they are all set, will return the specific module/app/client group config. Returns
nothing if no matches are found.
*/
typedef structure {
string module_name;
string function_name;
string client_group;
} VolumeMountFilter;
funcdef list_volume_mounts(VolumeMountFilter filter)
returns (list<VolumeMountConfig> volume_mount_configs) authentication required;
/* returns true (1) if the user is an admin, false (0) otherwise.
NOTE: username is now ignored (it checks the token) but retained for back compatibility
*/
funcdef is_admin(string username) returns (boolean) authentication optional;
/*
version - optional version (commit hash, tag or semantic one) of module, if not set
then default "" value is used which means parameter is applied to any version;
is_password - optional flag meaning to hide this parameter's value in UI.
*/
typedef structure {
string module_name;
string version;
string param_name;
boolean is_password;
string param_value;
} SecureConfigParameter;
typedef structure {
list<SecureConfigParameter> data;
} ModifySecureConfigParamsInput;
/*
Only admins can use this function.
*/
funcdef set_secure_config_params(ModifySecureConfigParamsInput params)
returns () authentication required;
/*
Only admins can use this function.
*/
funcdef remove_secure_config_params(ModifySecureConfigParamsInput params)
returns () authentication required;
/*
version - optional version (commit hash, tag or semantic one) of module, if
not set then default "release" value is used;
load_all_versions - optional flag indicating that all parameter versions
should be loaded (version filter is not applied), default value is 0.
*/
typedef structure {
string module_name;
string version;
boolean load_all_versions;
} GetSecureConfigParamsInput;
/*
Only admins can use this function.
*/
funcdef get_secure_config_params(GetSecureConfigParamsInput params)
returns (list<SecureConfigParameter>) authentication required;
};