Qpid Proton C API 0.39.0
 
Loading...
Searching...
No Matches
session.h
Go to the documentation of this file.
1#ifndef PROTON_SESSION_H
2#define PROTON_SESSION_H 1
3
4/*
5 *
6 * Licensed to the Apache Software Foundation (ASF) under one
7 * or more contributor license agreements. See the NOTICE file
8 * distributed with this work for additional information
9 * regarding copyright ownership. The ASF licenses this file
10 * to you under the Apache License, Version 2.0 (the
11 * "License"); you may not use this file except in compliance
12 * with the License. You may obtain a copy of the License at
13 *
14 * http://www.apache.org/licenses/LICENSE-2.0
15 *
16 * Unless required by applicable law or agreed to in writing,
17 * software distributed under the License is distributed on an
18 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
19 * KIND, either express or implied. See the License for the
20 * specific language governing permissions and limitations
21 * under the License.
22 *
23 */
24
25#include <proton/import_export.h>
26#include <proton/type_compat.h>
27#include <proton/types.h>
28#include <proton/error.h>
29#include <proton/condition.h>
30#include <stddef.h>
31
32#ifdef __cplusplus
33extern "C" {
34#endif
35
54PN_EXTERN pn_session_t *pn_session(pn_connection_t *connection);
55
66PN_EXTERN void pn_session_free(pn_session_t *session);
67
78PN_EXTERN void *pn_session_get_context(pn_session_t *session);
79
89PN_EXTERN void pn_session_set_context(pn_session_t *session, void *context);
90
98
106
126/* PN_DEPRECATED("Use pn_session_condition") */
128
146
162
173
182PN_EXTERN void pn_session_open(pn_session_t *session);
183
194PN_EXTERN void pn_session_close(pn_session_t *session);
195
206
224PN_EXTERN void pn_session_set_incoming_capacity(pn_session_t *session, size_t capacity);
225
233
240PN_EXTERN void pn_session_set_outgoing_window(pn_session_t *session, size_t window);
241
248PN_EXTERN size_t pn_session_outgoing_bytes(pn_session_t *session);
249
256PN_EXTERN size_t pn_session_incoming_bytes(pn_session_t *session);
257
275
291
296#ifdef __cplusplus
297}
298#endif
299
300#endif /* session.h */
An endpoint error state.
A Proton API error.
struct pn_condition_t pn_condition_t
An AMQP Condition object.
Definition: condition.h:64
struct pn_connection_t pn_connection_t
An AMQP Connection object.
Definition: types.h:285
int pn_state_t
Holds the state flags for an AMQP endpoint.
Definition: types.h:271
struct pn_error_t pn_error_t
An int error code and some string text to describe the error.
Definition: error.h:44
pn_condition_t * pn_session_remote_condition(pn_session_t *session)
Get the remote condition associated with the session endpoint.
void pn_session_free(pn_session_t *session)
Free a session object.
void pn_session_close(pn_session_t *session)
Close a session.
size_t pn_session_get_incoming_capacity(pn_session_t *session)
Get the incoming capacity of the session measured in bytes.
pn_connection_t * pn_session_connection(pn_session_t *session)
Get the parent connection for a session object.
pn_session_t * pn_session_head(pn_connection_t *connection, pn_state_t state)
Retrieve the first session from a given connection that matches the specified state mask.
void pn_session_open(pn_session_t *session)
Open a session.
pn_record_t * pn_session_attachments(pn_session_t *session)
Get the attachments that are associated with a session object.
void pn_session_set_context(pn_session_t *session, void *context)
Set a new application context for a session object.
struct pn_session_t pn_session_t
An AMQP Session object.
Definition: types.h:296
size_t pn_session_incoming_bytes(pn_session_t *session)
Get the number of incoming bytes currently buffered by a session.
pn_session_t * pn_session_next(pn_session_t *session, pn_state_t state)
Retrieve the next session from a given connection that matches the specified state mask.
pn_condition_t * pn_session_condition(pn_session_t *session)
Get the local condition associated with the session endpoint.
pn_state_t pn_session_state(pn_session_t *session)
Get the endpoint state flags for a session.
size_t pn_session_get_outgoing_window(pn_session_t *session)
Get the outgoing window for a session object.
void * pn_session_get_context(pn_session_t *session)
Get the application context that is associated with a session object.
size_t pn_session_outgoing_bytes(pn_session_t *session)
Get the number of outgoing bytes currently buffered by a session.
void pn_session_set_outgoing_window(pn_session_t *session, size_t window)
Set the outgoing window for a session object.
pn_error_t * pn_session_error(pn_session_t *session)
Deprecated - Use pn_session_condition().
void pn_session_set_incoming_capacity(pn_session_t *session, size_t capacity)
Set the incoming capacity for a session object.
pn_session_t * pn_session(pn_connection_t *connection)
Factory for creating a new session on a given connection object.
AMQP and API data types.
struct pn_record_t pn_record_t
A type representing attached context information.
Definition: types.h:477