[PATCH v4 7/9] views: Expose Series mbox

Daniel Axtens dja at axtens.net
Thu Mar 23 13:00:06 AEDT 2017


Hi Stephen,

Looks good to me.

Reviewed-by: Daniel Axtens <dja at axtens.net>

Regards,
Daniel

Stephen Finucane <stephen at that.guru> writes:

> It is possible to download a patch mbox with all dependencies. Now make
> it possible to download the entire series. This takes the form of the
> following URL when using the default routes:
>
>     /series/{seriesID}/mbox/
>
> Like the equivalent patch and bundle links, this will return a 404 if
> '{seriesID}' does not match an existing series' ID. However, a 404 will
> also be returned in the series is not complete, as indicated by
> Series.total > Series.received_total. You can override this behavior by
> providing the 'force' parameter:
>
>     /series/{seriesID}/mbox/?force=1
>
> Note that there are no current plans to provide a series-specific view,
> a.k.a.
>
>     /series/{seriesID}/
>
> As a result, this particular URL will continue to return a 404.
>
> Signed-off-by: Stephen Finucane <stephen at that.guru>
> ---
> v3:
> - Correct license header
> ---
>  patchwork/models.py       |  6 ++++++
>  patchwork/urls.py         |  7 ++++++-
>  patchwork/views/series.py | 35 +++++++++++++++++++++++++++++++++++
>  patchwork/views/utils.py  | 17 +++++++++++++++++
>  4 files changed, 64 insertions(+), 1 deletion(-)
>  create mode 100644 patchwork/views/series.py
>
> diff --git a/patchwork/models.py b/patchwork/models.py
> index 94aaa0f..22ab522 100644
> --- a/patchwork/models.py
> +++ b/patchwork/models.py
> @@ -589,6 +589,12 @@ class Series(models.Model):
>      def received_all(self):
>          return self.total <= self.received_total
>  
> +    @property
> +    def filename(self):
> +        fname_re = re.compile(r'[^-_A-Za-z0-9\.]+')
> +        fname = fname_re.sub('-', str(self))
> +        return fname.strip('-') + '.patch'
> +
>      def add_cover_letter(self, cover):
>          """Add a cover letter to the series.
>  
> diff --git a/patchwork/urls.py b/patchwork/urls.py
> index 7a8ea95..ef283c0 100644
> --- a/patchwork/urls.py
> +++ b/patchwork/urls.py
> @@ -32,6 +32,7 @@ from patchwork.views import notification as notification_views
>  from patchwork.views import patch as patch_views
>  from patchwork.views import project as project_views
>  from patchwork.views import pwclient as pwclient_views
> +from patchwork.views import series as series_views
>  from patchwork.views import user as user_views
>  from patchwork.views import xmlrpc as xmlrpc_views
>  
> @@ -61,10 +62,14 @@ urlpatterns = [
>      url(r'^cover/(?P<cover_id>\d+)/$', cover_views.cover_detail,
>          name='cover-detail'),
>  
> -    # comment urls
> +    # comment views
>      url(r'^comment/(?P<comment_id>\d+)/$', comment_views.comment,
>          name='comment-redirect'),
>  
> +    # series views
> +    url(r'^series/(?P<series_id>\d+)/mbox/$', series_views.series_mbox,
> +        name='series-mbox'),
> +
>      # logged-in user stuff
>      url(r'^user/$', user_views.profile, name='user-profile'),
>      url(r'^user/todo/$', user_views.todo_lists,
> diff --git a/patchwork/views/series.py b/patchwork/views/series.py
> new file mode 100644
> index 0000000..a59bffd
> --- /dev/null
> +++ b/patchwork/views/series.py
> @@ -0,0 +1,35 @@
> +# Patchwork - automated patch tracking system
> +# Copyright (C) 2017 Stephen Finucane <stephen at that.guru>
> +#
> +# This file is part of the Patchwork package.
> +#
> +# Patchwork is free software; you can redistribute it and/or modify
> +# it under the terms of the GNU General Public License as published by
> +# the Free Software Foundation; either version 2 of the License, or
> +# (at your option) any later version.
> +#
> +# Patchwork 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 General Public License for more details.
> +#
> +# You should have received a copy of the GNU General Public License
> +# along with Patchwork; if not, write to the Free Software
> +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
> +
> +from django.http import HttpResponse
> +from django.shortcuts import get_object_or_404
> +
> +from patchwork.models import Series
> +from patchwork.views.utils import series_to_mbox
> +
> +
> +def series_mbox(request, series_id):
> +    series = get_object_or_404(Series, id=series_id)
> +
> +    response = HttpResponse(content_type='text/plain')
> +    response.write(series_to_mbox(series))
> +    response['Content-Disposition'] = 'attachment; filename=' + \
> +        series.filename.replace(';', '').replace('\n', '')
> +
> +    return response
> diff --git a/patchwork/views/utils.py b/patchwork/views/utils.py
> index f936ed8..49d9c0c 100644
> --- a/patchwork/views/utils.py
> +++ b/patchwork/views/utils.py
> @@ -151,3 +151,20 @@ def series_patch_to_mbox(patch, series_num):
>      mbox.append(patch_to_mbox(patch))
>  
>      return '\n'.join(mbox)
> +
> +
> +def series_to_mbox(series):
> +    """Get an mbox representation of an entire series.
> +
> +    Arguments:
> +        series: The Series object to convert.
> +
> +    Returns:
> +        A string for the mbox file.
> +    """
> +    mbox = []
> +
> +    for dep in series.seriespatch_set.all():
> +        mbox.append(patch_to_mbox(dep.patch))
> +
> +    return '\n'.join(mbox)
> -- 
> 2.9.3
>
> _______________________________________________
> Patchwork mailing list
> Patchwork at lists.ozlabs.org
> https://lists.ozlabs.org/listinfo/patchwork


More information about the Patchwork mailing list