2 * @author Hallyson Melo <hallyson.melo@indt.org.br>
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU Lesser General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
27 #include <libgnomevfs/gnome-vfs-module.h>
28 #include <libgnomevfs/gnome-vfs-utils.h>
30 #include "gmyth_file_transfer.h"
31 #include "gmyth_backendinfo.h"
33 #define GST_MYTHTV_ID_NUM 1
34 #define MYTHTV_VERSION_DEFAULT 30
36 #define MYTHTV_BUFFER_SIZE 1024*64
38 static GnomeVFSResult do_read (GnomeVFSMethod *method,
39 GnomeVFSMethodHandle *method_handle,
41 GnomeVFSFileSize num_bytes,
42 GnomeVFSFileSize *bytes_read,
43 GnomeVFSContext *context);
46 GMythFileTransfer *file_transfer;
59 do_open (GnomeVFSMethod *method,
60 GnomeVFSMethodHandle **method_handle,
62 GnomeVFSOpenMode mode,
63 GnomeVFSContext *context)
65 MythtvHandle *myth_handle;
66 GMythBackendInfo *backend_info;
69 _GNOME_VFS_METHOD_PARAM_CHECK (method_handle != NULL);
70 _GNOME_VFS_METHOD_PARAM_CHECK (uri != NULL);
72 myth_handle = g_new0 (MythtvHandle, 1);
74 if (mode & GNOME_VFS_OPEN_WRITE) {
75 return GNOME_VFS_ERROR_NOT_PERMITTED;
78 if (gnome_vfs_uri_get_host_name (uri) == NULL) {
79 return GNOME_VFS_ERROR_INVALID_HOST_NAME;
82 /* Initialize mythtv handler*/
83 myth_handle->file_transfer = NULL;
84 myth_handle->mythtv_version = MYTHTV_VERSION_DEFAULT;
85 myth_handle->bytes_read = 0;
86 myth_handle->content_size = -1;
88 /* Creates and fills out the backend info structure */
89 backend_info = gmyth_backend_info_new_full (
90 gnome_vfs_uri_get_host_name (uri),
92 gnome_vfs_uri_get_host_port (uri));
94 /* Connect to the backend */
95 myth_handle->file_transfer = gmyth_file_transfer_new (backend_info);
97 g_return_val_if_fail (myth_handle->file_transfer != NULL, GNOME_VFS_ERROR_NOT_OPEN);
99 /* sets the Playback monitor connection */
100 ret = gmyth_file_transfer_open (myth_handle->file_transfer, gnome_vfs_uri_get_path (uri));
102 g_warning ("Mythtv FileTransfer open error\n");
103 return GNOME_VFS_ERROR_NOT_OPEN;
106 // TODO: Verify if file exists in the backend
108 myth_handle->content_size = myth_handle->file_transfer->filesize;
110 myth_handle->buffer = g_byte_array_sized_new (MYTHTV_BUFFER_SIZE);
111 myth_handle->buffer_remain = 0;
113 *method_handle = (GnomeVFSMethodHandle *) myth_handle;
118 static GnomeVFSResult
119 do_read (GnomeVFSMethod *method,
120 GnomeVFSMethodHandle *method_handle,
122 GnomeVFSFileSize num_bytes,
123 GnomeVFSFileSize *bytes_read,
124 GnomeVFSContext *context)
126 MythtvHandle *myth_handle = (MythtvHandle *) method_handle;
127 GnomeVFSFileSize bytes_to_read;
131 if (myth_handle->bytes_read >= myth_handle->content_size)
132 return GNOME_VFS_ERROR_EOF;
134 // fixme: change this to min math function
135 if (num_bytes > myth_handle->content_size - myth_handle->bytes_read)
136 bytes_to_read = myth_handle->content_size - myth_handle->bytes_read;
138 bytes_to_read = num_bytes;
140 /* Loop sending the Myth File Transfer request:
141 * Retry whilst authentication fails and we supply it. */
143 if ( bytes_to_read > myth_handle->buffer_remain ) {
144 GByteArray *tmp_buffer = g_byte_array_new();
146 gint len = gmyth_file_transfer_read (myth_handle->file_transfer,
147 tmp_buffer, MYTHTV_BUFFER_SIZE - myth_handle->buffer_remain, TRUE);
150 g_byte_array_free (tmp_buffer, TRUE);
151 g_warning ("Fail to read bytes");
152 return GNOME_VFS_ERROR_IO;
155 myth_handle->buffer = g_byte_array_append (myth_handle->buffer,
156 tmp_buffer->data, len);
158 myth_handle->buffer_remain += len;
160 g_byte_array_free (tmp_buffer, TRUE);
164 bytes_to_read = (bytes_to_read > myth_handle->buffer_remain) ? myth_handle->buffer_remain : bytes_to_read;
165 /* gets the first buffer_size bytes from the byte array buffer variable */
167 g_memmove (buffer, myth_handle->buffer->data, bytes_to_read);
169 myth_handle->bytes_read += bytes_to_read;
170 myth_handle->buffer_remain -= bytes_to_read;
172 /* flushs the newly buffer got from byte array */
173 myth_handle->buffer = g_byte_array_remove_range (myth_handle->buffer, 0, bytes_to_read);
174 *bytes_read = bytes_to_read;
179 static GnomeVFSResult
180 do_close (GnomeVFSMethod *method,
181 GnomeVFSMethodHandle *method_handle,
182 GnomeVFSContext *context)
185 MythtvHandle *myth_handle = (MythtvHandle *) method_handle;
187 if (myth_handle->file_transfer) {
188 gmyth_file_transfer_close (myth_handle->file_transfer);
189 g_object_unref (myth_handle->file_transfer);
190 myth_handle->file_transfer = NULL;
193 if (myth_handle->buffer) {
194 g_byte_array_free (myth_handle->buffer, TRUE);
195 myth_handle->buffer = NULL;
198 g_free (myth_handle);
203 static GnomeVFSResult
204 do_get_file_info (GnomeVFSMethod *method,
206 GnomeVFSFileInfo *file_info,
207 GnomeVFSFileInfoOptions options,
208 GnomeVFSContext *context)
210 file_info->name = g_strdup ("fixme.txt");
211 file_info->valid_fields = file_info->valid_fields
212 | GNOME_VFS_FILE_INFO_FIELDS_TYPE
213 | GNOME_VFS_FILE_INFO_FIELDS_MIME_TYPE
214 | GNOME_VFS_FILE_INFO_FIELDS_PERMISSIONS;
215 file_info->type = GNOME_VFS_FILE_TYPE_REGULAR;
216 // fixme: get from file extension?
217 file_info->mime_type = g_strdup ("video/x-nuv");
218 file_info->permissions =
219 GNOME_VFS_PERM_USER_READ |
220 GNOME_VFS_PERM_OTHER_READ |
221 GNOME_VFS_PERM_GROUP_READ;
227 do_is_local (GnomeVFSMethod *method,
228 const GnomeVFSURI *uri)
233 static GnomeVFSMethod method = {
234 sizeof (GnomeVFSMethod),
265 vfs_module_init (const char *method_name, const char *args)
271 vfs_module_shutdown (GnomeVFSMethod *method)