2019-07-13 20:17:42 +03:00
/*
* virsh - completer - secret . c : virsh completer callbacks related to secret
*
* Copyright ( C ) 2019 Red Hat , Inc .
*
* This library is free software ; you can redistribute it and / or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation ; either
* version 2.1 of the License , or ( at your option ) any later version .
*
* This library is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* Lesser General Public License for more details .
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library . If not , see
* < http : //www.gnu.org/licenses/>.
*/
# include <config.h>
# include "virsh-completer-secret.h"
# include "viralloc.h"
# include "virsh-secret.h"
2020-01-24 17:24:49 +03:00
# include "virsh-util.h"
2019-07-13 20:17:42 +03:00
# include "virsh.h"
# include "virstring.h"
char * *
virshSecretUUIDCompleter ( vshControl * ctl ,
2019-10-14 15:44:29 +03:00
const vshCmd * cmd G_GNUC_UNUSED ,
2019-07-13 20:17:42 +03:00
unsigned int flags )
{
2021-03-11 10:16:13 +03:00
virshControl * priv = ctl - > privData ;
2019-07-13 20:17:42 +03:00
virSecretPtr * secrets = NULL ;
int nsecrets = 0 ;
size_t i = 0 ;
char * * ret = NULL ;
2020-12-01 11:21:32 +03:00
g_auto ( GStrv ) tmp = NULL ;
2019-07-13 20:17:42 +03:00
virCheckFlags ( 0 , NULL ) ;
if ( ! priv - > conn | | virConnectIsAlive ( priv - > conn ) < = 0 )
return NULL ;
if ( ( nsecrets = virConnectListAllSecrets ( priv - > conn , & secrets , flags ) ) < 0 )
return NULL ;
2020-09-14 17:24:44 +03:00
tmp = g_new0 ( char * , nsecrets + 1 ) ;
2019-07-13 20:17:42 +03:00
for ( i = 0 ; i < nsecrets ; i + + ) {
char uuid [ VIR_UUID_STRING_BUFLEN ] ;
2019-10-20 14:49:46 +03:00
if ( virSecretGetUUIDString ( secrets [ i ] , uuid ) < 0 )
2019-07-13 20:17:42 +03:00
goto cleanup ;
2019-10-20 14:49:46 +03:00
tmp [ i ] = g_strdup ( uuid ) ;
2019-07-13 20:17:42 +03:00
}
2019-10-16 14:43:36 +03:00
ret = g_steal_pointer ( & tmp ) ;
2019-07-13 20:17:42 +03:00
cleanup :
for ( i = 0 ; i < nsecrets ; i + + )
2020-01-24 17:24:49 +03:00
virshSecretFree ( secrets [ i ] ) ;
2020-09-14 17:10:15 +03:00
g_free ( secrets ) ;
2019-07-13 20:17:42 +03:00
return ret ;
}
char * *
2019-10-14 15:44:29 +03:00
virshSecretEventNameCompleter ( vshControl * ctl G_GNUC_UNUSED ,
const vshCmd * cmd G_GNUC_UNUSED ,
2019-07-13 20:17:42 +03:00
unsigned int flags )
{
size_t i ;
2020-12-01 11:21:32 +03:00
g_auto ( GStrv ) tmp = NULL ;
2019-07-13 20:17:42 +03:00
virCheckFlags ( 0 , NULL ) ;
2020-09-14 17:24:44 +03:00
tmp = g_new0 ( char * , VIR_SECRET_EVENT_ID_LAST + 1 ) ;
2019-07-13 20:17:42 +03:00
2019-10-20 14:49:46 +03:00
for ( i = 0 ; i < VIR_SECRET_EVENT_ID_LAST ; i + + )
tmp [ i ] = g_strdup ( virshSecretEventCallbacks [ i ] . name ) ;
2019-07-13 20:17:42 +03:00
2019-10-17 11:10:10 +03:00
return g_steal_pointer ( & tmp ) ;
2019-07-13 20:17:42 +03:00
}