common_glue.c revision 233294
155682Smarkm/*
255682Smarkm * Copyright (c) 1997 - 2000 Kungliga Tekniska H��gskolan
355682Smarkm * (Royal Institute of Technology, Stockholm, Sweden).
455682Smarkm * All rights reserved.
555682Smarkm *
655682Smarkm * Redistribution and use in source and binary forms, with or without
755682Smarkm * modification, are permitted provided that the following conditions
855682Smarkm * are met:
955682Smarkm *
1055682Smarkm * 1. Redistributions of source code must retain the above copyright
1155682Smarkm *    notice, this list of conditions and the following disclaimer.
1255682Smarkm *
1355682Smarkm * 2. Redistributions in binary form must reproduce the above copyright
1455682Smarkm *    notice, this list of conditions and the following disclaimer in the
1555682Smarkm *    documentation and/or other materials provided with the distribution.
1655682Smarkm *
1755682Smarkm * 3. Neither the name of the Institute nor the names of its contributors
1855682Smarkm *    may be used to endorse or promote products derived from this software
1955682Smarkm *    without specific prior written permission.
2055682Smarkm *
2155682Smarkm * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
2255682Smarkm * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
2355682Smarkm * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
2455682Smarkm * ARE DISCLAIMED.  IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
2555682Smarkm * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2655682Smarkm * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2755682Smarkm * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2855682Smarkm * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2955682Smarkm * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
3055682Smarkm * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
3155682Smarkm * SUCH DAMAGE.
3255682Smarkm */
3355682Smarkm
3455682Smarkm#include "kadm5_locl.h"
3555682Smarkm
36120945SnectarRCSID("$Id$");
3755682Smarkm
3855682Smarkm#define __CALL(F, P) (*((kadm5_common_context*)server_handle)->funcs.F)P;
3955682Smarkm
4055682Smarkmkadm5_ret_t
4155682Smarkmkadm5_chpass_principal(void *server_handle,
4255682Smarkm		       krb5_principal princ,
4355682Smarkm		       const char *password)
4455682Smarkm{
4555682Smarkm    return __CALL(chpass_principal, (server_handle, princ, password));
4655682Smarkm}
4755682Smarkm
4855682Smarkmkadm5_ret_t
4955682Smarkmkadm5_chpass_principal_with_key(void *server_handle,
50120945Snectar				krb5_principal princ,
5155682Smarkm				int n_key_data,
5255682Smarkm				krb5_key_data *key_data)
5355682Smarkm{
54    return __CALL(chpass_principal_with_key,
55		  (server_handle, princ, n_key_data, key_data));
56}
57
58kadm5_ret_t
59kadm5_create_principal(void *server_handle,
60		       kadm5_principal_ent_t princ,
61		       uint32_t mask,
62		       const char *password)
63{
64    return __CALL(create_principal, (server_handle, princ, mask, password));
65}
66
67kadm5_ret_t
68kadm5_delete_principal(void *server_handle,
69		       krb5_principal princ)
70{
71    return __CALL(delete_principal, (server_handle, princ));
72}
73
74kadm5_ret_t
75kadm5_destroy (void *server_handle)
76{
77    return __CALL(destroy, (server_handle));
78}
79
80kadm5_ret_t
81kadm5_flush (void *server_handle)
82{
83    return __CALL(flush, (server_handle));
84}
85
86kadm5_ret_t
87kadm5_get_principal(void *server_handle,
88		    krb5_principal princ,
89		    kadm5_principal_ent_t out,
90		    uint32_t mask)
91{
92    return __CALL(get_principal, (server_handle, princ, out, mask));
93}
94
95kadm5_ret_t
96kadm5_modify_principal(void *server_handle,
97		       kadm5_principal_ent_t princ,
98		       uint32_t mask)
99{
100    return __CALL(modify_principal, (server_handle, princ, mask));
101}
102
103kadm5_ret_t
104kadm5_randkey_principal(void *server_handle,
105			krb5_principal princ,
106			krb5_keyblock **new_keys,
107			int *n_keys)
108{
109    return __CALL(randkey_principal, (server_handle, princ, new_keys, n_keys));
110}
111
112kadm5_ret_t
113kadm5_rename_principal(void *server_handle,
114		       krb5_principal source,
115		       krb5_principal target)
116{
117    return __CALL(rename_principal, (server_handle, source, target));
118}
119
120kadm5_ret_t
121kadm5_get_principals(void *server_handle,
122		     const char *expression,
123		     char ***princs,
124		     int *count)
125{
126    return __CALL(get_principals, (server_handle, expression, princs, count));
127}
128
129kadm5_ret_t
130kadm5_get_privs(void *server_handle,
131		uint32_t *privs)
132{
133    return __CALL(get_privs, (server_handle, privs));
134}
135