當前位置: 首頁>>代碼示例>>Python>>正文


Python Transaction.save方法代碼示例

本文整理匯總了Python中models.Transaction.save方法的典型用法代碼示例。如果您正苦於以下問題:Python Transaction.save方法的具體用法?Python Transaction.save怎麽用?Python Transaction.save使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在models.Transaction的用法示例。


在下文中一共展示了Transaction.save方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_model_transaction

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
    def test_model_transaction(self):
        "Test transaction model"
        contact_type = ContactType(name='test')
        contact_type.save()

        contact = Contact(name='test', contact_type=contact_type)
        contact.save()

        currency = Currency(code="GBP",
                            name="Pounds",
                            symbol="L",
                            is_default=True)
        currency.save()

        account = Account(
            name='test', owner=contact, balance_currency=currency)
        account.save()

        obj = Transaction(name='test',
                          account=account,
                          source=contact,
                          target=contact,
                          value=10,
                          value_currency=currency)
        obj.save()
        self.assertEquals('test', obj.name)
        self.assertNotEquals(obj.id, None)
        obj.delete()
開發者ID:tovmeod,項目名稱:anaf,代碼行數:30,代碼來源:tests.py

示例2: add

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
def add(request, portfolio, is_sample, read_only):
  form = TransactionForm(request.POST)
  if form.is_valid():
    commission = form.cleaned_data.get('commission')
    if commission == None:
      commission = 0.0
    
    type = form.cleaned_data.get('type').encode('UTF-8')
    
    symbol = form.cleaned_data.get('symbol').encode('UTF-8').upper()
    linked_symbol = None
    if type == 'ADJUST':
      linked_symbol = symbol
      
    if type in ['DEPOSIT', 'WITHDRAW', 'ADJUST']:
      symbol = CASH_SYMBOL
    
    if symbol != None and len(symbol) > 0:
      transaction = Transaction()
      transaction.portfolio = portfolio
      transaction.type = type
      transaction.as_of_date = form.cleaned_data.get('as_of_date')
      transaction.symbol = symbol
      transaction.quantity = form.cleaned_data.get('quantity')
      transaction.price = form.cleaned_data.get('price')
      transaction.total = (transaction.quantity * transaction.price) + commission
      transaction.linked_symbol = linked_symbol
      transaction.save()
    
      refresh_positions(portfolio, force = True)
  
  return redirect_to_portfolio_action('transactions', portfolio)
開發者ID:andlister,項目名稱:frano,代碼行數:34,代碼來源:views.py

示例3: process_import

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
def process_import(request, portfolio, is_sample, read_only):
  formset = ImportTransactionFormSet(request.POST)
  if not formset.is_valid():
    raise Exception('Invalid import set');
  
  for form in formset.forms:
    cd = form.cleaned_data
    
    if not cd.get('exclude'):
      transaction = Transaction()
      transaction.portfolio = portfolio
      transaction.type = cd.get('type').encode('UTF-8')
      transaction.as_of_date = cd.get('as_of_date')
      transaction.symbol = cd.get('symbol').encode('UTF-8').upper()
      transaction.quantity = cd.get('quantity')
      transaction.price = cd.get('price')
      transaction.total = cd.get('total')
      
      linked_symbol = cd.get('linked_symbol').encode('UTF-8')
      if linked_symbol != None and linked_symbol != '':
        transaction.linked_symbol = linked_symbol
        
      transaction.save()
    
  refresh_positions(portfolio, force = True)
  return redirect_to_portfolio_action('transactions', portfolio)
開發者ID:andlister,項目名稱:frano,代碼行數:28,代碼來源:views.py

示例4: transaction

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
def transaction(request, start=False):
    """
        Start a transaction with Fermi
        @param request: request object
        @param start: if True, a new transaction will be started if we didn't already have one
    """
    if start is not True:
        transID = request.session.get('fermi_transID', None)
        if transID is not None:
            transactions = Transaction.objects.filter(trans_id=transID)
            if len(transactions)>0:
                return transactions[0]
    try:
        conn = httplib.HTTPSConnection(settings.FERMI_HOST, timeout=0.5)
        conn.request('GET', settings.FERMI_BASE_URL+'transaction?Action=Start',
                            headers={'Cookie':request.session.get('fermi', '')})
        r = conn.getresponse()
        if not r.status == 200:
            logging.error("Fermi transaction call failed: %s" % r.status)
        info = json.loads(r.read())
        if "Err_Msg" in info:
            logging.error("MantidRemote: %s" % info["Err_Msg"])

        request.session['fermi_transID'] = info["TransID"]
        transaction_obj = Transaction(trans_id = info["TransID"],
                                  directory = info["Directory"],
                                  owner = request.user)
        transaction_obj.save()
        return transaction_obj
    except:
        logging.error("Could not get new transaction ID: %s" % sys.exc_value)
    return None
開發者ID:serena617,項目名稱:reduction_service,代碼行數:34,代碼來源:view_util.py

示例5: get_post_function

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
def get_post_function(request,t_id,rf_id,amt=0.0,l_or_s_or_c=None,date_time=None):
	loan_balance = 0.0
	savings_balance = 0.0
	try:
		customer = Customer.objects.get(RfCard_id=rf_id)
		if int(l_or_s_or_c) == 0: #i.e loan

			loan_amt = float(customer.loanAmount) - float(amt)
			trans_type = 'Loan'
			customer.loanAmount = loan_amt
			customer.save()
			
		elif int(l_or_s_or_c) == 1: #i.e savings
			savings_balance = float(customer.savingsAmount) + float(amt)
			trans_type = 'Savings'
			customer.savingsAmount = savings_balance
			customer.save()
		
		elif int(l_or_s_or_c) == 2: #i.e collections
			collection_amt = float(customer.collectionAmount) - float(amt)
			trans_type = 'Collections'
			customer.collectionAmount = collection_amt
			customer.save()

		else:
			return HttpResponseForbidden("You do not have permission!!")
          
               
   		#random codes from online
		#random_number = User.objects.make_random_password(length=20, allowed_chars='123456789')

		#while User.objects.filter(userprofile__temp_password=random_number):
    		#	random_number = User.objects.make_random_password(length=10, allowed_chars='123456789')
		
			
		
               # key = hashlib.new(str(random.random()))
		trans_id_gen = random.randint(1,1000000000000)
            	#trans_id_gen = hashlib.new('TRANS'+str(key)).hexdigest()

               

		trans = Transaction(transaction_type=trans_type,paymentAmount = float(amt),terminal_id = t_id,transaction_id = trans_id_gen,RfCard_id =  rf_id,status=l_or_s_or_c, company=customer.company, customer_name=customer.name, collector_id = str(request.user.username))
		trans.save()
		#return HttpResponse('Name: '+str(customer.name)+'<br/>'+ 'Amount Paid: GHS '+str(trans.paymentAmount)+'<br/>'+ 'Loan Balance: GHS '+ str(customer.loanAmount)+'<br/>'+'Transaction Type: '+ trans_type+'<br/>'+'Transaction Id: '+str(trans_id_gen)+'<br/>')
		#print 'blupay1'
                pwdBy = PoweredBy.objects.get(pk=1)
		if trans_type == 'Loan':
			return HttpResponse('<b>'+str(customer.company)+'</b></br></br>LOAN REPAYMENT RECEIPT<br/>***************************</br>'+'Name: '+str(customer.name)+'<br/>'+ 'Amount Paid: GHS '+str(trans.paymentAmount)+'<br/>'+ 'Loan Balance: GHS '+ str(customer.loanAmount)+'<br/>'+'Transaction Id: '+str(trans_id_gen)+'<br/>'+'Timestamp: '+str(trans.date_created)+'<br/>***************************</br>Powered by <b>'+pwdBy.poweredByName+'&#0174;</b>')
			#return HttpResponseRedirect('https://dev.jallohenterprise.co.uk/visiontekconnect.php?userid=visiontek&password=12345&amount='+str(customer.loanAmount))
		elif trans_type == 'Savings':
			return HttpResponse('<b>'+str(customer.company)+'</b></br></br>SAVINGS RECEIPT<br/>***************************</br>'+'Name: '+str(customer.name)+'<br/>'+ 'Amount Paid: GHS '+str(trans.paymentAmount)+'<br/>'+ 'Savings Balance: GHS '+ str(customer.savingsAmount)+'<br/>'+'Transaction Id: '+str(trans_id_gen)+'<br/>'+'Timestamp: '+str(trans.date_created)+'<br/>***************************</br>Powered by <b>'+pwdBy.poweredByName+'&#0174;</b>')
			#return HttpResponseRedirect('https://dev.jallohenterprise.co.uk/visiontekconnect.php?userid=visiontek&password=12345&amount='+str(customer.savingsAmount))
		else:
			return HttpResponse('<b>'+str(customer.company)+'</b></br></br>COLLECTION REPAYMENT RECEIPT<br/>***************************</br>'+'Name: '+str(customer.name)+'<br/>'+ 'Amount Paid: GHS '+str(trans.paymentAmount)+'<br/>'+ 'Collection Balance: GHS '+ str(customer.collectionAmount)+'<br/>'+'Transaction Id: '+str(trans_id_gen)+'<br/>'+'Timestamp: '+str(trans.date_created)+'<br/>***************************</br>Powered by <b>'+pwdBy.poweredByName+'&#0174;</b>')

	except Customer.DoesNotExist:	
		return HttpResponseForbidden("Forbidden!!, Customer does not exist!!")
開發者ID:blupay,項目名稱:BLUPAY,代碼行數:60,代碼來源:views.py

示例6: init

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
def init(amount, currency=None, email="", description="", language=None):
    """
    Init payment

    Params:
    * amount - Amount to pay
    * currency - Suggested currency (can be changed by user)
    * email - User's email (can be changed by user)
    * description - Transaction description
    * language - "en" or "ru"

    Return tuple (rk.models.Transaction instance, robokassa redirect URL)
    """

    from models import Transaction

    if amount is None:
        return None

    currency = currency or lib.conf("RK_DEFAULT_CURRENCY")
    language = language or lib.conf("RK_DEFAULT_LANGUAGE")

    login = lib.conf("RK_MERCHANT_LOGIN")
    pass1 = lib.conf("RK_MERCHANT_PASS1")

    # 2. Create transaction in DB
    tr = Transaction(amount=amount, currency=currency, description=description)
    tr.save()
    _id = tr.id

    signature = lib.sign([login, amount, str(_id), pass1])

    # 3. Redirect to robokassa
    params = {"MrchLogin": login,
              "OutSum": amount,
              "InvId": _id,
              "Desc": description,
              "SignatureValue": signature,
              "IncCurrLabel": currency,
              "Email": email,
              "Culture": language}

    if lib.conf("RK_USE_TEST_SERVER"):
        rk_url = lib.conf("RK_TEST_URL")
    else:
        rk_url = lib.conf("RK_URL")

    url = rk_url + "?%s" % urllib.urlencode(params)

    return (tr, url)
開發者ID:muzmates,項目名稱:django-rk,代碼行數:52,代碼來源:__init__.py

示例7: route_webhook

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
def route_webhook():
    data = json.loads(request.data.decode('utf8'))

    if data['type'] == 'transaction.created':
        transaction = Transaction(data['data'])
        transaction.save()

        if transaction.visited_count > settings.mondo_visit_count:
            suggestion = transaction.find_suggestion()

            if suggestion:
                suggestion.save()
                suggestion.post_to_feed()

    else:
        log.warning('Unsupported webhook type: %s' % data['type'])

    return ''
開發者ID:markdessain,項目名稱:goto-mondo,代碼行數:20,代碼來源:main.py

示例8: run_billing

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
def run_billing(bill_time=datetime.now()):
	"""Generate billing records for every member who deserves it."""
	bill_date = datetime.date(bill_time)
	print "Running billing for %s" % bill_date
	try:
		latest_billing_log = BillingLog.objects.latest()
	except ObjectDoesNotExist:
		latest_billing_log = None
	if latest_billing_log and not latest_billing_log.ended:
		print 'The last billing log (%s) claims to be in progress.	Aborting billing.' % latest_billing_log
		return

	billing_log = BillingLog.objects.create()
	billing_success = False
	bill_count = 0
	try:
			for member in Member.objects.all():
				last_bill = member.last_bill()
				if last_bill:
					start_date = last_bill.created + timedelta(days=1)
				else:
					start_date = bill_date - timedelta(days=62)
					if start_date < settings.BILLING_START_DATE: start_date = settings.BILLING_START_DATE
				run = Run(member, start_date, bill_date)
				for day_index in range(0, len(run.days)): # look for days on which we should bill for a membership
					day = run.days[day_index]
					if day.is_membership_anniversary() or day.is_membership_end_date(): # calculate a member bill
						bill_dropins = []
						bill_guest_dropins = []
						recent_days = run.days[0:day_index + 1]
						recent_days.reverse()
						for recent_day in recent_days: # gather the daily logs for this member and guests under this membership
							if recent_day.bill:
								break
							if recent_day.daily_log: bill_dropins.append(recent_day.daily_log)
							for guest_daily_log in recent_day.guest_daily_logs: bill_guest_dropins.append(guest_daily_log)
						# now calculate the bill amount
						bill_amount = 0
						monthly_fee = day.membership.monthly_rate
						if day.is_membership_end_date(): monthly_fee = 0
						billable_dropin_count = max(0, len(bill_dropins) + len(bill_guest_dropins) - day.membership.dropin_allowance)
						bill_amount = monthly_fee + (billable_dropin_count * day.membership.daily_rate)

						day.bill = Bill(created=day.date, amount=bill_amount, member=member, paid_by=day.membership.guest_of, membership=day.membership)
						#print 'saving bill: %s - %s - %s' % (day.bill, day, billable_dropin_count)
						day.bill.save()
						bill_count += 1
						day.bill.dropins = [dropin.id for dropin in bill_dropins]
						day.bill.guest_dropins = [dropin.id for dropin in bill_guest_dropins]
						day.bill.save()

						# Close out the transaction if no money is due
						if bill_amount == 0:
							transaction = Transaction(member=member, amount=0, status='closed')
							transaction.save()
							transaction.bills = [day.bill]
							transaction.save()

				# Now calculate a bill for non-member drop-ins if they exist and it has been two weeks since we billed them
				bill_dropins, guest_bill_dropins = run.non_member_daily_logs()
				if len(bill_dropins) > 0 or len(guest_bill_dropins) > 0:
					time_to_bill_guests = len(guest_bill_dropins) > 0 and (bill_date - guest_bill_dropins[0].visit_date) >= timedelta(weeks=2)
					time_to_bill_dropins = len(bill_dropins) > 0 and (bill_date - bill_dropins[0].visit_date) >= timedelta(weeks=2)
					if time_to_bill_guests or time_to_bill_dropins:
						bill_amount = (len(bill_dropins) + len(guest_bill_dropins)) * settings.NON_MEMBER_DROPIN_FEE
						last_day = run.days[len(run.days) - 1]
						last_day.bill = Bill(created=last_day.date, amount=bill_amount, member=member)
						last_day.bill.save()
						bill_count += 1
						last_day.bill.dropins = [dropin.id for dropin in bill_dropins]
						last_day.bill.guest_dropins = [dropin.id for dropin in guest_bill_dropins]
						last_day.bill.save()

			billing_success = True
			#print 'Successfully created %s bills' % bill_count
	except:
		billing_log.note = traceback.format_exc()
	finally:
		billing_log.ended = datetime.now()
		billing_log.successful = billing_success
		billing_log.save()
		#print 'Completed billing %s' % billing_success
		if not billing_success: print billing_log.note
開發者ID:ponyfleisch,項目名稱:nadine,代碼行數:85,代碼來源:billing.py

示例9: create_transaction

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
def create_transaction(request):
    if request.method == 'POST':
        form = TransactionForm(request.POST)
        if form.is_valid():
            data = form.cleaned_data

            invalid_response ={"message": "No transaction was created. The transaction failed due to the following error(s).",
                               "code": 500,
                               "errors": []}
            if data.has_key('points'):

                if data['points']:
                    try:
                        p=Permission.objects.get(user=request.user,
                                                permission_name='assign-points')

                    except(Permission.DoesNotExist):
                        invalid_response['errors'].append("You do not have permission to assign points.")
                        invalid_response['code'] = 401
                        jsonstr=json.dumps(invalid_response, indent = 4,)
                        return HttpResponse(jsonstr, mimetype="application/json")



            if settings.USERS_MUST_EXIST:
                data = verify_users_exist_and_sg(data)

                if data.has_key('errors'):
                    invalid_response['errors'].append(data['errors'])
                    jsonstr=json.dumps(invalid_response, indent = 4,)
                    return HttpResponse(jsonstr, mimetype="application/json")

            tx=Transaction(**data)
            result=tx.save()

            if int(result['code']) != 200:
                #print "result =", result
                jsonstr={"code": int(result['code']),
                         "message": result['message'],
                         "errors": result['errors']}
            else:
                jsonstr={"code": 200,
                         "message": "Transaction created.",
                         "results": (result['results'],)}

                jsonstr=json.dumps(jsonstr, indent = 4,)
                return HttpResponse(jsonstr, mimetype="application/json")
        else:
            # the form had errors
            errors=[]
        if form.non_field_errors():
            global_error={'global':global_error}
            errors.append()


        for k,v in form._errors.items():
            error={'field': k, 'description':v}
            errors.append(error)
            jsonstr={"code": 500,
                     "message": "No transaction was created. The transaction failed due to the following error(s). ",
                     "errors": errors}
            jsonstr=json.dumps(jsonstr, indent = 4,)
            return HttpResponse(jsonstr, status=500, mimetype="application/json")

    #this is an HTTP GET
    return render_to_response('transaction/create.html',
        {'form': TransactionForm(),}, RequestContext(request))
開發者ID:ekivemark,項目名稱:flangio,代碼行數:69,代碼來源:views.py

示例10:

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
				title = row[14],
				language = row[15],
				material = row[16],
				place = row[17],
				use = row[18],
				date = row[19],
				circa = row[20],
				artist = row[21],
				script = row[22],
				folios = row[23],
				lines = row[24],
				height = row[25],
				width = row[26],
				binding = row[27],
				provenance = row[28],
				comments = row[29],
				link = row[30],
				full_page_mini = row[31],
				large_mini = row[32],
				small_mini = row[33],
				mini = row[34],
				historiated_initials = row[35],
				decorated_initials = row[35],
				possible_duplicates = row[44],
				cat_date = row[47],
				buyer = row[48],
				columns = row[49],
				)
			print trans.manuscript_id
			trans.save()
開發者ID:samzhang111,項目名稱:schoenberg-visualization,代碼行數:32,代碼來源:import_all.py

示例11: FinanceViewsTest

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
class FinanceViewsTest(TestCase):
    username = "test"
    password = "password"

    def setUp(self):
        self.group, created = Group.objects.get_or_create(name='test')
        self.user, created = DjangoUser.objects.get_or_create(username=self.username)
        self.user.set_password(self.password)
        self.user.save()
        perspective, created = Perspective.objects.get_or_create(name='default')
        perspective.set_default_user()
        perspective.save()
        ModuleSetting.set('default_perspective', perspective.id)

        self.contact_type = ContactType(name='test')
        self.contact_type.set_default_user()
        self.contact_type.save()

        self.contact = Contact(name='test', contact_type=self.contact_type)
        self.contact.set_default_user()
        self.contact.save()

        self.category = Category(name='test')
        self.category.set_default_user()
        self.category.save()

        self.equity = Equity(
            issue_price=10, sell_price=10, issuer=self.contact, owner=self.contact)
        self.equity.set_default_user()
        self.equity.save()

        self.asset = Asset(name='test', owner=self.contact)
        self.asset.set_default_user()
        self.asset.save()

        self.tax = Tax(name='test', rate=10)
        self.tax.set_default_user()
        self.tax.save()

        self.currency = Currency(code="GBP",
                                 name="Pounds",
                                 symbol="L",
                                 is_default=True)
        self.currency.set_default_user()
        self.currency.save()

        self.account = Account(
            name='test', owner=self.contact, balance_currency=self.currency)
        self.account.set_default_user()
        self.account.save()

        self.liability = Liability(name='test',
                                   source=self.contact,
                                   target=self.contact,
                                   account=self.account,
                                   value=10,
                                   value_currency=self.currency)
        self.liability.set_default_user()
        self.liability.save()

        self.transaction = Transaction(name='test', account=self.account, source=self.contact,
                                       target=self.contact, value=10, value_currency=self.currency)
        self.transaction.set_default_user()
        self.transaction.save()

    ######################################
    # Testing views when user is logged in
    ######################################
    def test_finance_login(self):
        """Test index page with login at /finance/"""
        response = self.client.post('/accounts/login',
                                    {'username': self.username, 'password': self.password})
        self.assertRedirects(response, '/')
        response = self.client.get(reverse('finance'))
        self.assertEquals(response.status_code, 200)

    def test_finance_index_login(self):
        "Test index page with login at /finance/index/"
        response = self.client.post('/accounts/login',
                                    {'username': self.username, 'password': self.password})
        self.assertRedirects(response, '/')
        response = self.client.get(reverse('finance_index_transactions'))
        self.assertEquals(response.status_code, 200)

    def test_finance_income(self):
        "Test index page with login at /finance/income/"
        response = self.client.post('/accounts/login',
                                    {'username': self.username, 'password': self.password})
        self.assertRedirects(response, '/')
        response = self.client.get(reverse('finance_income_view'))
        self.assertEquals(response.status_code, 200)

    def test_finance_balance(self):
        "Test index page with login at /finance/balance/"
        response = self.client.post('/accounts/login',
                                    {'username': self.username, 'password': self.password})
        self.assertRedirects(response, '/')
        response = self.client.get(reverse('finance_balance_sheet'))
        self.assertEquals(response.status_code, 200)

#.........這裏部分代碼省略.........
開發者ID:tovmeod,項目名稱:anaf,代碼行數:103,代碼來源:tests.py

示例12: transfer_funds

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
def transfer_funds(tokens, sender_number):
    """
    Transfer funds to user or non-user
    Expected format: 'transfer [amount] [receiver] [pin]'
    
    transaction limit: NGN3,000
    daily transaction limit: NGN30,000
    """
    messages = []
    try:
        amount = float(tokens[1])
        receiver_number = tokens[2]
        pin = tokens[3]
        
        user = User.objects.get(phone=sender_number)
        if not validate_pin(user, pin):
            return msg_invalid_pin(user.phone)
        
        if not account_activated(user):
            return msg_account_not_activated(user.phone)
        
        # check account balance
        if amount > (user.balance - 100):
            msg = ("You do not have enough balance to make this transfer.")
            sms = OutgoingMessage(body=msg, receiver=sender_number,
                                  timestamp=time.time(), 
                                  type='insufficient_balance')
            messages.append(sms)
            return send_sms(messages)
        
        if amount > 3000:
            msg = ("You cannot transfer above NGN3,000 in one transaction."
                   " Please try again.")
            sms = OutgoingMessage(body=msg, receiver=sender_number,
                                  timestamp=time.time(), type='excess_transfer')
            messages.append(sms)
            return send_sms(messages)
        
        # add restriction of daily limit of 3ok
        
        # validate receiver exists
        #     if not generate cash out ticket instead
        transaction = Transaction(
            id=util.generate_uuid()[0:12], sender=user.phone, 
            receiver=receiver_number, timestamp=time.time(), amount=amount)
        try:
            User.objects.get(phone=receiver_number)
            transaction.type = 'user_to_user_transfer'
        except User.DoesNotExist:
            transaction.type = 'user_to_guest_transfer'
            
        transaction.save()
        
        # return message to confirm transaction
        msg = ("transaction-id: %s, amount: %s, receiver: %s. Please"
               " reply this message with 'confirm' to confirm this"
               " transaction." 
               % (transaction.id, transaction.amount, transaction.receiver))
        sms = OutgoingMessage(body=msg, receiver=sender_number,
                              timestamp=time.time(), meta=transaction,
                              type='confirm_transaction')
        messages.append(sms)
        return send_sms(messages)
        
    except User.DoesNotExist:
        return msg_user_does_not_exist(sender_number)
    
    except IndexError:
        expected_format = ("Unknown message format. Expeted format: transfer"
                           " [amount] [receiver] [pin]. Please try again.")
        return msg_unknown_format(expected_format, sender_number)
開發者ID:stackempty,項目名稱:mopay,代碼行數:73,代碼來源:actions.py

示例13: make_payment

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
def make_payment(content_object, request, transaction_opts={}):
  """"""

  trans = Transaction(content_object=content_object)
  trans.status = Transaction.PROCESSING
  trans.save()

  total = content_object.get_amount()
  shipping = content_object.shipping_cost()
  subtotal = (total - shipping)

  post_data = {
    'intent':'sale',
    'redirect_urls':{
        'return_url': build_url(request, trans.get_success_url()),
        'cancel_url': build_url(request, trans.get_failure_url()),
    },
    'payer':{
        'payment_method': 'paypal',
    },
    'transactions': [{
      'amount': {
        'total': "%.2f" % total,
        'currency': content_object.currency,
        'details': {
          'subtotal': "%.2f" % subtotal,
          'shipping': "%.2f" % shipping,
        }
      },
      'description': str(content_object).encode('ascii', 'ignore'),
      'item_list': {'items': []},
    }]
  }

  if hasattr(content_object, 'get_lines'):
    for line in content_object.get_lines():
      post_data['transactions'][0]['item_list']['items'].append({
        'name': '%s x %s' % (line[1], line[0]),
        'quantity': 1,
        'price': "%.2f" % line[2],
        'currency': content_object.currency,
      })
  else:
    post_data['transactions'][0]['item_list']['items'].append({
      'quantity': 1,
      'name': str(content_object).encode('ascii', 'ignore'),
      'price': "%.2f" % subtotal,
      'currency': content_object.currency,
    })

  url = PAYPAL_API + '/v1/payments/payment'
  token = get_paypal_token()

  # see https://developer.paypal.com/docs/integration/web/accept-paypal-payment/#specify-payment-information-to-create-a-payment

  opener = urllib2.build_opener(BetterHTTPErrorProcessor)
  urllib2.install_opener(opener)

  encoded_data = json.dumps(post_data)

  request = urllib2.Request(url, encoded_data,
                            headers={"Authorization": 'Bearer ' + token,
                                     "Content-Type": 'application/json'})
  try:
    request = urllib2.Request(url, encoded_data,
                              headers={"Authorization": 'Bearer ' + token,
                                       "Content-Type": 'application/json'})
    result = urllib2.urlopen(request).read()
  except urllib2.HTTPError, e:
    raise Exception(e.read())
開發者ID:pbright,項目名稱:django-shoptools,代碼行數:72,代碼來源:transactions.py

示例14: load_transactions

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]

#.........這裏部分代碼省略.........
      addr_final = row[20].strip()
      city_final = row[21].strip()
      try:	lat_y = float(row[22])
      except:	lat_y = None
      try:	long_x = float(row[23])
      except:   long_x = None
      try:	tract_fix = float(row[24])
      except:	tract_fix = None
      no_tract_info = True if int(row[25])==1 else False
      try:	ca_num = int(row[26])
      except:	ca_num = None
      ca_name = row[27].strip()
      place = row[28].strip()
      gisdate = row[29].strip()
      try:	ptype_id = int(row[30])
      except:   ptype_id = None
      try: 	residential = int(row[31])
      except:	residential = None
      try:	adj_yq = int(row[32])
      except:   adj_yq = None
      try:	adj_yd = int(row[33])
      except:	adj_yd = None
      loc       = None if row[22]=='' else Point((Decimal(row[23]), Decimal(row[22])),srid=4326).transform(3435)
      try:
        if skip_lookup:
          raise Exception('no lookup')
        transaction =  Transaction.objects.get(\
        pin = pin\
	,amount_prime = amount_prime\
        ,doc = doc\
        ,date_doc = date_doc\
	,date_rec = date_rec\
	,buyer = buyer\
	,buyer_type = buyer_type\
	,seller = seller\
	,seller_type = seller_type\
	,non_condo = non_condo\
	,purchase_less_20k = purchase_less_20k\
	,business_buyer = business_buyer\
        ,yq_doc = yq_doc\
	,yeard = yeard\
	,apt = apt\
	,direction = direction\
	,houseno = houseno\
	,street = street\
	,suffix = suffix\
	,addr_final = addr_final\
	,city_final = city_final\
	,lat_y = lat_y\
	,long_x = long_x\
	,tract_fix = tract_fix\
	,no_tract_info = no_tract_info\
	,ca_num = ca_num\
	,ca_name = ca_name\
	,place = place\
	,gisdate = gisdate\
	,ptype_id = ptype_id\
	,residential = residential\
	,adj_yq = adj_yq\
	,adj_yd = adj_yd\
        ,loc = loc\
        )
      except:
        transaction =  Transaction(\
        pin = pin\
	,amount_prime = amount_prime\
        ,doc = doc\
        ,date_doc = date_doc\
	,date_rec = date_rec\
	,buyer = buyer\
	,buyer_type = buyer_type\
	,seller = seller\
	,seller_type = seller_type\
	,non_condo = non_condo\
	,purchase_less_20k = purchase_less_20k\
	,business_buyer = business_buyer\
        ,yq_doc = yq_doc\
	,yeard = yeard\
	,apt = apt\
	,direction = direction\
	,houseno = houseno\
	,street = street\
	,suffix = suffix\
	,addr_final = addr_final\
	,city_final = city_final\
	,lat_y = lat_y\
	,long_x = long_x\
	,tract_fix = tract_fix\
	,no_tract_info = no_tract_info\
	,ca_num = ca_num\
	,ca_name = ca_name\
	,place = place\
	,gisdate = gisdate\
	,ptype_id = ptype_id\
	,residential = residential\
	,adj_yq = adj_yq\
	,adj_yd = adj_yd\
        ,loc = loc\
        )
      transaction.save()
開發者ID:Najah-lshanableh,項目名稱:land-bank,代碼行數:104,代碼來源:load_tran.py

示例15: transaction

# 需要導入模塊: from models import Transaction [as 別名]
# 或者: from models.Transaction import save [as 別名]
def transaction( request):
    '''
    View for handling transaction start/stop

    <base_url>/transaction?Action=Start
    <base_url>/transaction?Action=Stop&TransID=<ID>
    '''
    
    # Validate the request
    if request.method != 'GET':
        return HttpResponse( err_not_get(),  status=400)  # Bad request
    
    if not 'Action' in request.GET:
        return HttpResponse( err_missing_param( 'Action'), status=400)  # Bad request
    
    action = request.GET['Action']
    if not (action == 'Start' or action == 'Stop'):
        return HttpResponse( json_err_msg("Expected either 'Start' or 'Stop' for the 'Action' parameter."),
                             status=400)
    if action == 'Start':
        # Start a new transaction
        new_trans = Transaction()
        new_trans.owner = request.user
        new_trans.save()  # Need to call save() so that the id value is generated

        # generate the name and create the directory
        dir_name = os.path.join( settings.TRANSACTION_DIR, request.user.username + '_' + str(new_trans.id))
        os.mkdir(dir_name, 0770)

        # Use setfacl to give the user read, write & execute permissions
        # on the directory we just created    
        permissions = request.user.username + ':rwX'
        proc = subprocess.Popen([settings.SETFACL_BIN, '-m', permissions, dir_name])
        proc.wait()
        if proc.returncode != 0:
            # couldn't set the ACL (maybe this filesystem doesn't support ACL's?)
            # so we need to fail the operation and that means cleaning up after
            # ourselves
            recursive_rm( dir_name)
            new_trans.delete()
            return HttpResponse( json_err_msg( "Cannot start transaction: Failed to set ACL's on transaction directory."),
                                 status=500) # internal server error

        # If we make it here, everything's good - save the transaction object
        # to the DB and return the required JSON        
        new_trans.directory = dir_name
        new_trans.save()
        
        json_out = { }
        json_out['TransID'] = new_trans.id
        json_out['Directory'] = dir_name
        return HttpResponse( json.dumps( json_out))
        
    else:
        # Stop an existing transaction
        # Need to specify the transaction ID
        (trans, error_response) = validate_trans_id( request)
        if error_response != None:
        # TransID didn't validate...
            return error_response
        
        # The transaction is validated - delete the files/directories
        recursive_rm( trans.directory)
        
        # delete the transaction from the db (Django defaults to 'cascaded' deletes,
        # so all we need to do is remove the transaction and everything that was pointing
        # to it (jobs & files) will also be removed
        trans.delete()
        
        return HttpResponse()
開發者ID:neutrons,項目名稱:MantidRemote,代碼行數:72,代碼來源:views.py


注:本文中的models.Transaction.save方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。