1 /*
   2  * CDDL HEADER START
   3  *
   4  * The contents of this file are subject to the terms of the
   5  * Common Development and Distribution License (the "License").
   6  * You may not use this file except in compliance with the License.
   7  *
   8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
   9  * or http://www.opensolaris.org/os/licensing.
  10  * See the License for the specific language governing permissions
  11  * and limitations under the License.
  12  *
  13  * When distributing Covered Code, include this CDDL HEADER in each
  14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
  15  * If applicable, add the following below this CDDL HEADER, with the
  16  * fields enclosed by brackets "[]" replaced with your own identifying
  17  * information: Portions Copyright [yyyy] [name of copyright owner]
  18  *
  19  * CDDL HEADER END
  20  */
  21 
  22 /*
  23  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
  24  * Use is subject to license terms.
  25  * Copyright (c) 2016 by Delphix. All rights reserved.
  26  */
  27 
  28 /*
  29  * basic declarations for implementation of the share management
  30  * libraries.
  31  */
  32 
  33 #ifndef _LIBSHARE_IMPL_H
  34 #define _LIBSHARE_IMPL_H
  35 
  36 #include <libshare.h>
  37 #include <libscf.h>
  38 #include <scfutil.h>
  39 #include <libzfs.h>
  40 #include <sharefs/share.h>
  41 #include <sharefs/sharetab.h>
  42 
  43 #ifdef  __cplusplus
  44 extern "C" {
  45 #endif
  46 
  47 /* directory to find plugin modules in */
  48 #define SA_LIB_DIR      "/usr/lib/fs"
  49 
  50 /* default group name for dfstab file */
  51 #define SA_DEFAULT_FILE_GRP     "sys"
  52 
  53 typedef void *sa_phandle_t;
  54 
  55 #define SA_PLUGIN_VERSION       1
  56 struct sa_plugin_ops {
  57         int     sa_version;                     /* version number */
  58         char    *sa_protocol;                   /* protocol name */
  59         int     (*sa_init)();
  60         void    (*sa_fini)();
  61         int     (*sa_share)(sa_share_t);        /* start sharing */
  62         int     (*sa_unshare)(sa_share_t, char *); /* stop sharing */
  63         int     (*sa_valid_prop)(sa_handle_t, sa_property_t,
  64             sa_optionset_t); /* validate */
  65         int     (*sa_valid_space)(char *);      /* is name valid optionspace? */
  66         int     (*sa_security_prop)(char *);    /* property is security */
  67         int     (*sa_legacy_opts)(sa_group_t, char *); /* parse legacy opts */
  68         char   *(*sa_legacy_format)(sa_group_t, int);
  69         int     (*sa_set_proto_prop)(sa_property_t);    /* set a property */
  70         sa_protocol_properties_t (*sa_get_proto_set)(); /* get properties */
  71         char   *(*sa_get_proto_status)();
  72         char   *(*sa_space_alias)(char *);
  73         int     (*sa_update_legacy)(sa_share_t);
  74         int     (*sa_delete_legacy)(sa_share_t);
  75         int     (*sa_change_notify)(sa_share_t);
  76         int     (*sa_enable_resource)(sa_resource_t);
  77         int     (*sa_disable_resource)(sa_resource_t);
  78         uint64_t (*sa_features)(void);
  79         int     (*sa_get_transient_shares)(sa_handle_t); /* add transients */
  80         int     (*sa_notify_resource)(sa_resource_t);
  81         int     (*sa_rename_resource)(sa_handle_t, sa_resource_t, char *);
  82         int     (*sa_run_command)(int, int, char **); /* proto specific */
  83         int     (*sa_command_help)();
  84         int     (*sa_delete_proto_section)(char *);
  85 };
  86 
  87 struct sa_proto_handle {
  88         int                     sa_ref_count;
  89         int                     sa_num_proto;
  90         char                    **sa_proto;
  91         struct sa_plugin_ops    **sa_ops;
  92 };
  93 
  94 typedef struct propertylist {
  95         struct propertylist     *pl_next;
  96         int                     pl_type;
  97         union propval {
  98             sa_optionset_t      pl_optionset;
  99             sa_security_t       pl_security;
 100             void                *pl_void;
 101         }                       pl_value;
 102 } property_list_t;
 103 
 104 /* internal version of sa_handle_t */
 105 typedef struct sa_handle_impl {
 106         uint64_t        flags;
 107         scfutilhandle_t *scfhandle;
 108         libzfs_handle_t *zfs_libhandle;
 109         zfs_handle_t    **zfs_list;
 110         size_t          zfs_list_count;
 111         xmlNodePtr      tree;
 112         xmlDocPtr       doc;
 113         uint64_t        tssharetab;
 114         uint64_t        tstrans;
 115         int             sa_service;
 116 } *sa_handle_impl_t;
 117 
 118 extern int sa_proto_share(char *, sa_share_t);
 119 extern int sa_proto_unshare(sa_share_t, char *, char *);
 120 extern int sa_proto_valid_prop(sa_handle_t, char *, sa_property_t,
 121     sa_optionset_t);
 122 extern int sa_proto_security_prop(char *, char *);
 123 extern int sa_proto_legacy_opts(char *, sa_group_t, char *);
 124 extern int sa_proto_share_resource(char *, sa_resource_t);
 125 extern int sa_proto_unshare_resource(char *, sa_resource_t);
 126 
 127 /* internal utility functions */
 128 extern sa_optionset_t sa_get_derived_optionset(sa_group_t, char *, int);
 129 extern void sa_free_derived_optionset(sa_optionset_t);
 130 extern sa_optionset_t sa_get_all_security_types(void *, char *, int);
 131 extern sa_security_t sa_get_derived_security(void *, char *, char *, int);
 132 extern void sa_free_derived_security(sa_security_t);
 133 extern sa_protocol_properties_t sa_create_protocol_properties(char *);
 134 extern int sa_start_transaction(scfutilhandle_t *, char *);
 135 extern int sa_end_transaction(scfutilhandle_t *, sa_handle_impl_t);
 136 extern void sa_abort_transaction(scfutilhandle_t *);
 137 extern int sa_commit_share(scfutilhandle_t *, sa_group_t, sa_share_t);
 138 extern int sa_set_property(scfutilhandle_t *, char *, char *);
 139 extern void sa_free_fstype(char *fstyp);
 140 extern int sa_delete_share(scfutilhandle_t *, sa_group_t, sa_share_t);
 141 extern int sa_delete_instance(scfutilhandle_t *, char *);
 142 extern int sa_create_pgroup(scfutilhandle_t *, char *);
 143 extern int sa_delete_pgroup(scfutilhandle_t *, char *);
 144 extern void sa_fillshare(sa_share_t share, char *proto, struct share *sh);
 145 extern void sa_emptyshare(struct share *sh);
 146 
 147 /* ZFS functions */
 148 extern int sa_get_one_zfs_share(sa_handle_t, char *, sa_init_selective_arg_t *,
 149     char ***, size_t *);
 150 extern int sa_get_zfs_shares(sa_handle_t, char *);
 151 extern int sa_get_zfs_share_for_name(sa_handle_t, char *, const char *, char *);
 152 extern int sa_zfs_update(sa_share_t);
 153 extern int sa_share_zfs(sa_share_t, sa_resource_t, char *, share_t *,
 154     void *, zfs_share_op_t);
 155 extern int sa_sharetab_fill_zfs(sa_share_t share, struct share *sh,
 156     char *proto);
 157 
 158 /* plugin specific functions */
 159 extern int proto_plugin_init();
 160 extern void proto_plugin_fini();
 161 extern int sa_proto_set_property(char *, sa_property_t);
 162 extern int sa_proto_delete_legacy(char *, sa_share_t);
 163 extern int sa_proto_update_legacy(char *, sa_share_t);
 164 extern int sa_proto_rename_resource(sa_handle_t, char *,
 165     sa_resource_t, char *);
 166 
 167 #define PL_TYPE_PROPERTY        0
 168 #define PL_TYPE_SECURITY        1
 169 
 170 /* values only used by the internal dfstab/sharetab parser */
 171 #define SA_SHARE_PARSER         0x1000
 172 
 173 /* plugin handler only */
 174 struct sa_proto_plugin {
 175         struct sa_proto_plugin  *plugin_next;
 176         struct sa_plugin_ops    *plugin_ops;
 177         void                    *plugin_handle;
 178 };
 179 
 180 #define TSTAMP(tm)      (uint64_t)(((uint64_t)tm.tv_sec << 32) | \
 181                                         (tm.tv_nsec & 0xffffffff))
 182 
 183 
 184 #ifdef  __cplusplus
 185 }
 186 #endif
 187 
 188 #endif /* _LIBSHARE_IMPL_H */