예제 #1
0
def post_detail(post_id):
    post = Post.query.get_or_404(post_id)
    schema = PostSchema()
    result = schema.dump(post)
    pprint(result.data)
    pprint(result.errors)
    return render_template('Post.html', title='Post', post=post)
예제 #2
0
def add_shipment():
    '''
    Add a new shipment to DB.\n
    Creates a new Vizion subscription reference for tracking.
    '''
    schema = ShipmentSchema()
    data = request.get_json()
    scac = data.get('scac')
    bol_number = data.get('bill_of_lading')
    container_id = data.get('container_id')

    # Determine whether this shipment is a BL or container
    # Identifier for subscription creation is set based on this value
    is_bol = bol_number != None
    identifier = bol_number if is_bol else container_id

    # Create Vizion reference subscription and return ref ID
    vizion_ref_id = create_subscription(identifier, scac, is_bol)

    # Create shipment record and return
    shipment = Shipment(carrier_scac=scac,
                        bill_of_lading=bol_number,
                        container_id=container_id,
                        vizion_reference_id=vizion_ref_id)
    db.session.add(shipment)
    db.session.commit()
    res = schema.dump(shipment)
    print('Created new shipment.')
    pprint(res)
    return res, 201
예제 #3
0
    def put(self, id):
        print(f'PUT - for ID: {id}')
        req_data = None
        temp_schema = TempSchema()
        user = User.select().where(User.key == id)

        if user.exists():
            try:
                reqjson = request.get_json(force=True)
                req_data = temp_schema.load(reqjson)
            except ValidationError as err:
                pprint(err)
                return {'error': err.messages}, 422

            print('REQUEST DATA:', req_data)
            if 'date' not in req_data:
                req_data['date'] = dt.datetime.now()

            sensor_data = SensorData(temp=req_data['temp'],
                                     humi=req_data['humi'],
                                     date=req_data['date'],
                                     fkey=id)
            if sensor_data.save():
                return {'success': 'Data saved.'}
            else:
                return {'failed': 'Data was not saved.'}

        else:
            return {'error': 'User not exists.'}
예제 #4
0
파일: app.py 프로젝트: guoylyy/ms-analytics
def show_index():
	predicts = Prediction.query.first()
	serial = PredictionSerializer(predicts)
	pprint(serial.data)
	return render_template('index.html',
			metypes = MeType.query.all()
		)
예제 #5
0
async def test_get(request):

    emoji_1 = emoji.emojize('Python is :thumbs_up_sign:')
    emoji_2 = emoji.emojize('Python is :thumbsup:', use_aliases=True)

    job = dict(company='摩尔妈妈', start_date=datetime.datetime(2018, 3, 1))
    baby_1 = dict(name='zhaohao', age=31)
    baby_2 = dict(name='古瑞替', age=10)

    user = dict(name='刘大力',
                mobile='13311234567',
                email='*****@*****.**',
                job=job,
                babies=[baby_1, baby_2],
                married=False,
                money=decimal.Decimal(321.1235678),
                status=-1,
                skills=['吐槽', '使劲吐槽', ''],
                emoji=[emoji_1, emoji_2])

    schema = UserSchema()
    result = schema.dump(user)

    marshmallow.pprint(result, indent=4)

    return json(result)
예제 #6
0
def generate_transaction_for_user(user_email, amount):
    '''Generate transaction for given user'''
    amount = int(amount)
    user = mongo.db.users.find_one({'email': user_email})

    if not user:
        raise BadParameter(f'User with email {user_email} not found')

    fake_transactions = []
    for ind in range(amount):
        airports = fake.random_sample(AIRPORTS_CODES, 2)
        fake_transaction = {
            'transactions_id':
            fake.numerify('########'),
            'bonus_card_id':
            user['bonus_card_id'],
            'bonus_miles':
            fake.pyint(min_value=0, max_value=100),
            'flight_from':
            airports[0],
            'flight_to':
            airports[1],
            'flight_date':
            ma.utils.to_iso_date(
                fake.date_between(start_date='-10y', end_date='today'))
        }
        fake_transactions.append(fake_transaction)

    result = mongo.db.transactions.insert_many(fake_transactions, ordered=True)
    for ind, inserted_id in enumerate(result.inserted_ids):
        fake_transactions[ind]['_id'] = inserted_id

    ma.pprint(fake_transactions, indent=4)
예제 #7
0
def update(deploymentId, deployment):
    """
    This function updates an existing deployment in the deployment list

    :param deploymentId: deploymentId of the deployment to update in the deployment list
    :param deployment:   deployment to update
    :return:             updated deployment
    """

    pprint(deployment)

    # Does the deployment exist in deployments?
    existing_deployment = Deployments.query.filter(
            Deployments.deploymentId == deploymentId
    ).one_or_none()

    # Does deployment exist?

    if existing_deployment is not None:
        schema = DeploymentsSchema()
        update_deployment = schema.load(deployment, session=db.session)
        update_deployment.deploymentId = existing_deployment.deploymentId

        db.session.merge(update_deployment)
        db.session.commit()

        # return the updted deployment in the response
        data = schema.dump(update_deployment)
        return data, 200

    # otherwise, nope, deployment doesn't exist, so that's an error
    else:
        abort(404, f"Deployment not found")
예제 #8
0
 def post(self, id, accion):
     n = NotificacionTemplateModel.find_by_id(id)
     if not n:
         return {"message": "No se encontro la notificación"}, 404
     response_envio = NotificacionTemplateModel.send_to_participantes(n)
     if response_envio["status"] == 404:
         return {"message": "No se pudo crear o enviar la notificacion."}, 404
     if accion == 'ninguna':
             return {"message": "Notificacion reenviada con éxito.",
                 "Número de destinatarios:": response_envio["total"]}
     elif accion == 'premio':
         p = PremioModel.find_by_id(n.link)
         if not p:
             return {"message": "No se encontro el premio"}, 404
         response_envio = PremioModel.send_to_participantes(n)
         if response_envio["status"] == 404:
             return {"message": "No se pudo crear o enviar la notificacion."}, 404
         return {"message": "Notificacion reenviada con éxito.",
             "Número de destinatarios:": response_envio["total"]}
     elif accion == 'encuesta':
         n = NotificacionTemplateModel.find_by_id(id)
         pprint(n)
         if not n:
             return {"message": "No se encontro la notificacion"}, 404
         en = EncuestaModel.find_by_id(n.link)
         if not en:
             return {"message": "No se encontro la encuesta"}, 404
         response_envio = EncuestaModel.send_to_participantes(n)
         if response_envio["status"] == 404:
             return {"message": "No se pudo crear o enviar la notificacion."}, 404
         return {"message": "Notificacion reenviada con éxito.",
             "Número de destinatarios:": response_envio["total"]}
예제 #9
0
 def patch(self, id):
     bir = BirthdayModel.find_by_id(id)
     pprint(bir)
     if not bir:
         return {"message": "No se encontró el premio de cumpleaños"}, 404
     item_json = request.get_json()
     item = BirthdaySchema().load(item_json)
     try:
         if "id_notificacion" in item:
             bir.id_notificacion = item["id_notificacion"]
         if "id_promocion" in item:
             bir.id_promocion = item["id_promocion"]
         if "trigger" in item:
             bir.trigger = item["trigger"]
         if "antiguedad" in item:
             bir.antiguedad = item["antiguedad"]
         if "vigencia" in item:
             bir.vigencia = item["vigencia"]
         bir.fecha_creacion = item["fecha_creacion"]
         bir.save()
     except ValidationError as exc:
         print(exc.message)
         return {
             "message":
             "Error: No se pudo actualizar el premio de cumpleños"
         }
     return {'message': "Elemento actualizado", '_id': str(bir._id)}, 200
예제 #10
0
def test_dump():
    try:
        schema = UserSchema()
        result = schema.dump(input_user_data)
        marshmallow.pprint(result)
    except marshmallow.ValidationError as err:
        marshmallow.pprint({'errors': err.messages})
예제 #11
0
def reinit_db():
    print("Reinitializing database...")
    with db.app.app_context():
        db_name = db.app.config["MONGODB_DB"]
        db.connection.drop_database(db_name)

    try:
        for schema, data_file in INIT_DATA:
            print(f"Parsing {data_file}")
            with open(path.join(BASE_DIR_DATA, data_file), "r", encoding="utf8") as file:
                docs = schema.loads(file.read(), many=True)
                for doc in docs:
                    try:
                        mod = schema.__model__(**doc)
                    except Exception as e:
                        print(f"Cannot instanciate {schema.__model__.__name__} from \n{schema.dumps(doc, indent=2)}\n")
                        raise e

                    if isinstance(schema, UserSchema):
                        mod.set_password(mod.password)  # hashing password
                    mod.save()
    except HTTPException as e:
        print(e)
        pprint(e.data, indent=2)
        exit()
예제 #12
0
def test_portfolio_image_schema():
    """
    GIVEN a PostArgs Schema
    WHEN the Schema deserializes data
    THEN check that all fields are properly validated and data is deserialized as expected
    """
    schema = PostArgs()
    data = {
        "title": "Generic Event 2020",
        "category": "portrait",
        "preview": {"uri": "", "alt": "Img Alt"},
        "content": [
            {
                "uri": "",
                "alt": "Interesting Preview"
            }
        ],
        "year": 2020,
        "client": "Pre Malone",
        "description": "Some random event info could be written here."
    }
    try:
        pprint(schema.load(data))
    except ValidationError as err:
        pytest.fail(err.messages)
예제 #13
0
def test_load():
    try:
        data = UserSchema().load(input_user_data)
        marshmallow.pprint(data)
    except marshmallow.ValidationError as err:
        marshmallow.pprint({'errors': err.messages})

    return data
예제 #14
0
def GetBooking(request):
    print(current_user.get_id())
    bookingdetails = Booking.query.filter_by(id=current_user.get_id()).first()
    schema = BookingSchema()
    pprint(schema.dump(bookingdetails).data)
    booking_details = schema.dump(bookingdetails).data
    if request == None:
        return booking_details
    return jsonify(booking_details)
예제 #15
0
def GetUser(request):
    print(current_user.get_id())
    userdetails = User.query.filter_by(id=current_user.get_id()).first()
    schema = UserSchema()
    pprint(schema.dump(userdetails).data)
    user_details = schema.dump(userdetails).data
    if request == None:
        return user_details
    return jsonify(user_details)
예제 #16
0
def api_group(group_id):
    if request.method == 'GET':
        group = Group.query.get(group_id)
        return group_schema.dumps(group)

    elif request.method == 'PUT':
        group = group_schema.load(request.data)
        pprint(group)
        return "Sorry, this endpoint isn't finished yet"
예제 #17
0
def read_xml():
    cool_xml = None

    with open("cool.xml", "r") as f:
        cool_xml = f.read()

    my_cool_dict = xmltodict.parse(cool_xml)

    marshmallow.pprint(my_cool_dict)
예제 #18
0
def api_user(user_id):
    if request.method == 'GET':
        user = User.query.get(user_id)
        return user_schema.dumps(user)

    elif request.method == 'PUT':
        user = user_schema.load(request.data)
        pprint(user)
        return "Sorry, this endpoint isn't finished yet"
예제 #19
0
def test_json(app, base_json, base_nresult):
    print("\n\n\n\n\n")
    print("START")
    print(app)
    print(current_jsonschemas.list_schemas())
    base_json.update(base_nresult)
    pprint(base_json)
    _records_state.validate(
        base_json,
        "https://nusl.cz/schemas/nr_nresults/nr-nresults-v1.0.0.json")
예제 #20
0
파일: marshmallow.py 프로젝트: Tythos/seres
def run_demo():
	# OUTPUT SHOULD BE AS FOLLOWS:
	# { 'artist': {'name': 'David Bowie'},
	#   'release_date': '1971-12-17',
	#   'title': 'Hunky Dory'}
	bowie = dict(name='David Bowie')
	album = dict(artist=bowie, title='Hunky Dory', release_date=date(1971, 12, 17))
	schema = AlbumSchema()
	result = schema.dump(album)
	pprint(result.data, indent=2)	
예제 #21
0
def post_delete(post_id):
    post = Post.query.get_or_404(post_id)
    if post.author != current_user:
        abort(404)
    db.session.delete(post)
    db.session.commit()
    schema = PostSchema()
    result = schema.dump(post)
    pprint({'Delete Success': result.data})
    flash('Delete Successfully', 'success')
    return redirect(url_for('main.home'))
예제 #22
0
파일: app.py 프로젝트: ashish456/Pythonapi
def deleteMenu(pk):
	menu=Menusection.query.filter_by(id=pk).first()
	pprint(menu)
	if menu is None:
		return {"message":"No record related to ID"}

	else:	

		db.session.delete(menu)
		db.session.commit()
		return jsonify({'success':True})
예제 #23
0
def new_post():
    form = NewPostForm()
    if form.validate_on_submit():
        post = Post(title=form.title.data, content=form.content.data, author=current_user)
        db.session.add(post)
        db.session.commit()
        sechma = PostSchema()
        result = sechma.dump(post)
        pprint(result.data)
        return redirect(url_for('main.home'))
    return render_template('NewPost.html', title='New Post', form=form, legend='New Post')
예제 #24
0
def create_user():
    data = request.json
    row = user(data[0], data[0], data[1], data[3], data[2])

    db.session.add(row)
    try:
        db.session.commit()
    except IntegrityError:
        pprint("Error: Duplication of Primary Key")

    return "created"
예제 #25
0
 def post(self):
     notificacion_json = request.get_json()
     # print(notificacion_json)
     n = not_schema_template.load(notificacion_json)
     pprint(n)
     # print("loaded")
     try:
         template = NotificacionTemplateModel()
         if "titulo" in n:
             template.titulo=n["titulo"]
         if "mensaje" in n:
             template.mensaje=n["mensaje"]
         if "imagenIcon" in n:
             template.imagenIcon=n["imagenIcon"]
         if "imagenDisplay" in n:
             template.imagenDisplay=n["imagenDisplay"]
         if "ImagenDisplay" in n:
             template.ImagenDisplay=n["ImagenDisplay"]
         if "bar_text" in n:
             template.bar_text=n["bar_text"]
         if "fecha" in n:
             template.fecha=n["fecha"]
         else:
             template.fecha=dt.datetime.now()
         if  "tipo_notificacion" in n: 
             template.tipo_notificacion=n["tipo_notificacion"]
         if "link" in n:
             template.link=n["link"]
         if "filtros" in n:
             template.filtros = n["filtros"]
         else: 
             template.filtros = []
         template.save()
         if "filtros" in n and n["filtros"] != []:
             filtersObids=[]
             for fil in n["filtros"]:
                 filtersObids.append(ObjectId(fil))
             # Enviar a todos los participantes
             for p in ParticipanteModel.objects.raw({"_id": { "$in": filtersObids}}):
                 # part_id = ObjectId(id)
                 notif = NotificacionModel(
                 id_participante=p._id,
                 id_notificacion=template._id,
                 estado=0,
                 # Estado puede servir para actualizar tambien OJO! ahora esta fijo, pero podrías ser variable
                 ).save()            
                 # PYMODM no tiene soporte transaccional, en un futuro migrar a PYMONGO, que sí tiene soporte
         # return {"message": "Notificacion guardada con éxito."}
     except ValidationError as exc:
         print(exc.message)
         return {"message": "No se pudo crear o enviar la notificacion."}, 404
     return {"message": "Notificacion guardada con éxito.",
                 "id_notificacion": str(template._id),
             "Número de destinatarios:": len(template.filtros)}
예제 #26
0
def create_user():
	data = request.json
	row = user(data[0],data[0],data[1],data[3],data[2])

	db.session.add(row)
	try:
		db.session.commit()
	except IntegrityError:
		pprint("Error: Duplication of Primary Key")

	return "created"	
예제 #27
0
def GetRestaurant(request):
    print(current_user.get_id())
    restaurantdetails = Restaurant.query.filter_by(
        id=current_user.get_id()).first()
    schema = RestaurantSchema()
    pprint(schema.dump(restaurantdetails).data)
    restaurant_details = schema.dump(restaurantdetails).data

    if request == None:
        return restaurant_details
    return jsonify(restaurant_details)
예제 #28
0
파일: app.py 프로젝트: ashish456/Pythonapi
def addNewMenu():
	json_data= request.get_json(force=True)
	pprint(json_data)
	if not json_data:
		return {"message':'No input data provided"},400

	menuSection_schema=MenusectionSchema()
	data= menuSection_schema.load(json_data).data
   

	if data['name'] is None:
		return {"message':'Needs menuSection name"},422
	name=data['name']
	menu=Menusection.query.filter_by(name=name).first()
	if menu is None:
		if data.get('Items') is None:
			menu=Menusection(name=name)
			db.session.add(menu)

		else:
			menu=Menusection(name=name)
			db.session.add(menu)
			for key in data['Items']:
				item=Sectionitems(name=key['name'],price=key['price'])
				if data['Items']['Options'] is None:
					db.session.add(item)
					menu.Items.append(item)

				else:
					db.session.add(item)
					menu.Items.append(item)
					for key in data['Items']['Options']:
						option=Itemoptions(name=key['name'],price=key['price'])
						if data['Items']['Options']['Choices'] is None:
							db.session.add(option)
							item.Options.append(option)

						else:
							db.session.add(option)
							item.Options.append(option)
							for key in data['Items']['Options']['Choices']:
								choice=Itemchoices(name=key['name'],price=key['price'])
								db.session.add(choice)
								option.Choices.append(choice)
	else:
		for key in data.get('Items'):
			item=Sectionitems(name=key['name'],price=key['price'],m_id=menu.id)
			db.session.add(item)
			

	db.session.commit()
	result=menuSection_schema.dump(Menusection.query.get(menu.id))
	return jsonify({'success':True,'menusection':result})
예제 #29
0
 def post(self, event_id):
     json_data = request.get_json()
     data = event_guest_schema.load(json_data)
     pprint(data)
     event_guest = EventGuest(event_id=event_id, **data.data)
     db.session.add(event_guest)
     try:
         db.session.commit()
     except:
         db.session.rollback()
         raise
     return event_guest_schema.dump(event_guest).data, 201
예제 #30
0
 def delete(self, id, accion):
     if accion == 'ninguna':
         n = NotificacionTemplateModel.find_by_id(id)
         if not n:
             return {"message": "No se encontro la notificación"}, 404
         try:
             for p in NotificacionModel.objects.raw({"id_notificacion": n._id}):
                 p.delete()
             n.delete()
         except:
             return {"message": "No se pudo efectuar esta operación"},404 
         return {"message": "Notificacion eliminada"}, 200
     elif accion == 'premio':
         n = NotificacionTemplateModel.find_by_id(id)
         pprint(n)
         if not n:
             return {"message": "No se encontro la notificacion"}, 404
         if n.link != "null" and n.link:
             p = PremioModel.find_by_id(n.link)
             if not p:
                 return {"message": "No se encontro el premio"}, 404
         else: 
             p = None
         try:
             for np in NotificacionModel.objects.raw({"id_notificacion": n._id}):
                 np.delete()
             if n.link != "null" and n.link:
                 for pp in PremioParticipanteModel.objects.raw({"id_premio": p._id}):
                     pp.delete()
                 p.delete()
             n.delete()
         except:
             return {"message": "No se pudo efectuar esta operación"},404 
         return {"message": "Notificación y premio eliminados"}, 200               
     elif accion == 'encuesta':
         n = NotificacionTemplateModel.find_by_id(id)
         pprint(n)
         if not n:
             return {"message": "No se encontro la notificacion"}, 404
         en = EncuestaModel.find_by_id(n.link)
         if not en:
             return {"message": "No se encontro la encuesta"}, 404
         try:
             for np in NotificacionModel.objects.raw({"id_notificacion": n._id}):
                 np.delete()
             for ep in ParticipantesEncuestaModel.objects.raw({"id_encuesta": en._id}):
                 ep.delete()
             n.delete()
             en.delete()
         except:
             return {"message": "No se pudo efectuar esta operación"},404 
         return {"message": "Notificación y encuesta eliminados"}, 200   
예제 #31
0
def get_test_info(testid):
    conn = sqlite3.connect('cmpe273.db')
    c = conn.cursor()

    t = (testid, )
    c.execute("SELECT * FROM tests WHERE id=?", t)

    test = c.fetchone()
    test_id = test[0]
    test_name = test[1]
    keys_str = test[2]  # "A,B,C,D,E"
    test_ans_keys_json = dict(enumerate(keys_str.split(","), 1))

    # res = getres(keys_str, test_id)

    cursor = c.execute(
        "SELECT scantron_id, scantron_url, student_name,subject,score,ques_answers   FROM submissions WHERE test_id=?",
        t)
    names = list(map(lambda x: x[0], cursor.description))
    # row = c.fetchone()
    # col = row.keys()
    rows = c.fetchall()
    submissions = []

    print(names)
    print(rows)

    for x in range(len(rows)):
        temp = {}
        for y in range(len(rows[0])):

            if y == 5:
                print("I am here")
                temp["result"] = getres(
                    dict(enumerate((rows[x][y].split(",")))),
                    keys_str.split(","))
            else:
                temp[names[y]] = rows[x][y]

        submissions.append(temp)

    pprint(submissions)
    conn.commit()
    conn.close()

    return {
        "test_id": test_id,
        "subject": test_name,
        "answer_keys": test_ans_keys_json,
        "submissions": submissions
    }, 200
예제 #32
0
def validate_payload(payload):
    global count
    db = client.expenses_db
    try:
        schema = ExpenseSchema()
        schema.load(payload)
        payload["is_validated"] = True
        db.expenses.insert_one(payload)
        count = count + 1
        print("Total documents inserted: ", count)
    except ValidationError as ve:
        payload["errors"] = ve.messages
        pprint(ve)
        db.expenses_errors.insert_one(payload)
예제 #33
0
파일: user.py 프로젝트: raytham/DoStuff
 def post(self):
     json_data = request.get_json()
     data = user_schema.load(json_data)
     pprint(data)
     user = User(**data.data)
     user.password = bcrypt.hashpw(data.data['password'].encode('utf-8'),
                                   bcrypt.gensalt())
     db.session.add(user)
     try:
         db.session.commit()
     except:
         db.session.rollback()
         raise
     return user_schema.dump(user).data, 201
예제 #34
0
파일: serialize.py 프로젝트: PioTi/learning
from user import User
from schema import UserSchema

from marshmallow import pprint

user = User(name='M K', email='*****@*****.**')
schema = UserSchema()
result = schema.dump(user)
pprint(result.data)

json_result = schema.dumps(user)
pprint(json_result.data)

예제 #35
0
 def pprint(self, obj, *args, **kwargs):
     """Pretty-printing helper that can handle `OrderedDict`s."""
     ma.pprint(obj, *args, **kwargs)
예제 #36
0
        self.name = name
        self.email = email
        self.created_at = dt.datetime.now()

    def __repr__(self):
        return '<User(name={self.name!r})>'.format(self=self)


class UserSchema(Schema):
    name = fields.Str()
    email = fields.Email()
    created_at = fields.DateTime()


if __name__ == '__main__':
    user = User(name='Kasheem', email='*****@*****.**')
    schema = UserSchema()
    # USAGE OF ONLY PARAMETER
    # summary_schema = UserSchema(only=('name', 'email'))
    result = schema.dump(user)
    pprint(result.data)
    # pprint(json_result.data)

    #COLLECTIONS
    user1 = User(name='Mick', email='*****@*****.**')
    user2 = User(name='Keith', email='*****@*****.**')
    users = [user1, user2]
    schema = UserSchema(many=True)
    result = schema.dump(users)
    pprint(result.data)
예제 #37
0
from datetime import date
import pickle
import sys
from marshmallow import Schema, fields, pprint

class ArtistSchema(Schema):
    name = fields.Str()
    release_date = fields.Date()
    number_of_times_sold = fields.Number()

if __name__ == '__main__':
    schema = ArtistSchema()
    data = {'name': 'this is an artist', 'release_date': date(1970, 4, 2), 'number_of_times_sold': 4929492}
    data_str = str(data)
    result = schema.dump(data)
    pck_data = pickle.dumps(result.data)
    pprint(result.data, indent=2)
    print 'size of original data as dict: %s' % sys.getsizeof(data)
    print 'size of original data as string: %s' % sys.getsizeof(data_str)
    print 'size of data after marshalling: %s' % sys.getsizeof(result.data)
    print 'size of data after pickling: %s' % sys.getsizeof(pck_data)
    print 'size of entire marshalling result: %s' % sys.getsizeof(result)
    print '[x]: marshalled data:'
    print result.data
    print '[x]: pickled data:'
    print pck_data
    print '[x]: marshalled result:'
    print result
예제 #38
0
 def test_nested_meta_many(self):
     serialized_blog = BlogUserMetaSerializer(self.blog)
     assert_equal(len(serialized_blog.data['collaborators']), 2)
     pprint(serialized_blog.data['collaborators'][0])
     assert_equal(serialized_blog.data['collaborators'],
         [UserMetaSerializer(col).data for col in self.blog.collaborators])