diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-10-24 17:07:43 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-10-24 17:07:43 +0700 |
| commit | da1ba5223456e4c39d11a5af67968dda6d569c6b (patch) | |
| tree | 310eaa29f5982767e6685c2ca263f24fba72645e /indoteknik_api/models/blog_post.py | |
| parent | 646f9557c101bd6b8ed81fc46130e9761957b5c1 (diff) | |
| parent | 1934b5ca55840deb2a4369ef6ab0affd86e2ba8f (diff) | |
Merge commit '1934b5ca55840deb2a4369ef6ab0affd86e2ba8f'
Diffstat (limited to 'indoteknik_api/models/blog_post.py')
| -rw-r--r-- | indoteknik_api/models/blog_post.py | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/indoteknik_api/models/blog_post.py b/indoteknik_api/models/blog_post.py new file mode 100644 index 00000000..2a82c23c --- /dev/null +++ b/indoteknik_api/models/blog_post.py @@ -0,0 +1,44 @@ +from odoo import models +from pytz import timezone + + +class BlogPost(models.Model): + _inherit = 'blog.post' + + def api_single_response(self, blog, with_detail=False): + base_url = self.env['ir.config_parameter'].get_param('web.base.url') + data = { + 'id': blog.id, + 'thumbnail': base_url + 'api/image/blog.post/thumbnail/' + str(blog.id) if blog.thumbnail else '', + 'title': blog.name, + 'category': {}, + 'author': {}, + 'post_date': blog.post_date.astimezone(timezone('Asia/Jakarta')).strftime('%d/%m/%Y') or '', + } + if blog.blog_id: + data['category'] = { + 'id': blog.blog_id.id, + 'name': blog.blog_id.name, + } + if blog.author_id: + data['author'] = { + 'id': blog.author_id.id, + 'name': blog.author_id.name + } + if with_detail: + data_with_detail = { + 'meta': { + 'title': blog.website_meta_title, + 'description': blog.website_meta_description, + 'keywords': blog.website_meta_keywords + }, + 'tags': [], + 'content': blog.content, + } + for tag in blog.tag_ids: + data_with_detail['tags'].append({ + 'id': tag.id, + 'name': tag.name, + }) + data.update(data_with_detail) + return data
\ No newline at end of file |
