Skip to Content
Odoo मेन्यू
  • Sign in
  • मुफ़्त में आज़माएं
  • ऐप्लिकेशन
    फ़ाइनेंस
    • अकाउंटिंग
    • इनवॉइसिंग
    • एक्सपेंस
    • स्प्रेडशीट (बीआई)
    • डॉक्यूमेंट्स
    • साइन
    सेल्स
    • सीआरएम
    • सेल्स
    • पीओएस शॉप
    • पीओएस रेस्टोरेंट
    • सब्सक्रिप्शन
    • रेंटल
    वेबसाइट
    • वेबसाइट बिल्डर
    • ई-कॉमर्स
    • ब्लॉग
    • फ़ोरम
    • लाइव चैट
    • ई-लर्निंग
    सप्लाई चेन
    • इन्वेंट्री
    • मैन्युफ़ैक्चरिंग
    • पीएलएम
    • परचेज़
    • मेंटेनेंस
    • क्वालिटी
    मानव संसाधन
    • कर्मचारी
    • रिक्रूटमेंट
    • टाइम ऑफ़
    • अप्रेज़ल
    • रेफ़रल
    • फ़्लीट
    मार्केटिंग
    • सोशल मार्केटिंग
    • ईमेल मार्केटिंग
    • एसएमएस मार्केटिंग
    • इवेंट
    • मार्केटिंग ऑटोमेशन
    • सर्वे
    सेवाएं
    • प्रोजेक्ट
    • टाइमशीट
    • फ़ील्ड सर्विस
    • हेल्पडेस्क
    • प्लानिंग
    • अपॉइंटमेंट
    प्रॉडक्टिविटी
    • डिस्कस
    • अप्रूवल
    • आईओटी
    • वीओआईपी
    • नॉलेज
    • WhatsApp
    तीसरे पक्ष के ऐप्लिकेशन Odoo स्टूडियो Odoo क्लाउड प्लेटफ़ॉर्म
  • इंडस्ट्री
    रीटेल
    • बुक स्टोर
    • क्लोदिंग स्टोर
    • फ़र्नीचर स्टोर
    • ग्रॉसरी स्टोर
    • हार्डवेयर स्टोर
    • टॉय स्टोर
    Food & Hospitality
    • बार और पब
    • रेस्टोरेंट
    • फ़ास्ट फ़ूड
    • Guest House
    • बेवरिज डिस्ट्रीब्यूटर
    • होटल
    रियल एस्टेट
    • Real Estate Agency
    • आर्किटेक्चर फ़र्म
    • कंसट्रक्शन
    • एस्टेट मैनेजमेंट
    • गार्ड्निंग
    • प्रॉपर्टी ओनर असोसिएशन
    कंसल्टिंग
    • अकाउंटिंग फ़र्म
    • Odoo पार्टनर
    • मार्केटिंग एजेंसी
    • लॉ फ़र्म
    • टैलेंट ऐक्विज़िशन
    • ऑडिट & सर्टिफ़िकेशन
    मैन्युफ़ैक्चरिंग
    • टेक्सटाइल
    • Metal
    • फ़र्नीचर
    • फ़ूड
    • Brewery
    • कॉर्पोरेट गिफ़्ट
    हेल्थ & फिटनेस
    • स्पोर्ट्स क्लब
    • आईवियर स्टोर
    • फिटनेस सेंटर
    • वेलनेस प्रैक्टिशनर
    • फॉर्मेसी
    • हेयर सैलून
    Trades
    • Handyman
    • आईटी हॉर्डवेयर और सपोर्ट
    • Solar Energy Systems
    • Shoe Maker
    • Cleaning Services
    • HVAC Services
    अन्य
    • Nonprofit Organization
    • एन्वायरमेंटल एजेंसी
    • बिलबोर्ड रेंटल
    • फ़ोटोग्राफी
    • बाइक लीजिंग
    • सॉफ़्टवेयर रीसेलर
    Browse all Industries
  • कम्यूनिटी
    सीखें
    • ट्यूटोरियल्स
    • दस्तावेज़
    • सर्टिफ़िकेशन
    • ट्रेनिंग
    • ब्लॉग
    • पॉडकास्ट
    शिक्षा को बढ़ावा दें
    • एजुकेशन प्रोग्राम
    • स्केल अप! बिजनेस गेम
    • Odoo के ऑफ़िस में आएं
    सॉफ़्टवेयर पाएं
    • डाउनलोड
    • वर्शन की तुलना करें
    • रिलीज़
    साथ मिलकर काम करें
    • Github
    • फ़ोरम
    • इवेंट
    • अनुवाद
    • पार्टनर बनें
    • Services for Partners
    • अपना अकाउंटिंग फ़र्म रजिस्टर करें
    सेवाएं पाएं
    • पार्टनर ढूंढें
    • अकाउंटेंट खोजें
    • सलाहकार की मदद लें
    • इम्प्लिमेंटेशन सेवाएं
    • कस्टमर रेफ़रेंस
    • सहायता
    • अपग्रेड
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    डेमो देखें
  • कीमत
  • सहायता

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • सीआरएम
  • e-Commerce
  • लेखांकन
  • इन्वेंटरी
  • PoS
  • प्रोजेक्ट
  • MRP
All apps
You need to be registered to interact with the community.
All Posts People Badges
टैग (View all)
odoo accounting v14 pos v15
About this forum
You need to be registered to interact with the community.
All Posts People Badges
टैग (View all)
odoo accounting v14 pos v15
About this forum
Help

How to Create a Schedule Button Using ir.cron

Subscribe

Get notified when there's activity on this post

This question has been flagged
ir.cronscheduleodoo16features
1628 Views
Avatar
Arif Munandar

hey everyone,

Can you help me, here I tried to create a schedule button for posting salary, but here I encountered many errors. The most dominant error is in the model_id and looping for the transaction does not run so as skipped it immediately displays the successful posting process. Can you guys correct any of my program code that I need to fix. Thank

class BSDPosting(models.Model):    
​_name = 'bsd.posting'   
​_description = 'BSD Posting'
​nama = fields.Char(string='Nama Transaksi', required=True)   
​date_from = fields.Date(string='Date From', required=True)   
​date_to = fields.Date(string='Date To', required=True)   
​posting_date = ​fields.Datetime(required=True, string='Waktu Mulai')
​def action_schedule_posting(self):       
      ​posting_date = self.posting_date       
​ ​code_model = "env['bsd.posting'].action_posting_gaji()" 
​ ​self.env['ir.cron'].sudo().create({
​ ​ ​'name': 'Posting Take Home Pay',
​ ​ ​'model_id': self.env.ref('bsd_payroll.model_bsd_posting').id, 
​ ​ ​'state': 'code',
​ ​ ​'code': code_model,
​ ​ ​'nextcall': posting_date,           
​ ​ ​'interval_type': 'days',           
​ ​ ​'numbercall': 1,           
​ ​ ​'active': True,})
    def action_posting_gaji(self):               
​ ​client_secret = "CLIENT SECRET"       
​ ​api = "URL API"       
​ ​path = ["api/auth",               
​ ​ ​"api/tabungan/info",               
​ ​ ​"api/trans/setoran/coa",           
​ ​ ​"api/trans/penarikan/coa",             
​ ​ ​"api/trans/setoran/tab"]
​ ​endpoint = f'{api}{path[0]}'       
​ ​endpoint_setoran_coa = f'{api}{path[2]}'
​ ​date_from_str = fields.Date.to_string(fields.Date.today().replace(day=1))       
​ ​date_to_str = fields.Date.to_string((datetime.now().date() + relativedelta(months=1, day=1, days=-1)))
      ​date_from = datetime.strptime(date_from_str, '%Y-%m-%d').date()
​ ​date_to = datetime.strptime(date_to_str, '%Y-%m-%d').date()
​ ​date_from_formatted = date_from.strftime('%Y-%m-%d')
​ ​date_to_formatted = date_to.strftime('%Y-%m-%d')
​ ​domain = [('struct_id', '=', 5),
​ ​('date_from', '>=',date_from_formatted),
​ ​('date_to',' ​ ​​def get_net_wage_by_employee(get_net_wage_by_periode):
​ ​ ​net_wage_by_employee = {}           
​ ​ ​for payslip in get_net_wage_by_periode:               
​ ​ ​ ​norek = payslip.get('x_norek')               
​ ​ ​ ​net_wage = payslip.get('net_wage')               
​ ​ ​ ​if norek and net_wage:                   
​ ​ ​ ​ ​net_wage_str =str(net_wage).rstrip('0').rstrip('.')                    ​ ​net_wage_by_employee[norek] = net_wage_str                    ​ ​ ​net_wage_int = int(net_wage_str)
​ ​ ​ ​ ​net_wage_by_employee[norek] = net_wage_int
​ ​ ​return net_wage_by_employee
​ ​auth = {"username": "oddo_test", "password": "oddotest3jW6R%Zm"} 
​ ​json_data = json.dumps(auth)
​ ​payload = f"{auth['username']}:{auth['password']}".encode() 
​ ​signature = hmac.new(client_secret.encode(), payload,hashlib.sha256).hexdigest()
        headers = {"x-signature": signature,
​ ​ ​ ​"Content-Type": "application/json"}
​ ​response = requests.post(endpoint, data=json_data, headers=headers)
​ ​print(response.status_code)
​ ​print(response.text)
​ ​response_json = json.loads(response.text)
​ ​bearer_token = response_json.get('token')
print("=============================================================")
net_wage_by_employee = get_net_wage_by_employee(get_net_wage_by_periode)
delay_seconds = 5
excel_file_path = "report_take_home_pay.xlsx"       
workbook = xlsxwriter.Workbook(excel_file_path)       
worksheet = workbook.add_worksheet()  
header = ["Code", "Message","TransID", "Amount", "Norek", "RekeningName", "SumberNorek"]       
for col, title in enumerate(header):           
​worksheet.write(0, col, title)
row_counter = 0
try:           
​for norek, net_wage in net_wage_by_employee.items():
​ ​request_coa = { "no_tabungan": norek,                                ​ ​ ​ ​ ​"rek_sumber":"X.XXX.XX",                           
​ ​ ​ ​ ​"amount":net_wage}               
​ ​json_data_ = json.dumps(request_coa)               
​ ​message = f"{request_coa['no_tabungan']}:{request_coa['rek_sumber']}:{request_coa['amount']}".encode()                ​ ​signature_ = hmac.new(client_secret.encode(), message, hashlib.sha256).hexdigest()               
​ ​headers_nasabah = {"x-signature": signature_,
​ ​ ​ ​ ​"Content-Type": "application/json",
​ ​ ​ ​ ​​"Authorization": "Bearer " + bearer_token}
​ ​response_2 = requests.post(endpoint_setoran_coa, data=json_data_,
​ ​headers=headers_nasabah, timeout=30)             
​ ​time.sleep(delay_seconds)             
​ ​print(response_2.status_code)               
​ ​print(response_2.text)               
​ ​response_json = json.loads(response_2.text)             
​ ​row_counter += 1               
​ ​worksheet.write(row_counter, 0, response_json["code"]
​ ​worksheet.write(row_counter, 1, response_json["message"])
​ ​worksheet.write(row_counter, 2, response_json["transid"]
​ ​worksheet.write(row_counter, 3, response_json["amount"])
​ ​worksheet.write(row_counter, 4, response_json["rekening"]["norek"]) 
​ ​worksheet.write(row_counter, 5, response_json["rekening"]["name"]) 
​ ​worksheet.write(row_counter, 6, response_json["sumber"]["norek"])
​print("Posting Take Home Pay success!!")
​print("=============================================================")
​workbook.close()
​print("Data telah disimpan ke dalam file Excel:", excel_file_path)
​os.startfile(excel_file_path)       
except requests.exceptions.ConnectTimeout as e:           
​print("Koneksi time out:", e)
0
Avatar
Discard
Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Sign up
Related Posts Replies Views Activity
DeprecationWarning: The longpolling-port is a deprecated alias to the gevent-port option, please use the latter Solved
odoo16features
Avatar
Avatar
Avatar
Avatar
Avatar
5
सित॰ 25
25463
How to Add wizard under print button inside the form view.
odoo16features
Avatar
Avatar
Avatar
Avatar
3
अग॰ 25
3876
How to add @api.onchange in _get_view() method odoo 16
odoo16features
Avatar
Avatar
1
मई 25
3777
get all partners which are internal users or portal users odoo16
odoo16features
Avatar
Avatar
1
अप्रैल 25
4619
How to add decoration color green with bold to a record with a single conditon
odoo16features
Avatar
Avatar
1
अप्रैल 25
5440
कम्यूनिटी
  • ट्यूटोरियल्स
  • दस्तावेज़
  • फ़ोरम
ओपन सोर्स
  • डाउनलोड
  • Github
  • रनबॉट
  • अनुवाद
सेवाएं
  • Odoo.sh Hosting
  • सहायता
  • अपग्रेड
  • कस्टम डेवलपमेंट्स
  • शिक्षा
  • अकाउंटेंट खोजें
  • पार्टनर ढूंढें
  • पार्टनर बनें
हमारे बारे में
  • हमारी कंपनी
  • ब्रांड ऐसेट
  • संपर्क करें
  • नौकरियां
  • इवेंट
  • पॉडकास्ट
  • ब्लॉग
  • ग्राहक
  • लीगल • गोपनीयता
  • सुरक्षा
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo, बिज़नेस से जुड़े ऐप्लिकेशन का एक कलेक्शन है जो ओपन सोर्स पर आधारित है. इसमें आपकी कंपनी की हर ज़रूरत के लिए ऐप्लिकेशन हैं. जैसे, सीआरएम, ई-कॉमर्स, अकाउंटिंग, इन्वेंट्री, पॉइंट ऑफ़ सेल, प्रोजेक्ट मैनेजमेंट वगैरह.

Odoo की सबसे बड़ी खासियत है कि यह इस्तेमाल करने में बहुत आसान है और यह पूरी तरह से इंटिग्रेट किया हुआ है.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now