summaryrefslogtreecommitdiff
path: root/src/lib.h
blob: 0fb3f0293b560f339e23eb0a7258c76c07e8e954 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/*
 * vim: set sts=2 sw=2 et :
 *
 * License: LGPL-2.1+
 * Copyright (c) 2014 Nirbheek Chauhan <nirbheek@centricular.com>
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Library General Public
 * License as published by the Free Software Foundation; either
 * version 2 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
 * Library General Public License for more details.
 *
 * You should have received a copy of the GNU Library General Public
 * License along with this library; if not, write to the
 * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
 * Boston, MA 02110-1301, USA.
 */

#ifndef _SST_LIB
#define _SST_LIB

#include <glib.h>
#include <gst/gst.h>
#include <libsoup/soup.h>

typedef struct _TranscodeServerCtx TranscodeServerCtx;
typedef struct _TranscodeClientCtx TranscodeClientCtx;

struct _TranscodeServerCtx {
  SoupMessage *msg;
  GstElement *pipeline;
  GstElement *appsrc;
  /* If the encoding is not chunked, we'll get multiple requests
   * with separate Content-Length headers on the same path */
  SoupEncoding encoding;
  /* Set to TRUE when the incoming stream ends; let's us know if
   * we need to set the PUT response on EOS/ERROR on the pipeline,
   * and whether to reject further data when using a persistent
   * Content-Length + Content-Range PUT stream. */
  gboolean stream_finished;
  guint seconds_since_read;

  /* List of client contexts */
  GList *clients;
  /* Reference to the parent context hash table */
  GHashTable *parent_ctx_table;
  /* Reference to the key in the parent hash table */
  char *path;
};

struct _TranscodeClientCtx {
  SoupMessage *msg;
  GstElement *appsink; /* We hold an extra ref to this */
  GstPad *ghostsinkpad;

  GMutex can_write_chunk;
  guint timeout_handler_id;
  guint seconds_since_write;
  /* The transcode server context; we don't hold a ref to this */
  TranscodeServerCtx *server_ctx;
};

void stp_cleanup_transcode_server_ctx (TranscodeServerCtx *ctx);
void stp_cleanup_transcode_client_ctx (TranscodeClientCtx *ctx);
void stp_close_client_ctx (TranscodeClientCtx *ctx);

gboolean stp_on_gst_bus_message (GstBus             *bus,
                                 GstMessage         *msg,
                                 TranscodeServerCtx *ctx);

gboolean stp_copy_chunk_to_fd (SoupBuffer *chunk,
                               int         fd);
gboolean stp_copy_fd_to_body (TranscodeClientCtx *ctx);
gboolean stp_fd_has_data_to_read (int fd);

GstBuffer* stp_get_streamheader_from_caps (GstCaps *caps);
GstBuffer* stp_get_gst_buffer (SoupBuffer *chunk);

#endif /* _SST_LIB */