Go to the documentation of this file.
25 #ifndef PIPEWIRE_IMPL_CLIENT_H
26 #define PIPEWIRE_IMPL_CLIENT_H
79 struct pw_impl_client;
89 #define PW_VERSION_IMPL_CLIENT_EVENTS 0
117 struct pw_impl_client *
119 struct pw_protocol *protocol,
121 size_t user_data_size );
145 uint32_t global_id, uint32_t permissions);
int pw_global_update_permissions(struct pw_global *global, struct pw_impl_client *client, uint32_t old_permissions, uint32_t new_permissions)
Definition: global.c:314
#define PW_CLIENT_CHANGE_MASK_ALL
Definition: client.h:58
struct pw_impl_client * pw_context_create_client(struct pw_impl_core *core, struct pw_protocol *protocol, struct pw_properties *properties, size_t user_data_size)
Make a new client object.
Definition: impl-client.c:386
int pw_impl_client_update_properties(struct pw_impl_client *client, const struct spa_dict *dict)
Update client properties.
Definition: impl-client.c:638
int int const char * pw_properties_get(const struct pw_properties *properties, const char *key)
Get a property.
Definition: properties.c:487
Definition: module-filter-chain.c:176
void * pw_impl_client_get_user_data(struct pw_impl_client *client)
Get the client user data.
Definition: impl-client.c:558
#define PW_KEY_SEC_LABEL
client security label, set by protocol
Definition: src/pipewire/keys.h:58
#define NAME
Definition: impl-client.c:33
struct pw_mempool * pw_mempool_new(struct pw_properties *props)
Create a new memory pool.
Definition: mem.c:133
int pw_impl_client_register(struct pw_impl_client *client, struct pw_properties *properties)
Finish configuration and register a client.
Definition: impl-client.c:473
uint32_t id
unique id
Definition: src/pipewire/mem.h:80
const char * error
Definition: impl-client.c:115
const char * key
Definition: utils/dict.h:42
@ PW_MEMBLOCK_FLAG_READWRITE
Definition: src/pipewire/mem.h:53
#define PW_KEY_OBJECT_ID
a global object id
Definition: src/pipewire/keys.h:66
int pw_global_register(struct pw_global *global)
Register a global object to the context registry.
Definition: global.c:125
void pw_context_add_listener(struct pw_context *context, struct spa_hook *listener, const struct pw_context_events *events, void *data)
Add a new event listener to a context.
Definition: context.c:551
const struct pw_client_info * pw_impl_client_get_info(struct pw_impl_client *client)
Get the client information.
Definition: impl-client.c:622
struct pw_context * pw_impl_client_get_context(struct pw_impl_client *client)
Get the context used to create this client.
Definition: impl-client.c:522
uint32_t id
Definition: impl-client.c:113
#define pw_array_check_index(a, idx, t)
Check if an item with index idx and type t exist in array.
Definition: array.h:66
void pw_mempool_destroy(struct pw_mempool *pool)
Clear and destroy a pool.
Definition: mem.c:168
#define PW_KEY_MODULE_ID
module properties
Definition: src/pipewire/keys.h:249
Definition: impl-core.c:74
user data to add to an object
Definition: filter.c:75
struct pw_global * pw_global_new(struct pw_context *context, const char *type, uint32_t version, struct pw_properties *properties, pw_global_bind_func_t func, void *object)
Create a new global object.
Definition: global.c:66
uint8_t data[MAX_BUFFER]
Definition: module-profiler.c:87
int pw_global_add_resource(struct pw_global *global, struct pw_resource *resource)
Add a resource to a global.
Definition: global.c:230
void(* resource_added)(void *data, struct pw_resource *resource)
emitted when a new resource is added for client
Definition: impl-client.h:105
void pw_mempool_add_listener(struct pw_mempool *pool, struct spa_hook *listener, const struct pw_mempool_events *events, void *data)
Listen for events.
Definition: mem.c:186
bool spa_streq(const char *s1, const char *s2)
Definition: string.h:50
struct spa_hook resource_listener
Definition: impl-core.c:76
#define spa_list_for_each(pos, head, member)
Definition: list.h:111
uint32_t flags
flags for the memory block on of enum pw_memblock_flags
Definition: src/pipewire/mem.h:82
uint32_t pw_global_get_permissions(struct pw_global *global, struct pw_impl_client *client)
Get the permissions of the global for a given client.
Definition: global.c:45
#define SPA_EXPORT
Definition: defs.h:208
Global events, use pw_global_add_listener.
Definition: global.h:68
#define PW_PERM_R
object can be seen and events can be received
Definition: permission.h:47
struct spa_hook listener
Definition: access-flatpak.c:46
uint32_t id
Definition: access-flatpak.c:54
void spa_hook_list_append(struct spa_hook_list *list, struct spa_hook *hook, const void *funcs, void *data)
Append a hook.
Definition: hook.h:316
void pw_resource_destroy(struct pw_resource *resource)
Destroy a resource.
Definition: resource.c:264
#define SPA_PTROFF(ptr_, offset_, type_)
Return the address (buffer + offset) as pointer of type.
Definition: defs.h:159
The events that a client can emit.
Definition: impl-client.h:88
bool spa_strstartswith(const char *s, const char *prefix)
Definition: string.h:71
Definition: permission.h:64
#define PW_KEY_PROTOCOL
protocol used for connection
Definition: src/pipewire/keys.h:47
#define pw_array_get_len(a, t)
Get the number of items of type t in array.
Definition: array.h:62
struct spa_dict dict
dictionary of key/values
Definition: properties.h:50
#define SPA_CONTAINER_OF(p, t, m)
Definition: defs.h:170
#define PW_KEY_SEC_UID
Client uid, set by protocol.
Definition: src/pipewire/keys.h:56
void pw_global_add_listener(struct pw_global *global, struct spa_hook *listener, const struct pw_global_events *events, void *data)
Add an event listener on the global.
Definition: global.c:255
context events emitted by the context object added with pw_context_add_listener
Definition: context.h:72
Definition: src/pipewire/mem.h:99
void spa_list_remove(struct spa_list *elem)
Definition: list.h:69
void pw_resource_add_object_listener(struct pw_resource *resource, struct spa_hook *listener, const void *funcs, void *data)
Set the resource implementation.
Definition: resource.c:174
struct pw_global * pw_context_find_global(struct pw_context *context, uint32_t id)
Find a context global by id.
Definition: context.c:636
int fd
fd
Definition: src/pipewire/mem.h:84
struct spa_hook object_listener
Definition: impl-core.c:77
void(* busy_changed)(void *data, bool busy)
emitted when the client becomes busy processing an asynchronous message.
Definition: impl-client.h:113
struct spa_hook context_listener
Definition: module-access.c:143
#define pw_array_get_unchecked(a, idx, t)
Get the item with index idx and type t from array.
Definition: array.h:64
A hook, contains the structure with functions and the data passed to the functions.
Definition: hook.h:295
const struct spa_dict_item * items
Definition: utils/dict.h:52
uint32_t permissions
bitmask of above permissions
Definition: permission.h:66
#define PW_KEY_APP_NAME
application keys
Definition: src/pipewire/keys.h:108
#define PW_VERSION_RESOURCE_EVENTS
Definition: resource.h:61
#define PW_CLIENT_CHANGE_MASK_PROPS
Definition: client.h:57
The client information.
Definition: client.h:55
#define PW_VERSION_MEMPOOL_EVENTS
Definition: src/pipewire/mem.h:100
void pw_resource_add_listener(struct pw_resource *resource, struct spa_hook *listener, const struct pw_resource_events *events, void *data)
Add an event listener.
Definition: resource.c:165
#define PW_PERM_INVALID
Definition: permission.h:62
struct pw_context * context
Definition: module-protocol-native.c:105
Definition: impl-client.c:112
Definition: utils/dict.h:48
void(* free)(void *data)
emitted right before the client is freed
Definition: impl-client.h:96
int pw_global_update_keys(struct pw_global *global, const struct spa_dict *dict, const char *const keys[])
Update the global properties, must be done when unregistered.
Definition: global.c:209
void pw_impl_client_set_busy(struct pw_impl_client *client, bool busy)
Mark the client busy.
Definition: impl-client.c:716
#define PW_PERMISSION_INIT(id, p)
Definition: permission.h:69
const char * value
Definition: utils/dict.h:43
#define PW_ID_CORE
default ID for the core object after connect
Definition: core.h:66
struct pw_resource * pw_resource_new(struct pw_impl_client *client, uint32_t id, uint32_t permissions, const char *type, uint32_t version, size_t user_data_size)
Make a new resource for client.
Definition: resource.c:43
void(* initialized)(void *data)
the client is initialized
Definition: impl-client.h:99
Memory block structure.
Definition: src/pipewire/mem.h:78
#define pw_log_debug(...)
Definition: src/pipewire/log.h:89
int pw_impl_client_update_permissions(struct pw_impl_client *client, uint32_t n_permissions, const struct pw_permission *permissions)
Update the client permissions.
Definition: impl-client.c:646
Definition: module-protocol-native.c:103
void pw_global_destroy(struct pw_global *global)
Destroy a global.
Definition: global.c:369
#define PW_VERSION_GLOBAL_EVENTS
Definition: global.h:69
int pw_impl_client_check_permissions(struct pw_impl_client *client, uint32_t global_id, uint32_t permissions)
check if a client has permissions for global_id, Since 0.3.9
Definition: impl-client.c:726
int pw_properties_set(struct pw_properties *properties, const char *key, const char *value)
Set a property value.
Definition: properties.c:435
struct result_device_params_data data
Definition: impl-device.c:76
struct pw_protocol * pw_impl_client_get_protocol(struct pw_impl_client *client)
Get the protocol used to create this client.
Definition: impl-client.c:528
#define PW_ID_ANY
Definition: core.h:69
#define PW_KEY_SEC_GID
client gid, set by protocol
Definition: src/pipewire/keys.h:57
Client methods.
Definition: client.h:111
#define PW_TYPE_INTERFACE_Client
Definition: client.h:46
void pw_resource_error(struct pw_resource *resource, int res, const char *error)
Generate an error for a resource.
Definition: resource.c:255
void(* info_changed)(void *data, const struct pw_client_info *info)
emitted when the client info changed
Definition: impl-client.h:102
#define pw_log_warn(...)
Definition: src/pipewire/log.h:87
#define PW_VERSION_CLIENT_METHODS
Definition: client.h:112
struct pw_resource * pw_impl_client_get_core_resource(struct pw_impl_client *client)
Get the client core resource.
Definition: impl-client.c:534
struct pw_control this
Definition: control.c:34
#define PW_KEY_ACCESS
how the client access is controlled
Definition: src/pipewire/keys.h:48
struct pw_core * core
Definition: module-protocol-simple.c:107
void pw_impl_client_destroy(struct pw_impl_client *client)
Destroy a client object.
Definition: impl-client.c:577
void spa_hook_remove(struct spa_hook *hook)
Remove a hook.
Definition: hook.h:336
void * pw_resource_get_user_data(struct pw_resource *resource)
Get the user data for the resource, the size was given in pw_resource_new.
Definition: resource.c:159
void(* resource_removed)(void *data, struct pw_resource *resource)
emitted when a resource is removed
Definition: impl-client.h:108
uint32_t version
Definition: impl-client.h:90
#define PW_VERSION_CONTEXT_EVENTS
Definition: context.h:73
struct pw_resource * resource
Definition: impl-core.c:75
void spa_hook_list_init(struct spa_hook_list *list)
Initialize a hook list to the empty list.
Definition: hook.h:305
uint32_t n_items
Definition: utils/dict.h:51
int res
Definition: impl-client.c:114
#define PW_VERSION_CLIENT
Definition: client.h:48
void(* destroy)(void *data)
emitted when the client is destroyed
Definition: impl-client.h:93
struct pw_properties * pw_properties_new(const char *key,...) 1
Make a new properties object.
Definition: properties.c:98
uint32_t type
type of the fd, one of enum spa_data_type
Definition: src/pipewire/mem.h:83
Resource events.
Definition: resource.h:60
int pw_properties_setf(struct pw_properties *properties, const char *key, const char *format,...) 1(3
struct pw_resource * pw_impl_client_find_resource(struct pw_impl_client *client, uint32_t id)
Get a resource with the given id.
Definition: impl-client.c:540
uint32_t version
Definition: resource.h:62
#define PW_KEY_SEC_PID
Various keys related to the identity of a client process and its security.
Definition: src/pipewire/keys.h:55
struct spa_list link
link in impl client_list
Definition: module-protocol-simple.c:103
void pw_impl_client_add_listener(struct pw_impl_client *client, struct spa_hook *listener, const struct pw_impl_client_events *events, void *data)
listen to events from this client
Definition: impl-client.c:613
Definition: properties.h:49
void spa_hook_list_clean(struct spa_hook_list *list)
Remove all hooks from the list.
Definition: hook.h:344
uint32_t id
id of object, PW_ID_ANY for default permission
Definition: permission.h:65
void pw_properties_free(struct pw_properties *properties)
Free a properties object.
Definition: properties.c:364
#define PW_KEY_CLIENT_ACCESS
how the client wants to be access controlled
Definition: src/pipewire/keys.h:49
#define pw_log_error(...)
Definition: src/pipewire/log.h:86
struct pw_global * pw_impl_client_get_global(struct pw_impl_client *client)
Get the global associated with this client.
Definition: impl-client.c:546
#define spa_list_append(list, item)
Definition: list.h:81
const struct pw_properties * pw_impl_client_get_properties(struct pw_impl_client *client)
Get the client properties.
Definition: impl-client.c:552