source: products/quintagroup.plonegooglesitemaps/branches/1.7.1/quintagroup/plonegooglesitemaps/browser/configletview.py @ 3398

Last change on this file since 3398 was 3398, checked in by potar, 12 years ago

Rewrote code according with pep8

  • Property svn:eol-style set to native
File size: 6.5 KB
Line 
1from zope.component import queryMultiAdapter
2from zope.interface import implements, Interface, Attribute
3
4from OFS.Image import cookId
5from OFS.ObjectManager import BadRequestException
6from Products.Five import BrowserView
7
8
9def splitNum(num):
10    res = []
11    prefn = 3
12    for c in str(num)[::-1]:
13        res.insert(0, c)
14        if not len(res) % prefn:
15            res.insert(0, ',')
16            prefn += 4
17    return "".join(res[0] == ',' and res[1:] or res)
18
19
20class IConfigletSettingsView(Interface):
21    """
22    Sitemap view interface
23    """
24
25    sitemaps = Attribute("Returns mapping of sitemap's type to list of " \
26                         "appropriate objects")
27    hasContentSM = Attribute("Returns boolean about existance of content " \
28                             "sitemap")
29    hasMobileSM = Attribute("Returns boolean about existance of mobile " \
30                            "sitemap")
31    hasNewsSM = Attribute("Returns boolean about existance of news sitemap")
32    sm_types = Attribute("List of sitemap types")
33
34    def sitemapsDict():
35        """ Return dictionary like object with data for table
36        """
37    def sitemapsURLByType():
38        """ Return dictionary like object with sitemap_type as key
39            and sitemap object(s) as value
40        """
41    def getVerificationFiles():
42        """ Return list of existent verification files on site.
43            Update googlesitemap_properties.verification_file
44            property for only existent files
45        """
46
47    def uploadVerificationFile(vfile):
48        """ Upload passed site verification file to the site.
49            On success - update googlesitemaps verification files list.
50            Return tuple where :
51              1. boolean value - is verification file successfully created.
52              2. string value:
53                2.1. if successfull - id of created verification file
54                2.2. if failure - error descirption
55        """
56
57
58class ConfigletSettingsView(BrowserView):
59    """
60    Configlet settings browser view
61    """
62    implements(IConfigletSettingsView)
63    sitemaps = []
64
65    def __init__(self, context, request):
66        self.context = context
67        self.request = request
68
69        self.tools = queryMultiAdapter((self.context, self.request),
70                                       name="plone_tools")
71        self.pps = queryMultiAdapter((self.context, self.request),
72                                     name="plone_portal_state")
73        self.sitemaps = [i.getObject() for i in \
74                         self.tools.catalog()(portal_type='Sitemap')]
75    @property
76    def sm_types(self):
77        return [i.getSitemapType() for i in self.sitemaps]
78
79    @property
80    def hasContentSM(self):
81        return 'content' in self.sm_types
82
83    @property
84    def hasMobileSM(self):
85        return 'mobile' in self.sm_types
86
87    @property
88    def hasNewsSM(self):
89        return 'news' in self.sm_types
90
91    def sitemapsURLByType(self):
92        sitemaps = {}
93        for sm in self.sitemaps:
94            smlist = sitemaps.setdefault(sm.getSitemapType(), [])
95            smlist.append({'url': sm.absolute_url(), 'id': sm.id})
96        sitemaps['all'] = sitemaps.setdefault('content', []) + \
97                          sitemaps.setdefault('mobile', []) + \
98                          sitemaps.setdefault('news', [])
99        return sitemaps
100
101    def sitemapsURLs(self):
102        sitemaps = {}
103        for sm in self.sitemaps:
104            smlist = sitemaps.setdefault(sm.getSitemapType(), [])
105            smlist.append(sm.absolute_url())
106        return sitemaps
107
108    def sitemapsDict(self):
109        content, mobile, news = [], [], []
110        for sm in self.sitemaps:
111            data = self.getSMData(sm)
112            if data['sm_type'] == 'Content':
113                content.append(data)
114            elif data['sm_type'] == 'Mobile':
115                mobile.append(data)
116            elif data['sm_type'] == 'News':
117                news.append(data)
118        return content + mobile + news
119
120    def getSMData(self, ob):
121        size, entries = self.getSitemapData(ob)
122        return {'sm_type': ob.getSitemapType().capitalize(),
123                'sm_id': ob.id,
124                'sm_url': ob.absolute_url(),
125                'sm_size': size and splitNum(size) or '',
126                'sm_entries': entries and splitNum(entries) or '',
127               }
128
129    def getSitemapData(self, ob):
130        size, entries = (0, 0)
131        view = ob and ob.defaultView() or None
132        if view:
133            self.request.RESPONSE
134            bview = queryMultiAdapter((ob, self.request), name=view)
135            if bview:
136                try:
137                    size = len(bview())
138                    entries = bview.numEntries
139                    self.request.RESPONSE.setHeader('Content-Type',
140                                                    'text/html')
141                except:
142                    pass
143        return (size, entries)
144
145    def deleteVerificationFile(self):
146        portal = self.pps.portal()
147        portal.manage_delObjects([self.request.id, ])
148        if 'HTTP_REFERER' in self.request.keys():
149            url = self.request.HTTP_REFERER
150        else:
151            url = self.context + 'prefs_gsm_verification'
152        self.request.RESPONSE.redirect(url)
153
154    def getVerificationFiles(self):
155        vfs = []
156        props = getattr(self.tools.properties(), 'googlesitemap_properties')
157        portal = self.pps.portal()
158        if props:
159            portal_ids = portal.objectIds()
160            props_vfs = list(props.getProperty('verification_filenames', []))
161
162            vfs = [vf for vf in props_vfs if vf in portal_ids]
163            if not props_vfs == vfs:
164                props._updateProperty('verification_filenames', vfs)
165
166        return [{'id': x, 'title': portal[x].title} for x in vfs]
167
168    def uploadVerificationFile(self, request):
169        vfilename = ""
170        portal = self.pps.portal()
171        try:
172            comment = request.get("comment")
173            vfile = request.get("verification_file")
174            vfilename, vftitle = cookId("", "", vfile)
175            portal.manage_addFile(id="", file=vfile, title=comment)
176            portal[vfilename].manage_addProperty(
177                'CreatedBy', 'quintagroupt.plonegooglesitemaps', 'string')
178        except BadRequestException, e:
179            return False, str(e)
180        else:
181            props = self.tools.properties().googlesitemap_properties
182            vfilenames = list(props.getProperty('verification_filenames', []))
183            vfilenames.append(vfilename)
184            props.manage_changeProperties(verification_filenames=vfilenames)
185        return True, vfilename
Note: See TracBrowser for help on using the repository browser.